Skip to content

Additional properties manipulations

Order contains list of additional properties.

There are several endpoints to manipulate properties in this list:

  • Get all additional properties
  • Get specific additional property
  • Create new additional property
  • Update existing additional property
  • Remove existing additional property

Warning

Additional properties can be changed only as long the order has not gone over the Delivered state. (Mail not sent and not exported to CRM yet.)

Get all additional properties

It is possible to get all additional properties through special endpoint or together with the order response.

GET {{ marketUrl }}/orders/{{ orderId }}/additionalproperty
{
    "propertyValues": [
        {
            "name": "Some property name",
            "description": "Some description",
            "unitCode": "someUnitCode",
            "unitText": "someUnitText",
            "value": "someValue",
            "propertyId": "someProperty1"
        }
    ],
    "validationMessages": []
}

Get specific additional property

Returns additional property which has property id equals to propertyId from url (in next example someProperty1)

GET {{ marketUrl }}/orders/{{ orderId }}/additionalproperty/someProperty1
{
    "propertyValues": [
        {
            "name": "Some property name",
            "description": "Some description",
            "unitCode": "someUnitCode",
            "unitText": "someUnitText",
            "value": "someValue",
            "propertyId": "someProperty1"
        }
    ],
    "validationMessages": []
}

Create new additional property

Add new additional property to the order and return it in the response

{
    "propertyId" : "someProperty1",
    "name": "Some property name",
    "description": "Some description",
    "unitCode": "someUnitCode",
    "unitText" : "someUnitText",
    "value": "someValue"
}
POST {{ marketUrl }}/orders/{{ orderId }}/additionalproperty
{
    "propertyValues": [
        {
            "name": "Some property name",
            "description": "Some description",
            "unitCode": "someUnitCode",
            "unitText": "someUnitText",
            "value": "someValue",
            "propertyId": "someProperty1"
        }
    ],
    "validationMessages": []
}

Update existing additional property

Update additional property with property id which equals to property id from URL

Information

PropertyId cannot be updated. So any provided propertyId will be ignored

{
    "propertyId" : "someProperty1",
    "name": "New property name",
    "description": "New description",
    "unitCode": "someUnitCode",
    "unitText" : "someUnitText",
    "value": "someValue"
}
PUT {{ marketUrl }}/orders/{{ orderId }}/additionalproperty/someProperty1
{
    "propertyValues": [
        {
            "name": "New property name",
            "description": "New description",
            "unitCode": "someUnitCode",
            "unitText": "someUnitText",
            "value": "someValue",
            "propertyId": "someProperty1"
        }
    ],
    "validationMessages": []
}

Remove existing additional property

DELETE {{ marketUrl }}/orders/{{ orderId }}/additionalproperty/someProperty1