-
-
Notifications
You must be signed in to change notification settings - Fork 544
Requests
Nestjsx/crud provides a full range of path and query parameters parsing/validation to help you build rich RESTful APIs. @nestjsx/crud-request is responsible for that.
By default, we support these param names:
fields
, select
- get selected fields in GET result
s
- search conditions ($and
, $or
with all possible variations)
filter
- filter GET result by AND
type of condition
or
- filter GET result by OR
type of condition
join
- receive joined relational resources in GET result (with all or selected fields)
sort
- sort GET result by some field
in ASC | DESC
order
per_page
, limit
- limit the amount of received resources
offset
- offset some amount of received resources
page
- receive a portion of limited amount of resources
cache
- reset cache (if was enabled) and receive resources directly from the DB
Notice: You can easily map your own query params names and chose another string delimiters by applying global options.
Here is the description of each of those using default params names:
Selects fields that should be returned in the reponse body.
Syntax:
?fields=field1,field2,...
Example:
?fields=email,name
Adds a search condition as a JSON string to you request. You can combine $and
, $or
and use any condition you need. Make sure it's being sent encoded or just use RequestQueryBuilder
Syntax:
?s={"name": "Michael"}
Some examples:
- Search by field
name
that can be eithernull
OR equalsSuperman
?s={"name": {"$or": {"$isnull": true, "$eq": "Superman"}}}
- Search an entity where
isActive
istrue
ANDcreatedAt
not equal2008-10-01T17:04:32
?s={"$and": [{"isActive": true}, {"createdAt": {"$ne": "2008-10-01T17:04:32"}}]}
...which is the same as:
?s={"isActive": true, "createdAt": {"$ne": "2008-10-01T17:04:32"}}
- Search an entity where
isActive
isfalse
ORupdatedAt
is notnull
?s={"$or": [{"isActive": false}, {"updatedAt": {"$notnull": true}}]}
So the amount of combinations is really huge.
Notice: if search query param is present, then filter and or query params will be ignored.
-
$eq
(=
, equal) -
$ne
(!=
, not equal) -
$gt
(>
, greater than) -
$lt
(<
, lower that) -
$gte
(>=
, greater than or equal) -
$lte
(<=
, lower than or equal) -
$starts
(LIKE val%
, starts with) -
$ends
(LIKE %val
, ends with) -
$cont
(LIKE %val%
, contains) -
$excl
(NOT LIKE %val%
, not contains) -
$in
(IN
, in range, accepts multiple values) -
$notin
(NOT IN
, not in range, accepts multiple values) -
$isnull
(IS NULL
, is NULL, doesn't accept value) -
$notnull
(IS NOT NULL
, not NULL, doesn't accept value) -
$between
(BETWEEN
, between, accepts two values) -
$eqL
(LOWER(field) =
, equal) -
$neL
(LOWER(field) !=
, not equal) -
$startsL
(LIKE|ILIKE val%
) -
$endsL
(LIKE|ILIKE %val
, ends with) -
$contL
(LIKE|ILIKE %val%
, contains) -
$exclL
(NOT LIKE|ILIKE %val%
, not contains) -
$inL
(LOWER(field) IN
, in range, accepts multiple values) -
$notinL
(LOWER(field) NOT IN
, not in range, accepts multiple values)
Adds fields request condition (multiple conditions) to your request.
Syntax:
?filter=field||$condition||value
?join=relation&filter=relation.field||$condition||value
Notice: Using nested filter shall join relation first.
Examples:
?filter=name||$eq||batman
?filter=isVillain||$eq||false&filter=city||$eq||Arkham (multiple filters are treated as a combination of
AND
type of conditions)
?filter=shots||$in||12,26 (some conditions accept multiple values separated by commas)
?filter=power||$isnull (some conditions don't accept value)
Adds OR
conditions to the request.
Syntax:
?or=field||$condition||value
It uses the same filter conditions.
Rules and examples:
- If there is only one
or
present (withoutfilter
) then it will be interpreted as simple filter:
?or=name||$eq||batman
- If there are multiple
or
present (withoutfilter
) then it will be interpreted as a compination ofOR
conditions, as follows:
WHERE {or} OR {or} OR ...
?or=name||$eq||batman&or=name||$eq||joker
- If there are one
or
and onefilter
then it will be interpreted asOR
condition, as follows:
WHERE {filter} OR {or}
?filter=name||$eq||batman&or=name||$eq||joker
- If present both
or
andfilter
in any amount (one or miltiple each) then both interpreted as a combitation ofAND
conditions and compared with each other byOR
condition, as follows:
WHERE ({filter} AND {filter} AND ...) OR ({or} AND {or} AND ...)
?filter=type||$eq||hero&filter=status||$eq||alive&or=type||$eq||villain&or=status||$eq||dead
Adds sort by field (by multiple fields) and order to query result.
Syntax:
?sort=field,ASC|DESC
Examples:
?sort=name,ASC
?sort=name,ASC&sort=id,DESC
Receive joined relational objects in GET result (with all or selected fields). You can join as many relations as allowed in your CrudOptions.
Syntax:
?join=relation
?join=relation||field1,field2,...
?join=relation1||field11,field12,...&join=relation1.nested||field21,field22,...&join=...
Examples:
?join=profile
?join=profile||firstName,email
?join=profile||firstName,email&join=notifications||content&join=tasks
?join=relation1&join=relation1.nested&join=relation1.nested.deepnested
Notice: primary field/column always persists in relational objects. To use nested relations, the parent level MUST be set before the child level like example above.
Receive N
amount of entities.
Syntax:
?limit=number
Example:
?limit=10
Limit the amount of received resources
Syntax:
?offset=number
Example:
?offset=10
Receive a portion of limited amount of resources.
Syntax:
?page=number
Example:
?page=2
Reset cache (if was enabled) and receive resources directly from the DB.
Usage:
?cache=0
@nestjsx/crud-request is a framework agnostic package that has been designed for both backend and frontend usage. It's also used by @nestjsx/crud package in CrudRequestInterceptor
.
It has RequestQueryBuilder
class that helps building a query string and customizing your query params names and delimiters.
It has a static method setOptions
that alows you to set different params names (defaults are shown):
import { RequestQueryBuilder } from "@nestjsx/crud-request";
RequestQueryBuilder.setOptions({
delim: "||",
delimStr: ",",
paramNamesMap: {
fields: ["fields", "select"],
search: "s",
filter: ["filter[]", "filter"],
or: ["or[]", "or"],
join: ["join[]", "join"],
sort: ["sort[]", "sort"],
limit: ["per_page", "limit"],
offset: ["offset"],
page: ["page"],
cache: ["cache"]
}
});
You can compose a query string in a chaining methods manner:
import { RequestQueryBuilder, CondOperator } from "@nestjsx/crud-request";
const qb = RequestQueryBuilder.create();
// set search
qb.search({
$or: [
{
foo: {
$notnull: true
},
baz: 1
},
{
bar: {
$ne: "test"
}
}
]
});
// is actually the same as:
qb.setFilter({ field: "foo", operator: CondOperator.NOT_NULL })
.setFilter({ field: "baz": operator: "$eq", value: 1 })
.setOr({
field: "bar",
operator: CondOperator.NOT_EQUALS,
value: "test"
});
qb.select(["foo", "bar"])
.setJoin({ field: "company" })
.setJoin({ field: "profile", select: ["name", "email"] })
.sortBy({ field: "bar", order: "DECS" })
.setLimit(20)
.setPage(3)
.resetCache()
.query();
Or, you can path all params to the create
method:
const queryString = RequestQueryBuilder.create({
fields: ["name", "email"],
search: { isActive: true },
join: [{ field: "company" }],
sort: [{ field: "id", order: "DESC" }],
page: 1,
limit: 25,
resetCache: true
}).query();