You can use the Manufacturer V2 API to integrate the shopfloor and the enterprise resource planning (ERP) systems with the Serialized Manufacturing application.
The Manufacturer V2 API uses the Representational State Transfer (REST) standard to interact with other systems.
The Manufacturer V2 API is an extension of the Serialized Manufacturing application of Movilitas.Cloud that enables you to send requests from external systems to the application.
The following figure provides an overview of all the requests that you can send by using the Manufacturer V2 API:

This article describes how to create and execute a label (printing) order in the Serialized Manufacturing application using the Manufacturer V2 API.
API Tool to Use
In this document, we provide examples by using the cURL command-line tool. To send the API request, you can find a lot of user-friendly REST API tools on the Internet, for example, Postman.
Before You Begin
1. You must enable the Serialized Manufacturing application.
2. You must create an API key and secret.
3. You must create a shopfloor channel with the Manufacturer V2 API source. You will need the channel key for your requests.
4. You must configure the Serialized Manufacturing application and the channels required to connect to external systems.
5. You must have the authentication token to send requests over API. Select one of the following ways:
- Apply a dynamic token. Send an authentication request over the Authentication API. For more information about the Authentication API, open the Tenant Dashboard in Movilitas.Cloud, select API keys, and choose Authentication API Documentation. Also, see Authentication Request.
- Apply a static token. Generate a static token for your previously created API key.
For more information, see Configuring the Movilitas.Cloud APIs.
Procedure
1. Use the POST method and the following URL:
https://api-acc.movilitas.cloud/v1/manufacturer/v2/api/label_orders/
2. For the header, define the content type (JSON), the authentication token, and the channel key.
The token can be given in one of the following ways:
- As x-access-token header.
- As Authorization header by using the Bearer schema.
Header Option 1
| Key | Action |
|---|---|
| Content-Type | Apply JSON format for the content. Use the value application/json. |
| x-access-token | Provide the authentication token. |
| x-channel-key | Provide the channel key of your Manufacturer V2 API channel. |
Header Option 2
| Key | Action |
|---|---|
| Content-Type | Apply JSON format for the content. Use the value application/json. |
| Authorization | Provide the authentication token as Bearer <token>. |
| x-channel-key | Provide the channel key of your Manufacturer V2 API channel. |
3. In the body of the request, define the parameters and their values based on the table below.
| Field | Required or Optional? | Type | Description |
|---|---|---|---|
| order_id | Required | String | Label (printing) order ID. |
| product_code | Required | String | Product code. |
| product_code_schema | Required | String | Product code schema. The application supports one value, "GTIN". |
| batch | Required | String | Batch ID. |
| quantity | Required | Number | The number of labels to be printed. |
| extra_label_amount | Optional | Number | The quantified extra labels to be printed. Valid only together with the extra_label_typefield.
|
| extra_label_type | Conditional* | String | The quantity type of the extra labels:
If extra labels are not specified in the request, but a default value for the extra labels is provided in the Manufacturer V2 API channel settings, the system applies the default value given on the channel. |
| destination_tag | Required | String | Identifies the Zebra printing destination to which the label order is going to be sent. Note: Make sure that you have registered a Zebra Cloud Connect printing destination in the Serialized Manufacturing application, under the Labels --> Destinations tab and you apply the value that was given in the Destination tag field. |
| template_tag | Required | String | Identifies the ZPL label template to be used during printing. Note: Make sure that you have registered a ZPL label template in the Serialized Manufacturing application, under the Labels --> Templates tab and you apply the value that was given in the Template tag field. |
| execute | Optional | Boolean | The flag that indicates whether the label order is executed immediately after creation in the Serialized Manufacturing application:
If the field is not specified, the default is "false". |
*If the extra_label_amount field is provided in the request, the extra_label_type field is required.
4. Send the request. The label order is created and, depending on the execute flag status in the request, released, that you can check under the Serialized Manufacturing application --> Labels --> Orders tab.
Sample cURL Request
curl -X POST \
https://api-acc.movilitas.cloud/v1/manufacturer/v2/api/label_orders/ \
-H 'Content-Type: application/json' \
-H 'x-access-token: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJrZXkiOiKzX2FqazQyS3RLQWhHdiE4TUZtY1Q2Uzh' \
-H 'x-channel-key: Ky1SpfEXmjj05fW3USBFD3pgoEi9AQ29Atsnj4Zy' \
-d '{
"order_id": "MCS360418",
"product_code": "02026041310005",
"product_code_schema":"GTIN",
"batch": "MCS36042",
"quantity": 10,
"extra_label_amount": 2,
"extra_label_type": "amount",
"destination_tag": "zebra-cloud-device-1",
"template_tag": "data-matrix-example",
"execute": true
}'Sample Response (Success 200)
{
"success": true,
"message": "Label order created successfully"
}Admin UI Example (Created and Executed Label Order)

Error Types and Resolution
This section lists some of the most general error types when sending the request.
| Error Message or Error Type | Error Code | Description |
|---|---|---|
| No token provided | ERR0001 | No authentication token is provided. Ensure that you add the authentication token to the header of the request. |
| Failed to authenticate token | ERR0000 | Failed to authenticate the provided token. Double-check if your token has expired or has been revoked. Obtain a valid token by generating a static one or by getting a dynamic one through Authentication API. |
| Channel ID is missing or it needs to be in correct format | - | The channel key of your Manufacturer V2 API channel is not specified in the request. To get the channel key, go to Tenant Dashboard --> Channels in the Admin UI, open your Manufacturer V2 API channel, and find the channel key on the top of the Edit shopfloor channel panel. |
| Request body could not be parsed | - | The syntax of the request body is not correct, for example, a comma is missing at the end of a field. Make sure that the request body is defined in the correct way and that you use JSON format. |
| Batch not found | - | A batch with the given batch ID is not registered for the product in the Serialized Manufacturing application. Make sure that the given batch ID for the product exists in the application. |
| Label order already exists! | - | A label order with the given order ID is registered in the Serialized Manufacturing application. Make sure that you give a unique order ID in the request. |
| Printing template doesn't exist! | - | A label template with the given template tag is not registered in the Serialized Manufacturing application. Make sure that the label template you want to use is registered and give the correct template tag in the request. |
| Destination not found | - | A printing destination with the given destination tag is not registered in the Serialized Manufacturing application. Make sure that the printing destination you want to use is registered and give the correct destination tag in the request. |
| Not enough serials assigned at the moment | - | Not enough serial numbers in the pool to fulfill the request. To resolve the issue: 1. Go to the Serialized Manufacturing application. 2. Select the Products --> Products tab, select the product, and then select the Serial management tab. 3. Generate or request serial numbers for the product manually and/or turn on automatic replenishment in the serial management configuration of the product. 4. Resume the suspended label order under the Labels --> Orders tab. Note: Resuming the order over API is not supported. |
| Not enough serials available at the moment. More serials have been requested. Please try after some time. | - | Not enough serial numbers in the pool to fulfill the request, but the pool is refilled in the background due to automatic replenishment. To resolve the issue: 1. Go to the Serialized Manufacturing application. 2. Resume the suspended label order under the Labels --> Orders tab. Note: Resuming the order over API is not supported. |