resource-action-api
v2.1.45
Published
Requests to `/resources` must have a body that has the following format:
Downloads
21
Readme
POST
/resources
Requests to /resources
must have a body that has the following format:
{
[actionKey]: {
[resourceKey]: <params|[params]>,
...
},
...
}
actionKey
:
get
- request data for resource(s)create
- create resource(s)update
- update resource(s)destroy
- delete resource(s)
resourceKey
:
- there are many
resourceKey
s, such asproducts
andprojects
. resourceKey
s can be:- singular, like
product
, in which case it is considered aone
request (which has one corresponding result) - plural
- singular, like
- usually the value of a
resourceKey
will be an object -params
- occasionally, the value of a
resourceKey
will be an array ofparams
objects -[params, ...]
| param | behavior | value format | works with |
| --- | --- | --- | --- |
| where
| WHERE field = value AND ...
| {<field>:<value>}
| get
, update
, destroy
|
| props
| SET field = value
| {<field>:<value>}
| create
, update
|
| fields
| SELECT field, ...
| [<field>]
| get
|
| order
| ORDER BY field, ...
| [<field|{field, direction}>]
| get
|
| include
| include related resource
s | {<resourceKey>: <params>>
| get
|
| limit
| LIMIT X
| int
| get
|
| page
| LIMIT X, Y
| {count: int, number: int}
| get
|
where
default behavior: AND
- {where: {id: 1, type: 2}}
-> WHERE id = 1 AND type = 2
to achieve more complex where statements, the following syntax may be used (TODO):
{where: ['and', ['or', {productId: 1, materialId: 2}], {type: 'image'}]}
- recursively apply middleware? using pseudo field?
Responses
Responses come back in a format that corresponds to the request:
{success: true, data: {
[actionKey]: {
[singular resourceKey]: {props: {}}
[plural resourceKey]: [{props: {}}]
}
}}
resource
:
- an object of the format
{props: {}}
- only
get
, andcreate
respond with resources, sodata.resources
will never have the keysupdate
ordestroy
Example request and response:
var request = {
get: {
project: {where: {id: 1}},
products: {where: {categoryId: 1}, order: ['rank'], fields: ['id', 'title']},
},
update: {
project: {where: {id: 1}, props: {title: 'p1'}},
projects: {where: {zip: 10000}, props: {title: 'p2'}},
elevations: [{where: {id: 1}, props: {title: 'p3'}}, {where: {id: 2}, props: {title: 'p4'}}]
},
create: {
product: {where: {zip: 10000}, props: {title: 'p1'}},
projects: [{props: {title: 'p1'}}, {props: {title: 'p2'}}]
},
destroy: {
product: {where: {id: 1}},
projects: {where: {zip: 10000}}
}
};
var response = {
resources: {
get: {
project: {},
products: [{}, ...],
},
update: {
project: {},
projects: [{}, ...],
elevations: [{}, ...]
},
create: {
product: {},
projects: [{}, ...]
},
destroy: {
product: {},
projects: [{}, ...]
}
}
}