4.8.1.2.5. Коммит новых и измененных экземпляров, удаление
Функция коммита позволяет выполнять операции над переданными ей объектами и возвращает их новое состояния. Формат результата определяется тем, какой формат (JSON или XML) был использован для запроса (заголовок Content-Type
).
- Формат JSON
-
В качестве заголовка
Content-Type
следует использовать значениеapplication/json
.Создание сущности покупателя с автоматически сгенерированным идентификатором:
{ "commitInstances": [{ "id": "NEW-sales$Customer", "name": "Saltikov", "email": "saltikov@mail.com" } ] }
Создание сущности покупателя с указанным идентификатором:
{ "commitInstances": [{ "id": "NEW-sales$Customer-b32a6412-d4d9-11e2-a20b-87b22b1460c7", "name": "Titov", "email": "titov@mail.com" } ] }
Создание сущности заказа с указанием ссылки на новую сущность покупателя и заполнение атрибутами сущности данного покупателя:
{ "commitInstances": [{ "id": "NEW-sales$Order", "amount": 15, "customer": {"id": "NEW-sales$Customer-b32e43e8-d4d9-11e2-8c8b-2b2939d67fff" } },{ "id": "sales$Customer-b32e43e8-d4d9-11e2-8c8b-2b2939d67fff", "name": "Dudkin", "email": "dudkin@mail.com" } ] }
Изменение одновременно двух сущностей покупателей:
{ "commitInstances": [{ "id": "sales$Customer-b32e43e8-d4d9-11e2-8c8b-2b2939d67fff", "email": "dudkin@mail.ru" }, { "id": "sales$Customer-32261b09-b7f7-4b8c-88cc-6dee6fa8e6ab", "email": "saltikov@mail.ru" } ] }
Удаление сущности покупателя с поддержкой мягкого удаления:
{ "removeInstances": [{ "id": "sales$Customer-b32e43e8-d4d9-11e2-8c8b-2b2939d67fff" } ], "softDeletion": "true" }
-
Массив
commitInstances
содержит создаваемые или изменяемые сущности.-
При создании сущности в качестве значения поля
id
указывается значениеNEW-<entityName>
илиNEW-<entityName>-<entityId>
. -
При изменении сущности в качестве значения поля
id
указывается значение<entityName>-<entityId>
. -
Далее в списке элементов через запятую указываются названия атрибутов создаваемой или изменяемой сущности и их значения.
Если при изменении сущности требуется установить какой-либо атрибут в
null
, то в идентификаторе необходимо указать также представление, включающее этот атрибут. Например:{ "commitInstances": [{ "id": "sales$Customer-b32a6412-d4d9-11e2-a20b-87b22b1460c7-customer-edit", "name": "John Doe", "channel": null } ] }
-
Здесь представление
customer-edit
должно содержать атрибутchannel
, в противном случае его значение не изменится. Для установки вnull
локального атрибута можно указать всегда доступное представление_local
.-
Массив
removeInstances
содержит удаляемые объекты. При удалении объекта обязательно указывать значение поляid
. Перед удалением будет выполненmerge()
переданных объектов, что позволяет, например, проверить, не изменилась ли версия удаляемого объекта. -
Поле
softDeletion
управляет режимом мягкого удаления.
Функция вызывается посредством POST обращения к
{host:port}/app-portal/api/commit?s=<sessionId>
. JSON передается в теле запроса. Функция возвращает массив объектов JSON. Например, при изменении поляemail
у сущности покупателя будет возвращен следующий массив объектов JSON:[ {"id":"sales$Customer-32261b09-b7f7-4b8c-88cc-6dee6fa8e6ab", "createTs":"2013-06-14T14:07:15.040", "createdBy":"admin", "deleteTs":null, "deletedBy":null, "email":"saltikovvvv@mail.ru", "name":"Saltikov", "updateTs":"2013-06-14T15:07:03.463", "updatedBy":"admin", "version":"3" } ]
-
- Формат XML
-
В качестве заголовка
Content-Type
следует использовать значениеtext/xml
.Пример формата XML
<CommitRequest> <commitInstances> <instance id="sales$Order-9873c8a8-d4e7-11e2-85c0-33423bc08c84"> <field name="date">2015-01-30</field> <field name="amount">3500.00</field> <reference name="customer" id="sales$Customer-32261b09-b7f7-4b8c-88cc-6dee6fa8e6ab"/> </instance> </commitInstances> <removeInstances> <instance id="sales$Customer-d67c10f0-4d28-4904-afca-4bc45654985d"/> </removeInstances> <softDeletion>true</softDeletion> </CommitRequest>
Семантика полей XML-документа определяется в схеме http://schemas.haulmont.com/cuba/6.4/restapi-commit-v2.xsd.
В случае запроса в формате XML установка поля в null осуществляется с помощью атрибута
null="true"
. Кроме того, в идентификаторе должно быть указано представление, содержащее данный атрибут. Например:<CommitRequest> <commitInstances> <instance id="Order-9873c8a8-d4e7-11e2-85c0-33423bc08c84"> <field name="amount" null="true"/> <reference name="customer" null="true"/> </instance> </commitInstances> </CommitRequest>
Функция вызывается посредством POST запроса по адресу
{host:port}/app-portal/api/commit?s=<sessionId>
. XML передается в теле запроса. Запрос возвращает массив объектов XML вида<instances> <instance ...> <instance ...> </instances>
Схема, содержащая описание результата вызова функции, находится по адресу http://schemas.haulmont.com/cuba/6.4/restapi-instance-v2.xsd.