...
Introduction
The endpoints of this service allow createation or modification of the object instances. It is required to configure the service like for the views.
Configuration
Each action is associated to an identifier and a configuration JSON.
JSON example
Code Block |
---|
{
"objectname": "name of the object",
"create": true, // indicates if new instances creation is allowed
"patch": false, // indicates if partial modification of properties is allowed
"workflow": true, // indicates if workflow modification (per action) is allowed
"props": { // List of modifiable properties and their configurations
"name of the property": null
}
} |
Code Block |
---|
Properties and sections
objectname: String - Name of the object (type)
description: String - Short description of action
props: Section properties An object which properties are property names that should be exported. It is possible to configure some options, and some formating action or value validation. But it has limitation for a complex rule, the trigger should be used. Cf. hereafter for the configuration detail.
create: A boolean to allow creation
patch: A boolean to allow the modification of some specific properties (by default all configured properties shall be filled)
workflow: A boolean that allows to modify the workflow (thru workflow actions)
lock: A boolean that allows to lock or unlock objects
since 11.11reportprops: an array of properties of the created object that you want to include in the response
since 11.12updatequery: An optional selection request following JSON type specific language used within "create or update" mode. The values of the key properties (or others) are configurable in the query by the syntax ${<variable identifier>}:
to reference a key property, use its name as identifier
example: ${name}to reference the associated property in the clause, simply use a question mark (?)
example: ${?}to reference any parameter of the http request, prefix the name of parameter with "par:".
example: ${par:p_activated}
For example:
Code Block { "product": "${?}", "businessunit": "${?}" }
Properties configuration
It is possible to configure the assignment of a value to a property by defining a configuration object for the property.
If no configuration is defined, a null object shall be defined:
Code Block |
---|
"props": {
"name": null
} |
Depending on the data types, several configuration can be done: the indicators which are not corresponding to the available properties will be ignored. The configuration is split in 4 sections:
check: verification
pattern: allows the indication of a regular expression that value must verify (works with character string: text, data/word, sentence, html, image access path and file path (in this case backslashes should be considered as slashes) For example:
Code Block "file": { "check": { "pattern": "^.*\\.(docx|doc)$" } }
min: allows the definition of a minimal value included in the interval (works with numbers: integer, floating, currencies) For example:
Code Block "nbr": { "check": { "min": 1 } }
max: allows the definition of a maximal value included in the interval (works with numbers: integer, floating, currencies) For example:
Code Block "Quarter": { "check": { "min": 1, "max": 4 } }
values: Allows the indication of a list of value (table), among which the assigned value must be available (works for character string and numbers) For example:
Code Block "code": { "check": { "values": ["ARPA","TEGA","GOBA","NBPC"] } }
format: formating
trim: allows deletion of useless white spaces
right: delete right white spaces For example:
Code Block "value": { "format": { "trim": "right" } }
left: delete left white spaces For example:
Code Block "value": { "format": { "trim": "left" } }
true: delete right and left white spaces For example:
Code Block "value": { "format": { "trim": true } }
Code Block replace: allows replacement of some part of a character strings. Value is an object with two properties
pattern: a regular expression
replace: the replacing string
For example, to put all numbers between parenthesis except if they already are:
Code Block "value": { "replace": { "pattern": "(?<!\\()(\\d++)(?!\\))", "replace": "($1)" } }
case: to change the case
upper: to go uppercase
lower: to go lowercase
sentence: to have the full sentence in lowercase and only the first letter in uppercase
word: to have all characters in lowercase except the first letter of each word that will be in uppercase
i18n: localization
By default whenever a localized property is modified, the property corresponding to the language of the request is modified (lang parameter).
For example, if a property value (i18n), value_fr (i18n of value), value_en (i18n of value)If the request local is en
If we modify value, then value_en is modified
If we modify value_fr, then value_en is modified
This configuration property allows to modify this default behavior.
true: the hereinabove rules are applied
false: the specified property is modified. If we keep the same examples:
(3) If we modify value, then value is modified
(4) If we modify value_fr, then value_fr is modified
So if false then we only modify specified property else we check if the property is in the correct local; if true the correct local is directly modified; if default we raise an exception.
since 11.11byvalue: a boolean to enabled relational relationships assignation or creation by value (see create). Default to false. When this option is set to true, for relational properties, values can be passed instead of object identifiers. The corresponding object is searched for and if it does not exist, it is created with the specified value as its name. Finally, it is the object identifier that is affected. Use formatting options to limit the creation of duplicates.
since 11.11valueProperty: if relational relationships assignation is selected, indicates the name of property used to find the object corresponding to the value. it is possible to specify an array of properties if the object must be created or selected in relation to several values: in that case, the value of the parameter must be a json object, with all properties and their respective value.
since 11.11create: a boolean to enabled creation by value (see byvalue). Default to true.
since 11.18lockCaptureTimeout: the timeout value to capture a lock used with "by value" mode to handle simultaneous access (in seconds)
since 11.18lockAcquireTimeout: the timeout value to acquire a lock used with "by value" mode to handle simultaneous access (in seconds)
since 11.11pathseparator: a regular expression to break the paths into names. Default is \ (example of value: Europe \ Great Britain \ England \ (Greater) London \ City of London \ Hampstead).When assigning by value (see byvalue), it is possible to manipulate tree-like data by specifying a path, consisting of several successive names. The division of the value into names of the different objects is done according to this regular expression.
For example:
Code Block "metadatalocation": { "byvalue": true, "format": { "trim": true, "case": "sentence" }, "pathseparator": "\|" }
force: a boolean to force the modification of status property. By default, it is not possible to modify the assignment of position 7 property (status): a workflow action is required. But for ascending compatibility with the former workflow system, it is possible to modify the status by a value assignment via this property.
since 11.12key: a boolean to set this property as key for the "create or update" mode. This feature is not yet supported for children or collection properties.
EndPoints
There are seven endpoints available
To modify, partially modify or create
To modify a workflow by an action
To get the list of workflow actions
To get the list of available actions
To get object locks
To lock objects
To unlock objects
EndPoint: modify
since 11.14
Code Block |
---|
PUT http://host:port/app/api/json/update/{actionName}/{id}
PATCH http://host:port/app/api/json/update/{actionName}/{id} |
since 11.12
Code Block |
---|
PUT http//host:port/app/api/json/update
PATCH http//host:port/app/api/json/update
PUT http//host:port/app/api/json/update
PATCH http//host:port/app/api/json/update |
Legacy endpoint:
Code Block |
---|
http//host:port/app/_plugins/WXM_RESTAPI/page/update.jspz |
Supported methods: PUT, PATCH
The difference between the two methods is that PUT imposes the modification of all configured properties whereas PATCH allows the modification of some properties
Parameters
actionName: Character string, action identifier
id (or form_id): Identifier of the current instance
prop_<x>: the value to assign to the x property (cf. hereafter properties values assignment)
since 11.12rawValues Boolean - Indicates if we apply the localization (false by default) in reported properties
since 11.12headers: Boolean - Indicates if headers are required (Cf. hereafter, response format) (false by default)
since 11.12report: Boolean - Indicates if properties of the created object must be reported (if configured so) (true by default)
Security
The update action of the RESTAPI domain allows the management of the endpoint call authorisation.
There are two parameters:
surfer: surfer
actionName: the action identifier
Errors codes
HTTP Code | API Code | Definition |
---|---|---|
404 | 404/200 | Unknown action |
403 | 403/201 | Forbidden modification |
403 | 403/202 | Forbidden partial modification |
403 | 403/204 | The user grants doesn’t allow to modify an object |
403 | 403/205 | The user grants doesn’t allow to modify this object |
403 | 403/206 | Forbidden to modify a property |
404 | 404/900 | Object not found |
400 | 400/900 | Missing content |
since 11.11 400 | 400/900 | Not allowed value |
since 11.11 400 | 400/900 | Not allowed to creae value |
since 11.11 500 | 500/901 | Cannot create value (server error) |
EndPoint: create
since 11.14
Code Block |
---|
POST http://host:port/app/api/json/create/{actionName} |
since 11.12
Code Block |
---|
POST http://host:port/app/api/json/update |
Legacy endpoint:
Code Block |
---|
http//host:port/app/_plugins/WXM_RESTAPI/page/update.jspz |
Supported method: POST
Parameters
actionName: Character string, action identifier
prop_<x>: The value assigned to the x property (cf. hereafter properties values assignment)
since 11.11
rawValues Boolean - Indicates if we apply the localization (false by default) in reported properties
since 11.11
headers: Boolean - Indicates if headers are required (Cf. hereafter, response format) (false by default)
since 11.11
report: Boolean - Indicates if properties of the created object must be reported (if configured so) (true by default)
Response format
The response to the endpoint call contains the identifier of the newly created resource (field createdId).
Code Block |
---|
{
"actionName": "asset",
"response": {
"createdId": "10004"
},
"status": 201,
"time": 1435
} |
Security
The create action of RESTAPI domain allows to manage the endpoint call authorization.
There are two parameters:
surfer: surfer
actionName: the action identifier
Errors codes
HTTP Code | API Code | Definition |
---|---|---|
404 | 404/200 | Unknown action |
403 | 403/200 | Forbidden creation |
403 | 403/202 | Forbidden partial modification |
403 | 403/203 | The user grants doesn’t allow to create an object |
400 | 400/900 | Missing content |
since 11.11 400 | 400/900 | Not allowed value |
since 11.11 400 | 400/900 | Not allowed to creae value |
since 11.11 500 | 500/901 | Cannot create value (server error) |
EndPoint: Apply workflow action
since 11.14
Code Block |
---|
PATCH http://host:port/app/api/json/workflow/{actionName}/{id} |
since 11.12
Code Block |
---|
PATCH http://host:port/app/api/json/workflow |
Legacy endpoint:
Code Block |
---|
http//host:port/app/_plugins/WXM_RESTAPI/page/workflow/do.jspz |
Supported method: PATCH
Parameters
actionName: Character string, action identifier
id (or form_id): Identifier of current instance
action: Identifier or name of the action to be applied
Security
The workflow_do action of RESTAPI domain allows the management of the endpoint call authorization.
There are two parameters:
surfer: surfer
actionName: the action identifier
Errors codes
HTTP Code | API Code | Definition |
---|---|---|
404 | 404/200 | Unknown action |
403 | 403/207 | Forbidden workflow modification |
403 | 403/208 | Forbidden workflow action |
EndPoint: list of available workflow actions
since 11.14
Code Block |
---|
GET http://host:port/app/api/json/workflow/{actionName}/{id}
HEAD http://host:port/app/api/json/workflow/{actionName}/{id} |
since 11.12
Code Block |
---|
GET http://host:port/app/api/json/workflow |
Legacy endpoint:
Code Block |
---|
http//host:port/app/_plugins/WXM_RESTAPI/page/workflow/actions.jspz |
Supported methods: GET, HEAD
Parameters
actionName: Character string, action identifier
id (or form_id): Instance identifier for which we want to know the available actions
rawValues: Boolean that indicates if we need to localize terms (false by default)
onlyAllowed: Boolean, optional, to get only allowed action by the user (false by default)
Response format
Code Block |
---|
{
"response": {
"data": {
"Action identifier": "action label, or action name in rawValues mode"
}
},
"status": 200,
"time": 11121
}
|
Code Block |
---|
Security |
The workflow_actions action of RESTAPI domain allows the management of the endpoint call authorization.
There are two parameters:
surfer: surfer
actionName: the action identifier
EndPoint: obtain the status of object locks
since 11.14
Code Block |
---|
GET http://host:port/app/api/json/lock/{actionName}/{id*}
HEAD http://host:port/app/api/json/lock/{actionName}/{id*} |
since 11.12
Code Block |
---|
GET http://host:port/app/api/json/lock |
Legacy endpoint:
Code Block |
---|
http//host:port/app/_plugins/WXM_RESTAPI/page/getlocks.jspz |
Supported methods: GET, HEAD
Parameters
actionName: Character string, action identifier
id (or form_id): The identifier of the instance to be locked (multiple possible values)
Response format
Code Block |
---|
{
"actionName": "asset",
"response": [
{
"id": "1444",
"locked": true,
"owner": "user122"
},
{
"id": "1051",
"locked": false,
"owner": null
},
],
"status": 200,
"time": 44
} |
Security
The locks_get action of RESTAPI domain allows the management of the endpoint call authorization.
There are two parameters:
surfer: surfer
actionName: the action identifier
Errors codes
HTTP Code | API Code | Definition |
---|---|---|
403 | 403/210 | Forbidden action |
EndPoint: put locks on objects
since 11.14
Code Block |
---|
POST http://host:port/app/api/json/lock/{actionName}/{id*} |
since 11.12
Code Block |
---|
POST http://host:port/app/api/json/lock |
Legacy endpoint:
Code Block |
---|
http//host:port/app/_plugins/WXM_RESTAPI/page/lock.jspz |
Supported methods: POST
Parameters
actionName: Character string, action identifier
id (or form_id): The identifier of the instance to be locked (multiple possible values)
duration: Number, optional, lock duration in seconds
Response format
Code Block |
---|
{
"actionName": "asset",
"response": [
{
"id": "104",
"locked": true,
"status": "locked",
"info": "user133"
},
{
"id": "105",
"locked": true,
"status": "lock extended",
"info": "user133"
},
{
"id": "222",
"locked": false,
"status": "already locked",
"info": "user122"
},
{
"id": "477",
"locked": null,
"status": "error",
"info": "Can't find object with id 477"
}
],
"status": 200,
"time": 44
} |
Code Block |
---|
The locked property indicates if you get the lock (true) or not (false). The status property indicates the status of the object, and info specifies this status: |
in case of error, the status is error and info is the error message. The current lock status is null if the error occurred when querying the current lock status.
if the instance was not locked and becomes locked, the status is locked and the info is the name of the owner of the lock (the user who is invoking the service)
if the instance was already locked by the calling user, the lock is extended, and the status is lock extended
if the instance was locked but by another user, the status is already locked and info is the current owner’s name
Security
The lock action of RESTAPI domain allows the management of the endpoint call authorization.
There are two parameters:
surfer: surfer
actionName: the action identifier
Errors codes
HTTP Code | API Code | Definition |
---|---|---|
403 | 403/211 | Forbidden lock action |
EndPoint: remove locks on objects
since 11.14
Code Block |
---|
DELETE http://host:port/app/api/json/lock/{actionName}/{id*} |
since 11.12
Code Block |
---|
DELETE http://host:port/app/api/json/lock |
Legacy endpoint:
Code Block |
---|
http//host:port/app/_plugins/WXM_RESTAPI/page/unlock.jspz |
Supported methods: DELETE
Parameters
actionName: Character string, action identifier
id (or form_id): The identifier of the instance to be locked (multiple possible values)
Response format
Code Block |
---|
{
"actionName": "asset",
"response": [
{
"id": "124",
"locked": false,
"status": "not locked",
"info": null
},
{
"id": "118",
"locked": false,
"status": "unlocked",
"info": null
},
{
"id": "222",
"locked": true,
"status": "not owner",
"info": "user122"
},
{
"id": "477",
"locked": null,
"status": "error",
"info": "Can't find object with id 477"
}
],
"status": 200,
"time": 44
}
|
Code Block |
---|
The locked property indicates if the object is still locked (true) or not (false). The status property indicates the status of the object, and info specifies this status: |
in case of error, the status is error and info is the error message. The current lock status is null if the error occurred when querying the current lock status.
if the instance wasn’t locked, the status is not locked and the info is null.
if the instance was locked by the calling user, the status is unlocked the info is null
if the instance was locked but by another user, the status is not owner and info is the current owner’s name
Security
The unlock action of RESTAPI domain allows the management of the endpoint call authorization.
There are two parameters:
surfer: surfer
actionName: the action identifier
Errors codes
HTTP Code | API Code | Definition |
---|---|---|
403 | 403/210 | Forbidden lock view |
403 | 403/211 | Forbidden lock action |
403 | 403/212 | Forbidden unlock action |
403 | 500/200 | Cannot lock object |
EndPoint: list of available actions
since 11.12
Code Block |
---|
GET http://host:port/app/api/json/catalog/update |
Legacy endpoint:
Code Block |
---|
http//host:port/app/_plugins/WXM_RESTAPI/page/catalog/updateaction.jspz |
Supported methods: GET, HEAD
Parameters
actionName: Character string, an option regular expression filter (by default, all actions are accessible)
headers: Boolean indicates if headers are required or not (cf. hereafter, response format) (false by default).
Response format
Code Block |
---|
{
"catalog": "List of modification action, creation and workflow actions",
"request": {
"parameters": {
"headers": "true"
}
},
"response": {
"data": [ {
"name": "name of the action",
"actions": [ // Possible actions (create, update, patch, workflow)
"update",
"workflow"
],
"view": "default view to get the properties",
"properties": [ "name of property 1", "name of property 2", "name of property 3" ],
"headers": {
"name of the property": {
"name": "localized label of the property",
"type": "type of the property"
},
"name ot the resource type property": {
"name": "localized label of the property",
"type": "resource",
"attachment": true, // true or false if the file is in attachment or not
}
}
}
],
"links": {
"href": "http://host:port/app/_plugins/WXM_RESTAPI/page/catalog/updateaction.jspz?headers=true"
},
"status": 200,
"time": 131
}
}
|
Security
The catalog action of RESTAPI domain allows the management of the endpoint call authorization.
There are two parameters:
surfer: surfer
endPoint: the endpoint identifier, with update value.
Errors codes
HTTP Code | API Code | Definition |
---|---|---|
403 | 403/209 | Actions catalog not reachable |
Assigning property values
To assign a value to a property, please pass the prop_ prefixed property name as a parameter, as well as its value.
For instance, to assign the value Example to the name property: prop_name=Example
Character strings
Just indicate the value. For a null value, we shall use #NULL.
Examples:
Code Block |
---|
prop_name=Example (to assign the "Example" value)
prop_name=#null (to assign the NULL value)
prop_name= (to assign the Void value) |
Numbers
Just mention the value. For a float number, we shall use decimal point (.) to set the decimal position. For a null value, use a void value.
Examples:
Code Block |
---|
prop_val=42
prop_val=3.14159
prop_val= |
booleans
True stands for the true logical value, false for the false one or nothing for null.
Examples:
Code Block |
---|
prop_activated=true
prop_activated=false
prop_x= |
dates
Dates are passed either as timestamps (UTC unix time), or in ISO format
Examples:
Code Block |
---|
prop_date="20160317T123000"
prop_date="2016-03-17T12:30:00"
prop_date=1458169200000 |
children (object)
Children are referenced through their ID. It is not possible to assign a non existing object.
Example:
Code Block |
---|
prop_link=10070
|
multiple children (array)
To assign several values we shall mention the parameter on several times.
Examples:
Code Block |
---|
prop_links=10070 (to assign an ID)
prop_links=10070&prop_links=10071&prop_links=10072 (to assign three IDs)
prop_metadatacategory=Manufacturing (to assign by value)
prop_metadatacategory={"category":"Manufacturing","subcategory":"Small appliances"} (to assign by value, multiple values)
prop_metadatacategory={"id":123} (to assign by value, directly with id) |
files
Binary file content is passed in multipart mode (multipart/form-data). It is possible to indicate a replacement name for the file by passing it as a parameter.
We can to follow through a download by indicating an identification number via the parameter. The appropriate method to follow-up download progress is similar to the one detailed here.
since 11.12 It is possible also to pass an URL as value. To set the name, pass a json value like in this example :
Code Block |
---|
prop_image={"url":"http:8080//myimageserver/logos/brandsimplelogo.png","name":"myimage.png"} |
Create or update mode
It is possible to configure an action to operate in "create or update" mode. By default, a POST on the endpoint "create" creates a new object instance and a PUT on the endpoint "modify" modifies a time point designated by its identifier (parameter id).
With "create or update" mode, with all endpoints, we first determine if the object exists: if it exists, it is modified, otherwise it is created.
This mode is activated as soon as a property is designated as key, with the key configuration property. We search for the object instance (or instances) whose key values are equal to those passed as parameters: if it exists, it is modified, otherwise a new instance is created.
It is possible to use a specific query to search for the object instance by the updatequery configuration property.