MRPeasy API
MRPeasy has a REST API, it is accessible in Unlimited pricing plan for paying clients. It allows to create new objects or view, update and delete them using standard methods.
Disclaimer! Our API is an Application Programming Interface. This is not a function of the MRPeasy software. Our Support Department cannot help you using the API. To use it, you must have your own highly qualified software development partner.
Method: | GET |
---|---|
Description: |
Get an object if its ID is provided. For example, https://api.mrpeasy.com/rest/v1/items/1. If no ID is provided, return a list of objects. For example, https://api.mrpeasy.com/rest/v1/items. The maximum length of list is 100 objects at a time. If there are more than 100 objects in the database, response code will be 206 and response will include HTTP header content-range with indexes of the first and the last objects and total number of objects. Please note that the index of the last object is equal to the total number of objects minus 1. In order to receive next objects from the list, your request should include
HTTP header range with index of the first object
that should be returned. For example: content-range: items 0-99/250 - response contains first 100 objects of 250. content-range: items 200-249/250 - response contains last 50 objects of 250. range: items=200 - request 100 objects starting
from 201. |
Response codes: |
200 - object is found 200 - all elements of list are returned 206 - list is returned partially 400 - provided data did not pass the validation 404 - object is not found |
Method: | POST |
---|---|
Description: |
Create a new object. For example, request to https://api.mrpeasy.com/rest/v1/items creates a new stock item. Data should be posted as HTTP POST data (application/x-www-form-urlencoded) or JSON. If object is created successfully, the response includes the ID of created object. If provided data was not valid, the response includes array of validation errors. |
Response codes: |
201 - object is created successfully 400 - provided data did not pass the validation |
Method: | PUT |
---|---|
Description: |
Updates existing object. For example, request to https://api.mrpeasy.com/rest/v1/items/1 updates stock item. Data should be posted as HTTP POST data (application/x-www-form-urlencoded) or JSON. If object is updated successfully, response has no content. If provided data was not valid, the response includes array of validation errors. |
Response codes: |
202 - object is updated successfully 400 - provided data did not pass the validation 404 - object is not found |
Method: | DELETE |
---|---|
Description: |
Deletes existing object. For example, request to https://api.mrpeasy.com/rest/v1/items/1 updates stock item. This method has no content in response. |
Response codes: |
204 - object is deleted successfully 400 - object cannot be deleted 404 - object is not found |
Requests must be in UTF-8.
Response data is JSON encoded in UTF-8.
Also, API can return the following codes:
- 401 - Unauthorized. Please see section Authentication for details.
- 429 - Too Many Requests. MRPeasy allows one request per client at a time. In this case please retry the same request after previous request is completed. Also, MRPeasy allows 100 requests per 10 seconds only.
- 503 - MRPeasy is under maintenance. In this case please retry the same request later.
Authentication
MRPeasy REST API uses Basic access authentication. Each request must contain the HTTP header Authorization:
Authorization: Basic base64([api-key]:[api-secret])
- api-key - your MRPeasy API key, that can be found in Settings - Integration - API access;
- api-secret - a secret key that can be defined in
Settings - Integration - API access.
Please note that it must be confidential. Never give it to anybody. We will never ask you for this key.
We advise to change this key from time to time. If you do not need to do API requests all the time, we advise do delete it after each usage. Empty API access key disables API and this increases security.
For example:
api-key: z1g41b3d0a7c2
api-secret: AbC123
Authorization: Basic ejFnNDFiM2QwYTdjMjpBYkMxMjM=
Typically, we would write a cUrl request as follows:
curl -X "GET" "https://api.mrpeasy.com/rest/v1/items" \
-H 'content-type: application/json' \
-u 'z1g41b3d0a7c2:AbC123'
curl -X "PUT" "https://api.mrpeasy.com/rest/v1/items/5" \
-H 'content-type: application/json' \
-u 'z1g41b3d0a7c2:AbC123' \
-d '{"selling_price": "2.54"}'
In the examples above, you can replace the URLs with the ones you find from the documentation. In case of a PUT request, there is a payload (the last parameter -d). You can supply it with any field found in the documentation for the corresponding URL.
Objects
MRPeasy REST API provides the access to the following objects:
- Bills of materials
- Customer orders
- Customers
- Manufacturing orders
- Parameters
- Product groups
- Purchase orders
- Relations
- RMA orders
- Routings
- Sales invoices
- Serial numbers
- Shipments
- Stock items
- Stock lots
- Units of measurement
- Users actions
- Vendors
- Work station types
- Work stations
Bills of materials
https://api.mrpeasy.com/rest/v1/boms
Field | Type | Description |
bom_id | Integer, read-only | Database ID of the BOM. |
product_id | Integer |
ID of the final product for this BOM. It can be defined only while creating a new BOM and cannot be changed later. This field can be added as a GET parameter to URL to filter BOMs list. |
code | String | A unique number to identify the BOM. |
title | String | Name of the BOM. |
routings | Array of integers | IDs of routings that are suitable for this BOM. |
components | Array of objects |
Array of BOM components. If you create a new BOM, then you must provide components. If you update existing BOM, you should provide either all components (both updated and not updated with their component IDs) or no components (existing components will remain). If you provide components, then each component that has existing component ID will be updated, components without component ID will be created and old components that were not found by ID among provided ones will be deleted. |
Components are objects with the following structure:
Field | Type | Description |
component_id | Integer, read-only | Database ID of the component. |
article_id | Integer | ID of the material. |
product_id | Integer | ID of the product (if Matrix BOM functionality is turned on). |
relation_id | Integer | ID of the relation (if Matrix BOM functionality is turned on). |
def_params | String | Default parameter values (if Matrix BOM functionality is turned on). |
quantity | Decimal or array | Number of units that are needed to produce one unit of finished product (array if Matrix BOM functionality is turned on). |
quantity_fixed | Decimal | Fixed number of units that are needed to execute the manufacturing order (if Fixed Quantity functionality is turned on). |
description | Text | A free text |
ord | Integers | A serial number of the component, starting with 1. |
Sample POST data
product_id=1&components%5B0%5D%5Barticle_id%5D=2&components%5B0%5D%5Bquantity%5D=5&components%5B0%5D%5Bord%5D=1&components%5B1%5D%5Barticle_id%5D=3&components%5B1%5D%5Bquantity%5D=7&components%5B1%5D%5Bord%5D=2
{ "product_id": 1, "components": [ { "article_id": 2, "quantity": 5, "ord": 1 }, { "article_id": 3, "quantity": 7, "ord": 2 } ] }
Customer orders
https://api.mrpeasy.com/rest/v1/customer-orders[?cust_ord_id=...&code=...]
Field | Type | Description |
cust_ord_id | Integer, read-only | Database ID of the customer order. This field can be added as a GET parameter to URL to filter customer orders list. |
code | String | A unique number to identify the customer order. This field can be added as a GET parameter to URL to filter customer orders list. |
reference | String | Reference of the customer order. This field can be added as a GET parameter to URL to filter customer orders list. |
customer_id | Integer | Database ID of the customer. This field can be added as a GET parameter to URL to filter customer orders list. |
customer_code | String, read-only | A unique number to identify the customer. This field can be added as a GET parameter to URL to filter customer orders list. |
customer_name | String, read-only | A name of the customer. This field can be added as a GET parameter to URL to filter customer orders list. |
pricelist_id | Integer | Database ID of the pricelist. This field can be added as a GET parameter to URL to filter customer orders list. |
pricelist_code | String, read-only | A unique number to identify the pricelist. This field can be added as a GET parameter to URL to filter customer orders list. |
pricelist_title | String, read-only | A name of the pricelist. This field can be added as a GET parameter to URL to filter customer orders list. |
shipping_address_id | Integer | ID of customer order shipping address if it is selected in CO details. This field can be added as a GET parameter to URL to filter customer orders list. |
shipping_address | String or array, read-only | Shipping address as a text or an array. This field can be added as a GET parameter to URL to filter customer orders list. If shipping_address_id is empty, then this is the default address of a customer. It was not selected manually in CO details. |
status | Integer | Status of customer order.
|
status_txt | String, read-only | Status of customer order as text. |
part_status | Integer, read-only | Product status of customer order.
|
part_status_txt | String, read-only | Product status of customer order as text. |
invoice_status | Integer, read-only | Invoice status of customer order.
|
invoice_status_txt | String, read-only | Invoice status of customer order as text. |
payment_status | Integer, read-only | Payment status of customer order.
|
payment_status_txt | String, read-only | Payment status of customer order as text. |
created | Unix timestamp | Date and time when this customer order was created. GET parameters created_min and created_max can be added to URL to filter customer orders list. |
delivery_date | Unix timestamp | Date and time when this customer order should be delivered. GET parameters delivery_date_min and delivery_date_max can be added to URL to filter customer orders list. |
actual_delivery_date | Unix timestamp, read-only | Date and time when products were picked in a shipment GET parameters actual_delivery_date_min and actual_delivery_date_max can be added to URL to filter customer orders list. |
currency | String | Currency of the customer order. |
currency_rate | Decimal | Currency rate of the customer order. |
total_price | Decimal, read-only | Total price of the customer order. GET parameters total_price_min and total_price_max can be added to URL to filter customer orders list. |
total_price_cur | Decimal, read-only | Total price of the customer order in the order's currency. |
total_cost | Decimal, read-only | Total cost of the customer order. It is available if all products have been
booked. GET parameters total_cost_min and total_cost_max can be added to URL to filter customer orders list. |
profit | Decimal, read-only | Difference between total_price and total_cost. GET parameters profit_min and profit_max can be added to URL to filter customer orders list. |
discount_rate | Decimal | Percentage of discount. |
discount_sum | Decimal | Sum of discount. |
discount_sum_cur | Decimal | Sum of discount in the order's currency. |
notes | String | Internal notes, any additional information about the order. |
delivery_terms | String | Delivery terms of the order. |
products | Array of objects | Array of products that are sold. |
Products are objects with the following structure:
Field | Type | Description |
line_id | Integer, read-only | Database ID of the customer order line. |
ord | Integers | A number of the product, starting with 1. |
article_id | Integer | ID of the article. |
description | Text | A free text. |
quantity | Decimal | Number of items to sell. |
shipped | Decimal, read-only | Number of shipped items. |
delivery_date | Unix timestamp | Custom date and time when this product should be delivered. If this field is empty, use order's delivery_date. |
item_price | Decimal | Price of one item. |
item_price_cur | Decimal | Price of one item in the order's currency. |
total_price | Decimal | Price of product. |
total_price_cur | Decimal | Price of product in the order's currency. |
discount_rate | Decimal | Percentage of discount per line. |
discount_sum | Decimal, read-only | Sum of discount per line. |
discount_sum_cur | Decimal, read-only | Sum of discount per line in the order's currency. |
cost | Decimal, read-only | Total cost of the product. It is available if the products has been booked. |
profit | Decimal, read-only | Difference between total_price and cost. |
part_status | Integer, read-only | Status of product booking:
|
part_status_txt | String, read-only | Product status of booking as text. |
source | Array, read-only | Stock lots, from which products are booked. The following fields are included:
|
To create a customer order, provide the following data:
- customer_id;
- products
-
article_id - whether article_id from MRPeasy database;
sku - or SKU that must match part number in MRPeasy;
product_id with param [parameter_id => value_id, parameter_id => value_id, ...] - or, if Matrix BOM is turned on, product_id from MRPeasy database with array of parameters. - quantity;
- total_price_cur
-
article_id - whether article_id from MRPeasy database;
- status - optional. If the status is Confirmed (30) or greater, the software tries to book available products from stock immediately. If the status is Shipped (70) or Delivered (80), and products are booked, the software creates a shipment document and picks products from the stock.
- site_id - optional, integer. If provided, products are booked from this site. Otherwise, products are booked from the customer order's site.
- lot_id - optional, integer or array. If provided, products are booked from these stock lots. Otherwise, products are booked from any stock lots.
- location_id - optional, integer or array. If provided, products are booked from these storage locations. Otherwise, products are booked from any storage location.
- Other fields not marked as read-only may also be provided.
Sample POST data
customer_id=1&status=30&products%5B0%5D%5Barticle_id%5D=2&products%5B0%5D%5Bquantity%5D=5&products%5B0%5D%5Btotal_price_cur%5D=100&products%5B1%5D%5Barticle_id%5D=3&products%5B1%5D%5Bquantity%5D=7&products%5B1%5D%5Btotal_price_cur%5D=70
{ "customer_id": 1, "status": 30, "products": [ { "article_id": 2, "quantity": 5, "total_price_cur": 100 }, { "article_id": 3, "quantity": 7, "total_price_cur": 70 } ] }
Customers
https://api.mrpeasy.com/rest/v1/customers[?code=...&title=...]
Customers can be added, viewed, and updated. Only GET, POST, and PUT methods are supported. Other methods are disabled.
Field | Type | Description |
customer_id | Integer, read-only | Database ID of the customer. |
code | String | A unique number to identify the customer. This field can be added as a GET parameter to URL to filter customers list. |
title | String | Name of the customer. This field can be added as a GET parameter to URL to filter customers list. |
reg_nr | String | Registration number of customer's company. This field can be added as a GET parameter to URL to filter customers list. |
tax_nr | String | Tax/VAT number of customer's company. This field can be added as a GET parameter to URL to filter customers list. |
created | Unix timestamp | Date and time when this customer was created. GET parameters created_min and created_max can be added to URL to filter customers list. |
next_contact | Unix timestamp | Date and time when this customer should be contacted. GET parameters next_contact_min and next_contact_max can be added to URL to filter customers list. |
status | Integer | Status of customer. Statuses are configured in MRPeasy -> Settings ->
System settings -> Customer statuses. This field can be added as a GET parameter to URL to filter customers list. |
payment_period | Integer | A default payment period in days for invoices to this customer. |
user_id | Integer | Sales person who handles that customer. |
language_id | Integer | Language of documents that are printed for this customer. |
contact_data | Array of objects | Array of contact details. |
Contact details are objects with the following structure:
Field | Type | Description |
line_id | Integer, read-only | Database ID of the contact information. |
type | String | Type of contact information:
|
value | String or object |
Contact information. If this is address or shipping_address, it is possible to pass a structured address as an object:
|
To create a customer, provide the following data:
- title;
- contact_data
- type;
- value
Sample POST data
title=Tester&contact_data%5B0%5D%5Btype%5D=phone&contact_data%5B0%5D%5Bvalue%5D=123456789&contact_data%5B1%5D%5Btype%5D=email&contact_data%5B1%5D%5Bvalue%5D=info%40tester.com&contact_data%5B2%5D%5Btype%5D=address&contact_data%5B2%5D%5Bvalue%5D%5Bfirst_name%5D=John&contact_data%5B2%5D%5Bvalue%5D%5Blast_name%5D=Doe&contact_data%5B2%5D%5Bvalue%5D%5Bcompany%5D=JD+Ltd&contact_data%5B2%5D%5Bvalue%5D%5Bstreet_line_1%5D=123+Maple+Street&contact_data%5B2%5D%5Bvalue%5D%5Bstreet_line_2%5D=&contact_data%5B2%5D%5Bvalue%5D%5Bcity%5D=Any-town&contact_data%5B2%5D%5Bvalue%5D%5Bpostal_code%5D=17101&contact_data%5B2%5D%5Bvalue%5D%5Bstate%5D=PA&contact_data%5B2%5D%5Bvalue%5D%5Bcountry_code%5D=US&contact_data%5B2%5D%5Bvalue%5D%5Bphone%5D=999-999-9999
{ "title": "Tester", "contact_data": [ { "type": "phone", "value": "123456789" }, { "type": "email", "value": "info@tester.com" }, { "type": "address", "value": { "first_name": "John", "last_name": "Doe", "company": "JD Ltd", "street_line_1": "123 Maple Street", "street_line_2": "", "city": "Any-town", "postal_code": "17101", "state": "PA", "country_code": "US", "phone": "999-999-9999" } } ] }
Manufacturing orders
https://api.mrpeasy.com/rest/v1/manufacturing-orders[?man_ord_id=...&code=...]
Field | Type | Description |
man_ord_id | Integer, read-only | Database ID of the manufacturing order. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
code | String | A unique number to identify the manufacturing order. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
article_id | Integer, read-only | Database ID of the stock item. If Matrix BOM is turned on, this is unique for
each variation. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
product_id | Integer, read-only | Database product ID. If Matrix BOM is turned on, product_id is the same at all
variations of the stock item. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
item_code | String | A unique number to identify the stock item. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
item_title | String | Name of the stock item. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
unit_id | Integer or null | ID of the unit of measurement. |
unit | String | Unit of measurement. |
group_id | Integer or null | ID of the product group. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
group_code | String | A unique number to identify the product group. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
group_title | String | Name of the product group. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
quantity | Decimal | Quantity of manufacturing order. GET parameters quantity_min and quantity_max can be added to URL to filter manufacturing orders list. |
status | Integer | Status of manufacturing order.
|
part_status | Integer | Status of parts that are booked.
|
part_status_txt | String, read-only | Part status of manufacturing order as text. |
created | Unix timestamp | Date and time when this manufacturing order was created. GET parameters created_min and created_max can be added to URL to filter manufacturing orders list. |
due_date | Unix timestamp | Date and time when this manufacturing order should be ready. GET parameters due_date_min and due_date_max can be added to URL to filter manufacturing orders list. |
start_date | Unix timestamp | Date and time when this manufacturing order is started. GET parameters start_date_min and start_date_max can be added to URL to filter manufacturing orders list. |
finish_date | Unix timestamp | Date and time when this manufacturing order is finished. GET parameters finish_date_min and finish_date_max can be added to URL to filter manufacturing orders list. |
item_cost | Decimal | Cost per one stock item. GET parameters item_cost_min and item_cost_max can be added to URL to filter manufacturing orders list. |
total_cost | Decimal | Total cost of manufacturing order. GET parameters total_cost_min and total_cost_max can be added to URL to filter manufacturing orders list. |
assigned_id | Integer | User that is responsible for this manufacturing order. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
assigned_username | String | Username of the user that is responsible for this manufacturing order. |
bom_id | Integer | ID of BOM. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
routing_id | Integer | ID of routing. This field can be added as a GET parameter to URL to filter manufacturing orders list. |
lot_id | Integer deprecated |
Please use the list of target lots instead.
ID of target stock lot.
This field can be added as a GET parameter to URL to filter manufacturing orders list. |
lot_code | String deprecated |
Please use the list of target lots instead.
A unique number to identify the target lot.
This field can be added as a GET parameter to URL to filter manufacturing orders list. |
target_lots | Array of objects | A list of target lots produced by this manufacturing order. |
site_id | Integer | ID of site where this manufacturing order is performed (only if Enterprise
function "Multiple Production Sites/Stocks" is enabled). This field can be added as a GET parameter to URL to filter manufacturing orders list. |
revision | String | Revision of the stock item (only if Enterprise function "Revision/Version Control System" is enabled). |
parts | Array of objects | Array of booked or consumed parts. This field is included in the reply only when a particular MO is requested (https://api.mrpeasy.com/rest/v1/manufacturing-orders/[MO_ID]). |
operations | Array of objects | Array of manufacturing operations. This field is included in the reply only when a particular MO is requested (https://api.mrpeasy.com/rest/v1/manufacturing-orders/[MO_ID]). |
notes | Array of objects | Array of notes of the manufacturing order. This field is included in the reply only when a particular MO is requested (https://api.mrpeasy.com/rest/v1/manufacturing-orders/[MO_ID]). |
Target lots are objects with the following structure:
Field | Type | Description |
lot_id | Integer, read-only |
Database ID of the stock lot.
This field can be added as a GET parameter to URL to filter manufacturing orders list. |
code | String, read-only |
A unique number of the stock lot.
lot_code can be added as a GET parameter to URL to filter manufacturing orders list. |
Parts are objects with the following structure:
Field | Type | Description |
writeoff_id | Integer, read-only | Database ID of the booking. |
booking_code | String | A unique number of the booking. |
article_id | Integer | ID of the article. |
product_id | Integer | ID of the product. |
booked | Decimal | Number of items that are booked. |
consumed | Decimal | Number of items that are consumed. |
lots | Array of objects | Array of stock lots. |
Stock lots are objects with the following structure:
Field | Type | Description |
lot_id | Integer, read-only | Database ID of the stock lot. NULL if the item is not booked from a particular stock lot. |
code | String | A unique number of the stock lot. NULL if the item is not booked from a particular stock lot. |
booked | Decimal | Number of items that are booked. |
consumed | Decimal | Number of items that are consumed. |
item_cost | Decimal | Cost per one stock item. |
Operations are objects with the following structure:
Field | Type | Description |
operation_id | Integer, read-only | Database ID of the operation. |
ord | Integers | A number of the operation, starting with 1. |
type_id | Integer | ID of the work station type. |
vendor_id | Integer | ID of the subcontractor. |
description | Text | A description of the operation. |
setup_time | Integer | Setup time from a routing in minutes. |
cycle_time | Integer | Cycle time from a routing in minutes. |
planned_start_date | Unix timestamp | Date and time when this operation should be started. |
planned_finish_date | Unix timestamp | Date and time when this operation should be finished. |
planned_duration | Integer | Planned duration of the operation. |
real_start_date | Unix timestamp | Date and time when this operation was started. NULL if the operation is not started yet. |
real_finish_date | Unix timestamp | Date and time when this operation was finished. NULL if the operation is not finished yet. |
real_duration | Integer | Real duration of the operation. NULL if the operation is not finished yet. |
manufacturing_cost | Decimal | Manufacturing overhead. |
labour_cost | Decimal | Labour cost. |
stations | Array of objects | Array of work stations. |
Work stations are objects with the following structure:
Field | Type | Description |
pws_id | Integer, read-only | Database ID of the work station in the operation. |
station_id | Integers | Database ID of the work station. |
code | String | A unique number of the work station. |
title | String | Name of the work station. |
planned_start_date | Unix timestamp | Date and time when this operation should be started. |
planned_finish_date | Unix timestamp | Date and time when this operation should be finished. |
planned_duration | Integer | Planned duration of the operation. |
real_start_date | Unix timestamp | Date and time when this operation was started. NULL if the operation is not started yet. |
real_finish_date | Unix timestamp | Date and time when this operation was finished. NULL if the operation is not finished yet. |
real_duration | Integer | Real duration of the operation. NULL if the operation is not finished yet. |
manufacturing_cost | Decimal | Manufacturing overhead. |
workers | Array of objects | Array of worker. |
Workers are objects with the following structure:
Field | Type | Description |
worker_id | Integer, read-only | Database ID of the worker. |
user_id | Integers | Database ID of the user. |
department_id | Integers | Database ID of the department. |
planned_start_date | Unix timestamp | Date and time when this operation should be started. |
planned_finish_date | Unix timestamp | Date and time when this operation should be finished. |
planned_duration | Integer | Planned duration of the operation. |
real_start_date | Unix timestamp | Date and time when this operation was started. NULL if the operation is not started yet. |
real_finish_date | Unix timestamp | Date and time when this operation was finished. NULL if the operation is not finished yet. |
real_duration | Integer | Real duration of the operation. NULL if the operation is not finished yet. |
labour_cost | Decimal | Labour cost. |
results | Array of objects | Array of real results of the worker. |
Results are objects with the following structure:
Field | Type | Description |
result_id | Integer, read-only | Database ID of the result. |
real_start_date | Unix timestamp | Date and time when this operation was started. NULL if the operation is not started yet. |
real_finish_date | Unix timestamp | Date and time when this operation was finished. NULL if the operation is not finished yet. |
real_duration | Integer | Real duration of the operation. NULL if the operation is not finished yet. |
Quantity | Decimal | Number of ready items. |
Notes are objects with the following structure:
Field | Type | Description |
note_id | Integer, read-only | Database ID of the result. |
created | Unix timestamp | Date and time when this note was created. |
author_id | Integer | ID of the user who created that note. |
author | String | Username of the user who created that note. |
last_modified | Unix timestamp | Date and time when this note was modified the last time. |
last_modifier_id | Integer | ID of the user who modified that note. |
last_modifier | String | Username of the user who modified that note. |
text | Text | Text of the note. |
To add a manufacturing order, provide the following data:
- article_id;
- quantity;
- assigned_id;
- site_id (only if Enterprise function "Multiple Production Sites/Stocks" is enabled);
- no_bookings - optional, if the Professional function "Unscheduled Manufacturing Orders" is enabled, and the value is 1, parts will not be booked;
- no_scheduling - optional, if the Professional function "Unscheduled Manufacturing Orders" is enabled, and the value is 1, workstations will not be booked.
Sample POST data
article_id=1&quantity=10&assigned_id=3&site_id=1
{ "article_id": 1, "quantity": 10, "assigned_id": 3, "site_id": 1 }
Via API, it is possible to update the following fields only. Other changed must be done in the software.
- code;
- quantity;
- due_date;
- assigned_id;
- custom fields.
Parameters
https://api.mrpeasy.com/rest/v1/parameters[?parameter_id=...&title=...]
Field | Type | Description |
parameter_id | Integer, read-only | Database ID of the parameter. |
title | String | Name of the parameter. This field can be added as a GET parameter to URL to filter parameters list. |
changes_quantity | Boolean | Shows if the parameter can change the quantities of raw materials in BOM. |
values | Array of objects | Array of possible values. |
Values are objects with the following structure:
Field | Type | Description |
value_id | Integer | Database ID of the value. |
code | String | A unique number to identify the value. |
value | String | A name of the value. |
selling_price | Decimal | Selling price adjustment of the value. |
ord | Integer | A number of the value, starting with 1. |
Sample POST data
title=Size&changes_quantity=1&values%5B0%5D%5Bcode%5D=s&values%5B0%5D%5Bvalue%5D=S&values%5B0%5D%5Bord%5D=1&values%5B1%5D%5Bcode%5D=m&values%5B1%5D%5Bvalue%5D=M&values%5B1%5D%5Bord%5D=2&values%5B2%5D%5Bcode%5D=l&values%5B2%5D%5Bvalue%5D=L&values%5B2%5D%5Bord%5D=3&values%5B3%5D%5Bcode%5D=xl&values%5B3%5D%5Bvalue%5D=XL&values%5B3%5D%5Bord%5D=4
{ "title": "Size", "changes_quantity": true, "values": [ { "code": "s", "value": "S", "ord": 1 }, { "code": "m", "value": "M", "ord": 2 }, { "code": "l", "value": "L", "ord": 3 }, { "code": "xl", "value": "XL", "ord": 4 } ] }
Product groups
https://api.mrpeasy.com/rest/v1/product-groups[?group_id=...&code=...]
Field | Type | Description |
group_id | Integer, read-only | Database ID of the group. |
code | String | A unique number to identify the group. This field can be added as a GET parameter to URL to filter product groups list. |
title | String | Name of the group. This field can be added as a GET parameter to URL to filter product groups list. |
Sample POST data
title=Ready+products
{ "title": "Ready products" }
Purchase orders
https://api.mrpeasy.com/rest/v1/purchase-orders[?pur_ord_id=...&code=...]
Purchase orders are read-only. Only GET method is supported. Other methods are disabled.
Field | Type | Description |
pur_ord_id | Integer, read-only | Database ID of the purchase order. This field can be added as a GET parameter to URL to filter purchase orders list. |
code | String | A unique number to identify the purchase order. This field can be added as a GET parameter to URL to filter purchase orders list. |
vendor_id | Integer | Database ID of the vendor. This field can be added as a GET parameter to URL to filter purchase orders list. |
vendor_code | String, read-only | A unique number to identify the vendor. This field can be added as a GET parameter to URL to filter purchase orders list. |
vendor_title | String, read-only | A name of the vendor. This field can be added as a GET parameter to URL to filter purchase orders list. |
status | Integer | Status of purchase order.
|
created | Unix timestamp | Date and time when this purchase order was created. GET parameters created_min and created_max can be added to URL to filter purchase orders list. |
expected_date | Unix timestamp | Date and time when this purchase order should be received. GET parameters expected_date_min and expected_date_max can be added to URL to filter purchase orders list. |
due_date | Unix timestamp | Due date of the purchase order. GET parameters due_date_min and due_date_max can be added to URL to filter purchase orders list. If the Software setting "Several invoices per PO" is enabled, please check the bills field. |
shipped_date | Unix timestamp | Actual shipment date of the purchase order. GET parameters shipped_date_min and shipped_date_max can be added to URL to filter purchase orders list. |
arrival_date | Unix timestamp | Actual arrival date and time of the purchase order. GET parameters arrival_date_min and arrival_date_max can be added to URL to filter purchase orders list. |
order_number | String | Order number that is received from the vendor. This field can be added as a GET parameter to URL to filter purchase orders list. |
order_date | Unix timestamp | Vendor order's date. GET parameters order_date_min and order_date_max can be added to URL to filter purchase orders list. |
invoice_number | String | Invoice number that is received from the vendor. This field can be added as a GET parameter to URL to filter purchase orders list. If the Software setting "Several invoices per PO" is enabled, please check the bills field. |
invoice_date | Unix timestamp | Vendor invoice's date. GET parameters invoice_date_min and invoice_date_max can be added to URL to filter purchase orders list. If the Software setting "Several invoices per PO" is enabled, please check the bills field. |
total_price | Decimal | Total price of the purchase order in the default currency. GET parameters total_price_min and total_price_max can be added to URL to filter purchase orders list. |
total_price_cur | Decimal | Total price of the purchase order in vendor's currency. |
fees_taxable_sum | Decimal | Taxable fees of the purchase order in the default currency. |
fees_taxable_sum_cur | Decimal | Taxable fees of the purchase order in vendor's currency. |
fees_sum | Decimal | Additional fees of the purchase order in the default currency. |
fees_sum_cur | Decimal | Additional fees of the purchase order in vendor's currency. |
tax_rate | Decimal | Tax percentage. |
tax_sum | Decimal | Tax sum of the purchase order in the default currency. |
tax_sum_cur | Decimal | Tax sum of the purchase order in vendor's currency. |
discount_rate | Decimal | Discount percentage. |
discount_sum | Decimal | Discount sum of the purchase order in the default currency. |
discount_sum_cur | Decimal | Discount sum of the purchase order in vendor's currency. |
currency | String | Vendor's currency. |
currency_rate | Decimal | Vendor's currency rate. |
free_text | Text | A free text. |
products | Array of objects | Array of products that are ordered. |
bills | Array of objects | If the Software setting "Several invoices per PO" is enabled, this field
contains an array of incoming invoices with the following fields:
|
Products are objects with the following structure:
Field | Type | Description |
line_id | Integer, read-only | Database ID of the purchase order line. |
ord | Integers | A number of the product, starting with 1. |
article_id | Integer | Database ID of the stock item. |
product_id | Integer | Database product ID. |
item_code | String | A unique number to identify the stock item. |
item_title | String | Name of the stock item. |
description | String | A free text. |
unit_id | Integer or null | ID of the unit of measurement. |
unit | String | Unit of measurement. |
group_id | Integer or null | ID of the product group. |
group_code | String | A unique number to identify the product group. |
group_title | String | Name of the product group. |
quantity | Decimal | Number of products purchased in the default unit. |
vendor_quantity | Decimal | Number of products purchased in the vendor's custom unit of measurement. |
vendor_unit | String | Vendor's custom unit of measurement. |
item_price | Decimal | Price per item of the purchase order line in the default currency. |
item_price_cur | Decimal | Price per item of the purchase order line in vendor's currency. |
total_price | Decimal | Total price of the purchase order line in the default currency. |
total_price_cur | Decimal | Total price of the purchase order line in vendor's currency. |
fees_taxable_sum | Decimal | Taxable fees of the purchase order line in the default currency. |
fees_taxable_sum_cur | Decimal | Taxable fees of the purchase order line in vendor's currency. |
fees_sum | Decimal | Additional fees of the purchase order line in the default currency. |
fees_sum_cur | Decimal | Additional fees of the purchase order line in vendor's currency. |
tax_sum | Decimal | Tax sum of the purchase order line in the default currency. |
tax_sum_cur | Decimal | Tax sum of the purchase order line in vendor's currency. |
discount_sum | Decimal | Discount sum of the purchase order line in the default currency. |
discount_sum_cur | Decimal | Discount sum of the purchase order line in vendor's currency. |
revision | String | Revision of the stock item (only if Enterprise function "Revision/Version Control System" is enabled). |
Relations
https://api.mrpeasy.com/rest/v1/relations[?relation_id=...&code=...]
Field | Type | Description |
relation_id | Integer, read-only | Database ID of the relation. |
code | String | A unique number to identify the relation. This field can be added as a GET parameter to URL to filter relations list. |
title | String | Name of the relation. This field can be added as a GET parameter to URL to filter relations list. |
lines | Array of objects | Array of possible parameter values and articles. This field is included in the reply only when a particular relation is requested (https://api.mrpeasy.com/rest/v1/relations/[ID]). |
Lines are objects with the following structure:
Field | Type | Description |
line_id | Integer | Database ID of the line. |
article_id | Integer | Database ID of the stock item. |
ord | Integers | A number of the product, starting with 1. |
values | Array of objects | Object that defines parameter values. Object has the following keys:
|
Sample POST data
title=Relation+A&lines%5B0%5D%5Barticle_id%5D=2&lines%5B0%5D%5Bord%5D=1&lines%5B0%5D%5Bvalues%5D%5B0%5D%5Bparameter_id%5D=1&lines%5B0%5D%5Bvalues%5D%5B0%5D%5Bvalue_id%5D=11&lines%5B0%5D%5Bvalues%5D%5B1%5D%5Bparameter_id%5D=2&lines%5B0%5D%5Bvalues%5D%5B1%5D%5Bvalue_id%5D=21&lines%5B1%5D%5Barticle_id%5D=3&lines%5B1%5D%5Bord%5D=2&lines%5B1%5D%5Bvalues%5D%5B0%5D%5Bparameter_id%5D=1&lines%5B1%5D%5Bvalues%5D%5B0%5D%5Bvalue_id%5D=12&lines%5B1%5D%5Bvalues%5D%5B1%5D%5Bparameter_id%5D=2&lines%5B1%5D%5Bvalues%5D%5B1%5D%5Bvalue_id%5D=22
{ "title": "Relation A", "lines": [ { "article_id": 2, "ord": 1, "values": [ { "parameter_id": 1, "value_id": 11 }, { "parameter_id": 2, "value_id": 21 } ] }, { "article_id": 3, "ord": 2, "values": [ { "parameter_id": 1, "value_id": 12 }, { "parameter_id": 2, "value_id": 22 } ] } ] }
RMA orders
https://api.mrpeasy.com/rest/v1/rma[?rma_ord_id=...&code=...]
Field | Type | Description |
rma_ord_id | Integer, read-only | Database ID of the RMA order.
This field can be added as a GET parameter to URL to filter RMA orders list. |
code | String | A unique number to identify the RMA order.
This field can be added as a GET parameter to URL to filter RMA orders list. |
reference | String | Reference of the RMA order.
This field can be added as a GET parameter to URL to filter RMA orders list. |
customer_id | Integer | Database ID of the customer.
This field can be added as a GET parameter to URL to filter RMA orders list. |
customer_code | String, read-only | A unique number to identify the customer.
This field can be added as a GET parameter to URL to filter RMA orders list. |
customer_name | String, read-only | A name of the customer.
This field can be added as a GET parameter to URL to filter RMA orders list. |
status | Integer | Status of RMA order.
|
status_txt | String, read-only | Status of RMA order as text. |
rma_type | Integer | Type of RMA order.
|
rma_type_txt | String, read-only | Type of RMA order as text. |
created | Unix timestamp | Date and time when this customer order was created.
GET parameters created_min and created_max can be added to URL to filter RMA orders list. |
notes | String | Internal notes, any additional information about the order. |
article_id | Integer | ID of the article.
This field can be added as a GET parameter to URL to filter RMA orders list. |
item_code | String | A unique number to identify the stock item.
This field can be added as a GET parameter to URL to filter RMA orders list. |
item_title | String | Name of the stock item.
This field can be added as a GET parameter to URL to filter RMA orders list. |
quantity | Decimal | Number of items returned. |
unit_id | Integer or null | ID of the unit of measurement. |
unit | String | Unit of measurement. |
group_id | Integer or null | ID of the product group.
This field can be added as a GET parameter to URL to filter RMA orders list. |
group_code | String | A unique number to identify the product group.
This field can be added as a GET parameter to URL to filter RMA orders list. |
group_title | String | Name of the product group.
This field can be added as a GET parameter to URL to filter RMA orders list. |
received | Boolean | Is the item received or not. If the item is received, a stock lot is created. |
lot_id | Integer or null | ID of the target stock lot. |
lot_code | String or null | A unique number of the target stock lot. |
lot_status | Integer or null | Status of target stock lot, if the product is received. |
lot_status_txt | String or null | Status of target stock lot as text. |
site_id | Integer | ID of site where this RMA order is created (only if Enterprise
function "Multiple Production Sites/Stocks" is enabled).
This field can be added as a GET parameter to URL to filter RMA orders list. |
notes | String | Internal notes, any additional information about the order. |
service_order_id | Integer or null | ID of the service order. |
service_order_code | Integer or null | A unique number to identify the service order. |
service_order_status | Integer or null | Status of the service order. |
Routings
https://api.mrpeasy.com/rest/v1/routings
Field | Type | Description |
routing_id | Integer, read-only | Database ID of the routing. |
product_id | Integer | ID of the final product for this routing. It can be defined only while creating a new routing and cannot be changed later. |
code | String | A unique number to identify the routing. |
title | String | Name of the routing. |
boms | Array of integers | IDs of BOMs that are suitable for this routing. |
operations | Array of objects |
Array of routing operations. If you create a new routing, then you must provide operations. If you update existing routing, you should provide either all operations (both updated and not updated with their operation IDs) or no operations (existing operations will remain). If you provide operations, then each operation that has existing operation ID will be updated, operations without operation ID will be created and old operations that were not found by ID among provided ones will be deleted. |
Operations are objects with the following structure (for a better explanation please see Quick help in the software):
Field | Type | Description |
operation_id | Integer, read-only | Database ID of the operation. |
type_id | Integer | ID of the work center type. |
ord | Integer | An ordinal number of operation, starting with 1. |
description | Text | A free text. |
fixed_time | Decimal | A time in minutes that is needed to start the operation (this time does not depend on the quantity of finished products). |
variable_time | Decimal | Additional time of each finished product in minutes. |
fixed_cost | Decimal | A cost of starting the operation that does not depend on the quantity of finished products. |
variable_cost | Decimal | Additional cost of each finished product. |
variable_quantity | Decimal | A quantity of finished products that are produced simultaneously. |
time_payment | Boolean | Shows if user receives a salary per working time. |
piece_payment | Decimal | If defined, then user receives a payment per each piece of finished product. |
sequence | Array of integers | An array of ord values of operations that must be finished before current operation can start (first operation must have sequence 0). |
overlap | Decimal or null |
If the current operation starts before previous operation is fully finished, you can define the quantity of products that must be ready before this operation can start. |
Sample POST data
product_id=1&title=Routing+A&operations%5B0%5D%5Btype_id%5D=1&operations%5B0%5D%5Bord%5D=1&operations%5B0%5D%5Bvariable_time%5D=30&operations%5B1%5D%5Btype_id%5D=4&operations%5B1%5D%5Bord%5D=2&operations%5B1%5D%5Bvariable_time%5D=60
{ "product_id": 1, "title": "Routing A", "operations": [ { "type_id": 1, "ord": 1, "variable_time": 30 }, { "type_id": 4, "ord": 2, "variable_time": 60 } ] }
Sales invoices
https://api.mrpeasy.com/rest/v1/invoices[?invoice=...&code=...]
Field | Type | Description |
invoice_id | Integer, read-only | Database ID of the invoice.
This field can be added as a GET parameter to URL to filter the list of invoices. |
code | String | A unique number to identify the invoice.
This field can be added as a GET parameter to URL to filter the list of invoices. |
type | Integer | Type of invoice.
|
type_txt | String, read-only | Type of invoice as text. |
status | Integer | Status of invoice.
|
status_txt | String, read-only | Status of invoice as text. |
customer_id | Integer | Database ID of the customer.
This field can be added as a GET parameter to URL to filter the list of invoices. |
customer_code | String, read-only | A unique number to identify the customer.
This field can be added as a GET parameter to URL to filter the list of invoices. |
customer_name | String, read-only | A name of the customer.
This field can be added as a GET parameter to URL to filter the list of invoices. |
cust_ord_id | Integer | Database ID of the customer order.
This field can be added as a GET parameter to URL to filter the list of invoices. |
customer_order_code | String | A unique number to identify the customer order.
This field can be added as a GET parameter to URL to filter the list of invoices. |
rma_ord_id | Integer | Database ID of the RMA order.
This field can be added as a GET parameter to URL to filter the list of invoices. |
rma_order_code | String | A unique number to identify the RMA order.
This field can be added as a GET parameter to URL to filter the list of invoices. |
pricelist_id | Integer | Database ID of the pricelist.
This field can be added as a GET parameter to URL to filter the list of invoices. |
pricelist_code | String, read-only | A unique number to identify the pricelist.
This field can be added as a GET parameter to URL to filter the list of invoices. |
pricelist_title | String, read-only | A name of the pricelist.
This field can be added as a GET parameter to URL to filter the list of invoices. |
billing_address_id | Integer | ID of invoice billing address.
This field can be added as a GET parameter to URL to filter the list of invoices. |
billing_address | String or array, read-only | Billing address as a text or an array.
This field can be added as a GET parameter to URL to filter the list of invoices. |
created | Unix timestamp | Date and time when this invoice was created.
GET parameters created_min and created_max can be added as a GET parameters to URL to filter the list of invoices. |
due_date | Unix timestamp | Date when this invoice should be paid.
GET parameters due_date_min and due_date_max can be added as a GET parameters to URL to filter the list of invoices. |
free_text | Text | Free text.
This field can be added as a GET parameter to URL to filter the list of invoices. |
currency | String | Currency of the invoice. |
currency_rate | Decimal | Currency rate of the invoice. |
total_price | Decimal | Total price of the invoice. |
total_price_cur | Decimal | Total price of the invoice in customer's currency.
GET parameters total_price_cur_min and total_price_cur_max can be added as a GET parameters to URL to filter the list of invoices. |
total_tax_price | Decimal | Total price of the invoice with tax. |
total_tax_price_cur | Decimal | Total price of the invoice with tax in customer's currency.
GET parameters total_tax_price_cur_min and total_tax_price_cur_max can be added as a GET parameters to URL to filter the list of invoices. |
discount_rate | Decimal | Percentage of discount. |
discount_sum | Decimal | Sum of discount. |
discount_sum_cur | Decimal | Sum of discount in customer's currency. |
prepayment_rate | Decimal | Percentage of pre-payment in a pre-payment invoice. |
prepayment_sum | Decimal | Sum of a pre-payment invoice or sum of allocated pre-payment in an invoice. |
prepayment_sum_cur | Decimal | Sum of a pre-payment invoice or sum of allocated pre-payment in an invoice, in customer's currency. |
prepayment_tax_sum | Decimal | Sum of a pre-payment invoice or sum of allocated pre-payment in an invoice, with tax. |
prepayment_tax_sum_cur | Decimal | Sum of a pre-payment invoice or sum of allocated pre-payment in an invoice, with tax in customer's currency. |
tax_rate | Decimal | Percentage of tax. |
tax_sum | Decimal | Tax sum of the invoice in the default currency. |
tax_sum_cur | Decimal | Tax sum of the invoice in customer's currency. |
products | Array of objects | Array of products that are sold. |
Products are objects with the following structure:
Field | Type | Description |
line_id | Integer, read-only | Database ID of the invoice line. |
ord | Integers | A number of the product, starting with 1. |
article_id | Integer | ID of the article. |
description | Text | A free text. |
quantity | Decimal | Number of items to sell. |
item_price | Decimal | Price of one item. |
item_price_cur | Decimal | Price of one item in customer's currency. |
total_price | Decimal | Price of product. |
total_price_cur | Decimal | Price of product in customer's currency. |
discount_rate | Decimal | Percentage of discount per line. |
discount_sum | Decimal, read-only | Sum of discount per line. |
discount_sum_cur | Decimal, read-only | Sum of discount per line in customer's currency. |
delivery_date | Unix timestamp | Custom date and time when this product should be delivered. |
Serial numbers
https://api.mrpeasy.com/rest/v1/serials[?serial_id=...&serial=...]
Serial numbers are read-only. Only GET method is supported. Other methods are
disabled.
Field | Type | Description |
serial_id | Integer, read-only | Database ID of the serial number. This field can be added as a GET parameter to URL to filter serial numbers list. |
serial | String | Serial number. This field can be added as a GET parameter to URL to filter serial numbers list. |
article_id | Integer, read-only | Database ID of the stock item. If Matrix BOM is turned on, this is unique for
each variation. This field can be added as a GET parameter to URL to filter serial numbers list. |
product_id | Integer, read-only | Database product ID. If Matrix BOM is turned on, product_id is the same at all
variations of the stock item. This field can be added as a GET parameter to URL to filter serial numbers list. |
item_code | String | A unique number to identify the stock item. This field can be added as a GET parameter to URL to filter serial numbers list. |
item_title | String | Name of the stock item. This field can be added as a GET parameter to URL to filter serial numbers list. |
group_id | Integer or null | ID of the product group. This field can be added as a GET parameter to URL to filter serial numbers list. |
group_code | String | A unique number to identify the product group. This field can be added as a GET parameter to URL to filter serial numbers list. |
group_title | String | Name of the product group. This field can be added as a GET parameter to URL to filter serial numbers list. |
status | Integer | Status of serial number.
|
lot_id | Integer | ID of serial number's stock lot. This field can be added as a GET parameter to URL to filter serial numbers list. |
lot_code | String | Unique code of serial number's stock lot. This field can be added as a GET parameter to URL to filter serial numbers list. |
cust_ord_id | Integer | If the item with this serial number has been shipped, show the database ID of
the customer order. This field can be added as a GET parameter to URL to filter serial numbers list. |
customer_order_code | String | If the item with this serial number has been shipped, show the customer order
number. This field can be added as a GET parameter to URL to filter serial numbers list. |
customer_order_created | Unix timestamp | Date and time when the customer order was created. GET parameters customer_order_created_min and customer_order_created_max can be added to URL to filter serial numbers list. |
rma_ord_id | Integer | If the item with this serial number was received in RMA order, show the database
ID of the RMA order. This field can be added as a GET parameter to URL to filter serial numbers list. |
rma_order_code | String | If the item with this serial number was received in RMA order, show the RMA
order number. This field can be added as a GET parameter to URL to filter serial numbers list. |
customer_id | Integer | If the item with this serial number has been shipped, show the database ID of
the customer. This field can be added as a GET parameter to URL to filter serial numbers list. |
customer_code | String | If the item with this serial number has been shipped, show the customer
number. This field can be added as a GET parameter to URL to filter serial numbers list. |
customer_name | String | If the item with this serial number has been shipped, show the customer
name. This field can be added as a GET parameter to URL to filter serial numbers list. |
site_id | Integer | ID of site where this serial number is located (only if Enterprise function
"Multiple Production Sites/Stocks" is enabled). This field can be added as a GET parameter to URL to filter serial numbers list. |
Shipments
https://api.mrpeasy.com/rest/v1/shipments[?shipment_id=...&code=...]
Shipments are read-only. Only GET method is supported. Other methods are disabled.
It is not possible to create a shipment directly. To ship the entire customer order, please update a CO and set the status 70 Shipped or 80 Delivered. This will create a shipment with all products and pick it up.
Field | Type | Description |
shipment_id | Integer, read-only | Database ID of the shipment.
This field can be added as a GET parameter to URL to filter shipments list. |
code | String | A unique number to identify the shipment.
This field can be added as a GET parameter to URL to filter shipments list. |
tracking_number | String | Tracking number.
This field can be added as a GET parameter to URL to filter shipments list. |
created | Unix timestamp | Date and time when this shipment was created.
GET parameters created_min and created_max can be added as a GET parameters to URL to filter the list of shipments. |
delivery_date | Unix timestamp | Date and time when this shipment should be picked.
GET parameters created_min and created_max can be added as a GET parameters to URL to filter the list of shipments. |
status | Integer | Status of shipment.
This field can be added as a GET parameter to URL to filter shipments list. |
status_txt | String, read-only | Status of shipment as text. |
orders | Array of objects | Orders that are shipped by this shipment. |
shipping_address | String or array, read-only | Shipping address as a text or an array. |
waybill_notes | String | Notes for the waybill. |
packing_notes | String | Notes for the picking list. |
products | Array of objects | Array of products that are shipped. |
Field | Type | Description |
customer_order_id | Integer | Database ID of the customer order.
This field can be added as a GET parameter to URL to filter the list of shipments. |
customer_order_code | String | A unique number to identify the customer order.
This field can be added as a GET parameter to URL to filter the list of shipments. |
rma_order_id | Integer | Database ID of the RMA order.
This field can be added as a GET parameter to URL to filter the list of shipments. |
rma_order_code | String | A unique number to identify the RMA order.
This field can be added as a GET parameter to URL to filter the list of shipments. |
purchase_order_id | Integer | Database ID of the purchase order.
This field can be added as a GET parameter to URL to filter the list of shipments. |
purchase_order_code | String | A unique number to identify the purchase order.
This field can be added as a GET parameter to URL to filter the list of shipments. |
Field | Type | Description |
article_id | Integer | Database ID of the stock item. |
product_id | Integer | Database product ID. |
item_code | String | A unique number to identify the stock item. |
item_title | String | Name of the stock item. |
unit_id | Integer or null | ID of the unit of measurement. |
unit | String | Unit of measurement. |
quantity_picked | Decimal | Number of products that have been shipped. |
quantity_booked | Decimal | Number of products that are waiting to be shipped. |
lot_id | Integer or null | ID of the stock lot. |
lot_code | String or null | A unique number of the stock lot. |
lot_status | Integer or null | Status of the stock lot. |
lot_status_txt | String or null | Status of the stock lot as text. |
expiry_date | Unix timestamp | Expiry date of this stock lot (only if Professional function "Expiry Date" is enabled). |
site_id | Integer | ID of site where this product should be shipped (only if Enterprise function "Multiple Production Sites/Stocks" is enabled). |
site | String | Name of site where this product should be shipped (only if Enterprise function "Multiple Production Sites/Stocks" is enabled). |
location_id | Integer | ID of storage location. |
location | String | Name of storage location. |
weight | Number | The total weight of this product (only if Enterprise function "Packing" is enabled). |
weight_unit_id | Integer |
|
weight_unit_txt | String | Weight UoM as a text. |
serials | Array | If a product has serial numbers, a list of shipped serial numbers (only if Professional function "Serial numbers" is enabled). |
Field | Type | Description |
serial_id | Integer | Database ID of the serial number. |
serial | String | Serial number. |
Stock items
https://api.mrpeasy.com/rest/v1/items[?article_id=...&code=...]
Field | Type | Description |
article_id | Integer, read-only |
Database ID of the stock item. If Matrix BOM is turned on, this is unique for
each variation. This field can be added as a GET parameter to URL to filter stock items list. |
product_id | Integer, read-only |
Database product ID. If Matrix BOM is turned on, product_id is the same at
all variations of the stock item. This field can be added as a GET parameter to URL to filter stock items list. |
code | String |
A unique part number to identify the item. If Matrix BOM is turned on, it is same for all variations. This field can be added as a GET parameter to URL to filter stock items list. |
title | String |
Name/description of the item. If Matrix BOM is turned on, it is same for all variations. This field can be added as a GET parameter to URL to filter stock items list. |
unit_id | Integer or null |
ID of the unit of measurement. If Matrix BOM is turned on, it is same for all variations. This field can be added as a GET parameter to URL to filter stock items list. |
group_id | Integer or null |
ID of the product group. If Matrix BOM is turned on, it is same for all variations. This field can be added as a GET parameter to URL to filter stock items list. |
group_code | String, read-only | A unique number to identify the product group. This field can be added as a GET parameter to URL to filter stock items list. |
group_title | String, read-only | Name of the product group. This field can be added as a GET parameter to URL to filter stock items list. |
is_raw | Boolean |
Shows if this is a raw material that is bought from vendors. If Matrix BOM is turned on, it is same for all variations. This field can be added as a GET parameter to URL to filter stock items list. |
selling_price | Decimal or array or null | If you sell this item, enter a selling price. Array is returned if tiered prices
are defined for the product. If Matrix BOM is turned on, it is same for all
variations. GET parameters selling_price_min and selling_price_max can be added to URL to filter stock items list. |
avg_cost | Decimal or null | Approximate cost of the item. Please check the documentation about how the cost of items is calculated. GET parameters avg_cost_min and avg_cost_max can be added to URL to filter stock items list. |
in_stock |
Decimal, read-only | Total physical quantity in stock right now (available + booked). GET parameters in_stock_min and in_stock_max can be added to URL to filter stock items list. |
available | Decimal, read-only | Quantity, which is in stock and available. GET parameters available_min and available_max can be added to URL to filter stock items list. |
booked | Decimal, read-only | Quantity, which is in stock and booked, not freely available. GET parameters booked_min and booked_max can be added to URL to filter stock items list. |
expected_total | Decimal, read-only | Total quantity which is planned to be received in the future. GET parameters expected_total_min and expected_total_max can be added to URL to filter stock items list. |
expected_available | Decimal, read-only | Quantity, which is expected and available, not booked yet. GET parameters expected_available_min and expected_available_max can be added to URL to filter stock items list. |
expected_booked | Decimal, read-only | Quantity, which is expected and already booked, not freely available. GET parameters expected_booked_min and expected_booked_max can be added to URL to filter stock items list. |
min_quantity | Decimal or array | The minimal inventory level of the item (reorder point). If the Enterprise function "Multiple Production Sites/Stocks" is disabled, this is a number. Otherwise,
|
revision | String | Revision of the stock item (only if Enterprise function "Revision/Version Control System" is enabled).
This field can be added as a GET parameter to URL to filter stock items list. |
icon | String | URL of the icon. |
quality_control | Boolean | Shows whether this item must pass quality inspection when received (only if Professional function "Quality Control" is enabled). |
onhold_period | Integer | The number of days the goods will be on hold for quality inspection (only if Professional function "Quality Control" is enabled). |
serials | Boolean | Shows whether this item has serial numbers (only if Professional function "Serial Numbers" is enabled). |
shelf_life | Integer | The number of days before the goods expire (only if Professional function "Expiry Date" is enabled). |
deleted | Boolean |
Shows if this item is deleted. This field can be added as a GET parameter to URL to filter stock items list. |
purchase_terms | Array of objects | Array of purchase terms. |
parameters | Array of objects | If Matrix BOM is turned on, this field contains array of parameters:
|
Purchase terms are read-only. They are objects with the following structure:
Field | Type | Description |
vendor_id | Integer | Database ID of the vendor. |
vendor_code | String | A unique number to identify the vendor. |
vendor_title | String | A name of the vendor. |
vendor_product_code | String | Item number in vendor's database. |
priority | Decimal | Priority of this vendor compared with other vendors that supply the same stock item (as a number, higher number means higher priority). |
lead_time | Integer | How many days it takes for the purchase order to arrive from the vendor to your stock. |
unit | String | Units, which are used to purchase the item. Can be whether item's unit or vendor's custom unit. |
unit_rate | Decimal | If a vendor has a custom unit, this is a conversion rate. |
min_quantity | Decimal | Minimum quantity of purchase order in item's units. |
vendor_min_quantity | Decimal | Minimum quantity of purchase order in vendor's units. |
price | Decimal | Price per one unit in the main currency (in vendor's unit, if it is used). |
currency_price | Decimal | Price per one unit in vendor's currency. |
currency | String | Vendor's currency. |
Sample POST data
title=Wooden+table&unit_id=5&group_id=3&is_raw=0
{ "title": "Wooden table", "unit_id": 5, "group_id": 3, "is_raw": false }
Stock lots
https://api.mrpeasy.com/rest/v1/lots[?lot_id=...&code=...]
Stock lots are read-only. Only GET method is supported. Other methods are
disabled.
Locations are objects with the following structure:
Field | Type | Description |
location_id | Integer | Database ID of the storage location. |
location | String | Name of the storage location. |
available | Decimal | Quantity of stock items that are available for booking. |
booked | Decimal | Quantity of stock items that are booked. |
Units of measurement
https://api.mrpeasy.com/rest/v1/units
Field | Type | Description |
unit_id | Integer, read-only | Database ID of the unit of measurement. |
title | String | Name of the unit of measurement. |
Sample POST data
title=pcs
{ "title": "pcs" }
User actions
https://api.mrpeasy.com/rest/v1/users/actions[?log_id=...&created_min=...]
User actions are read-only. Only GET method is supported. Other methods are disabled.
Field | Type | Description |
log_id | Integer, read-only | Database ID of the action. This field can be added as a GET parameter to URL to filter actions list. |
created | Unix timestamp | Date and time when this action was made. GET parameters created_min and created_max can be added to URL to filter actions list. |
user_id | Integer | Database ID of the user. This field can be added as a GET parameter to URL to filter actions list. |
username | String | Username of the user. |
object_id | Integer | Database ID of the target object. This field can be added as a GET parameter to URL to filter actions list. |
activity | Integer | Unique number of the activity. This field can be added as a GET parameter to URL to filter actions list. |
description | String | Text description of the activity. |
comment | String |
Additional comment about the action. This field can be added as a GET parameter to URL to filter actions list. |
It is possible to get a list of all possible activities by making a GET request to https://api.mrpeasy.com/rest/v1/users/actions/list.
Vendors
https://api.mrpeasy.com/rest/v1/vendors
Purchase orders are read-only. Only GET method is supported. Other methods are disabled.
Field | Type | Description |
vendor_id | Integer, read-only | Database ID of the vendor. |
code | String | A unique number to identify the vendor.
This field can be added as a GET parameter to URL to filter vendors list. |
title | String | Name of the vendor.
This field can be added as a GET parameter to URL to filter vendors list. |
currency | String | Default currency of the vendor. |
tax_rate | Decimal | Default tax percentage of the vendor. |
payment_period | Integer | Default payment period of the vendor in days. |
payment_period_type | Integer |
|
lead_time | Integer | Default lead time of the vendor in days. |
language | String | Language of documents that are printed for this vendor. |
language_id | Integer | Language of documents that are printed for this vendor. |
contact_data | Array of objects | Array of contact details. |
on_time_rate | Decimal | On time delivery percentage of the vendor during the period *. |
avg_delay | Decimal | Average delay of the vendor in days during the period *. |
total_cost | Decimal | Total cost of purchase orders during the period *. |
rejected | Decimal | Number of rejected items the period *. |
rejected_rate | Decimal | Percentage of rejected items the period *. |
* the default period is this year. To change the period, set the GET parameters start and end (YYYY-MM-DD).
Contact details are objects with the following structure:
Field | Type | Description |
line_id | Integer, read-only | Database ID of the contact information. |
type | String | Type of contact information:
|
value | String or object |
Contact information. If this is address or shipping_address, it is possible to pass a structured address as an object:
|
Work station types
https://api.mrpeasy.com/rest/v1/work-center-types
Field | Type | Description |
type_id | Integer, read-only | Database ID of the type. |
code | String | A unique number to identify the work center type. |
title | String | Name of the work center type. |
Sample POST data
title=Bench
{ "title": "Bench" }
Work stations
https://api.mrpeasy.com/rest/v1/work-centers
Field | Type | Description |
center_id | Integer, read-only | Database ID of the type. |
type_id | Integer | ID of the work center type. |
code | String | A unique number to identify the work center. |
title | String | Name of the work center. |
Sample POST data
type_id=2&title=Bench+1
{ "type_id": 2, "title": "Bench 1" }
Inventory
To fetch inventory, make a GET request to https://api.mrpeasy.com/rest/v1/stock/inventory. This returns a list of stock items with on hand quantities and costs.
To fetch inventory at a specific date, add a date parameter to request URL (for example, https://api.mrpeasy.com/rest/v1/stock/inventory?date=2025-01-01).
To fetch on hand quantity of a particular stock item, use request URL https://api.mrpeasy.com/rest/v1/stock/inventory/[article_id] (replace [article_id] with a number).
To get a total cost of inventory make a request to URL https://api.mrpeasy.com/rest/v1/stock/inventory/sum. A DATE parameter can be used to receive total cost at a specific date.
The following parameters can be added to a request URL to filter the result:
- group_id
- group_code
- group_title
- site_id
For example: https://api.mrpeasy.com/rest/v1/stock/inventory?group_id=1&site_id=2
Reports
MRPeasy API provides access to some reports.
To fetch a report, make a GET request to https://api.mrpeasy.com/rest/v1/report/[REPORT_TYPE].
The default period for reports is current month. You can adjust the period by setting dates like https://api.mrpeasy.com/rest/v1/report/[REPORT_TYPE]?from=2025 -01-01&to=2025-01-31. Maximum period length is one month.
The following reports are available:
Type | Description |
crm/shipped |
Get the CRM -> Statistics -> "Goods shipped" report. GET parameters with same names as fields can be added to URL to filter the list. Numeric parameters must have suffixes _min and _max. For example: https://api.mrpeasy.com/rest/v1/report/crm/shipped?from=2025 -01-01&to=2025-01-31&product_id=[ID]&quantity_min=10. |
production/products | Get a production plan by products (planned finish date is within the
period). |
production/coproducts | Get a list of co-products that were made during the period. |
production/operations | Get a list of manufacturing operations that are planned for the period (planned
finish date is within the period). |
Sample request:
https://api.mrpeasy.com/rest/v1/report/production/products?from=2025 -01-01&to=2025-01-31.
Sample response:
Object (
[from] => 2025-01-01
[to] => 2025 -01-31
[report] => production/products
[data] => Array (...)
)
Webhooks
Webhooks can be configured in Settings - Integration - API access - Webhooks.
A webhook enables MRPeasy to send a request to a provided URL whenever the status of a Customer order, Manufacturing order, Purchase order, or Shipment changes.
To set up a webhook, please provide the following information:
- URL - the endpoint where the webhook data will be sent.
- Object - customer, manufacturing, purchase order, or shipment.
- Action - depending on object, Status changed or Payment status changed events are supported.
- HTTP auth username - optional, if your URL requires authentication, you can provide the username here.
- HTTP auth password - optional, along with the username, you can provide the authentication password.
Up to 5 webhooks can be configured in total.
Code sample
Download a sample API client in PHP.
If cUrl is not configured to validate SSL certificates, please uncomment lines 279 and 280.
Troubleshooting
HTTP Response Code 403 returned
The 403 response code is returned when a GET request includes a body or a content-length header.
This commonly occurs when a client employs a single cURL session for multiple requests, and a GET request follows a prior POST or PUT request. By default, cURL accumulates request headers and includes all headers from preceding requests. Consequently, a POST or PUT request appends the content-length header, and the subsequent GET request is transmitted with this unintended header.
To avoid this issue, use the --next option in subsequent requests ( curl_reset in PHP ). This ensures that the headers are appropriately managed, preventing the inadvertent inclusion of headers from previous requests.
Are HTTP header names lowercase or Pascal-Case?
According to HTTP/2 standard, all headers are lowercase.