KEMBAR78
eMAG Marketplace API Documentation v4.0.0 | PDF | Application Programming Interface | Array Data Type
0% found this document useful (0 votes)
435 views34 pages

eMAG Marketplace API Documentation v4.0.0

This document describes the eMAG Marketplace API version 4.0.0 for integrating partner systems. It outlines conventions for API requests and responses. Sections provide details on sending products and offers, processing orders, and shipping functionality. Updates have expanded product, order, and shipping data available through the API.

Uploaded by

Ovidiu Dobre
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
435 views34 pages

eMAG Marketplace API Documentation v4.0.0

This document describes the eMAG Marketplace API version 4.0.0 for integrating partner systems. It outlines conventions for API requests and responses. Sections provide details on sending products and offers, processing orders, and shipping functionality. Updates have expanded product, order, and shipping data available through the API.

Uploaded by

Ovidiu Dobre
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 34

eMAG Marketplace

API Documentation v4.0.0


21.11.2016

Version Date modified Changes


3.4.0 26.08.2014 Product families
Example for sending a new product
Example for reading an order
3.5.0 29.10.2014 Offer start date details
3.6.0 06.11.2014 More details in product / order keys
Removed keys on AWB save
3.7.0 22.01.2015 Added best practices on general requests for products, offers and orders updating
3.8.0 26.02.2015 Update on order status matrix
Removed messaging API
Changed invoice details to PDF download
Updated authentication PHP code example
3.9.0 17.03.2015 Added open_on_receipt on AWB save and awb_format on AWB read_pdf.
3.9.1 22.04.2015 Added method for sending order invoices.
Order example completed with vouchers and order attachments.
3.9.2 04.05.2015 Updated order status matrix.
3.9.3 06.05.2015 Added image and attachments restrictions. Added count method on category.
3.9.4 01.07.2015 Added attachments for order (invoice, manuals, warranty)
3.9.5 06.10.2015 Storno method, Poland locale, shipping contact & phone
Documentation responses, offer/documentation separation
3.9.6 26.10.2015 Added characteristic values on /category/read, characteristic values validation and parent category.
Added allowed categories read key.
Extended product_offer read and count methods (product validation status, stock)
3.9.7 02.12.2015 Update on order status matrix
3.9.8 20.01.2016 Added is_complete flag on order read method.
Extended order read and count methods (order status)
Category hierarchy (category parent id)
Order cancellation reasons
3.9.9 20.07.2016 Added Product Matching resource
4.0.0 21.11.2016 Added number of offers, buy button rank, best sale price & best recommended price on product_offer/read
Added min / max sale_price keys on API
Added new API route for uploading attachments
Table of Contents
1. eMAG Marketplace API ................................................................................................................................................... 3
1.1. Conventions ............................................................................................................................................................ 3
1.2. Request, resources and actions .............................................................................................................................. 4
1.3. Pagination and filters .............................................................................................................................................. 5
1.4. Response ................................................................................................................................................................. 5
2. Sending products and offers ........................................................................................................................................... 6
2.1. Reading eMAG categories, characteristics and family_types ................................................................................. 6
2.2. Reading VAT rates ................................................................................................................................................... 8
2.3. Sending a new product ........................................................................................................................................... 8
2.3.1. Example for a new product ........................................................................................................................... 14
2.4. Updating existing offer.......................................................................................................................................... 15
2.5. Product validation responses ................................................................................................................................ 19
2.6. Matching products ................................................................................................................................................ 19
2.7. Attaching offers on existing eMAG products ........................................................................................................ 20
3. Processing orders .......................................................................................................................................................... 20
3.1. Order fields ........................................................................................................................................................... 20
3.1.1. Product field in order details ....................................................................................................................... 21
3.1.2. Customer fields in order details .................................................................................................................... 22
3.1.3. Order invoices ............................................................................................................................................... 24
3.2. Order notification, acknowledgment and order filters......................................................................................... 24
3.3. Order status matrix ............................................................................................................................................... 25
3.4. Order filters ........................................................................................................................................................... 25
3.5. Updating orders .................................................................................................................................................... 27
3.5.1. Removing products from an order................................................................................................................ 28
3.5.2. Adding products to an existing order............................................................................................................ 28
3.5.3. Returned products and storno route ............................................................................................................ 28
4. Shipping eMAG Marketplace orders ............................................................................................................................. 31
4.1. Saving AWB's ......................................................................................................................................................... 32
4.2. Reading AWB PDF files .......................................................................................................................................... 33
4.3. Counting Localities ................................................................................................................................................ 33
4.4. Reading Localities.................................................................................................................................................. 34
4.5. Reading AWB......................................................................................................................................................... 34

2
1. eMAG Marketplace API

eMAG Marketplace API is developed by eMAG for Marketplace partners in order to allow them to use their
own CRM’s / ERP’s. This document explains the methods for calling the API.
The API can be used in order to:
 send products and offers
 process orders

1.1. Conventions

We define MARKETPLACE_API_URL constant of being the API URL of the platform


(ex: https://marketplace.emag.ro/api-3)
We define MARKETPLACE_URL constant of being the URL of the platform (ex: https://marketplace.emag.ro)
We define DEFAULT_CURRENCY constant of being the default currency of the platform (ex: RON).
All API parameters are key-sensitive.

Platform Romania Bulgaria

MARKETPLACE_URL https://marketplace.emag.ro https://marketplace.emag.bg

MARKETPLACE_API_URL https://marketplace.emag.ro/api-3 https://marketplace.emag.bg/api-3

Protocol HTTPS HTTPS

Locale ro_RO bg_BG

Default currency RON BGN

Platform Hungary Poland

MARKETPLACE_URL https://marketplace.emag.hu https://marketplace.agito.pl

MARKETPLACE_API_URL https://marketplace.emag.hu/api-3 https://marketplace.agito.pl/api-3

Protocol HTTPS HTTPS

Locale hu_HU pl_PL

Default currency HUF PLN

To access the API, simply pass your seller username, code and well computed hash. Please note that user should
be granted API rights in order to access the API.

$hash = sha1(http_build_query($data).sha1('testpassword'));

3
1.2. Request, resources and actions

A Marketplace API call is represented by sending a request to API URL of platform. Every request consists of a
POST to an URL like:
MARKETPLACE_URL/api-3/resource/action
Ex: https://marketplace.emag.ro/api-3/product_offer/save

RESOURCES AND AVAILABLE ACTIONS

Resource Resource URL Available actions

product_offer MARKETPLACE_URL/api-3/product_offer read save count match

order MARKETPLACE_URL/api-3/order read save count acknowledge

order/attachments MARKETPLACE_URL/api-3/order/attachments save

message MARKETPLACE_URL/api-3/message read save count

category MARKETPLACE_URL/api-3/category read count

vat MARKETPLACE_URL/api-3/vat read

locality MARKETPLACE_URL/api-3/locality read count

awb MARKETPLACE_URL/api-3/awb read save read_pdf

Below a code example using the resource "vat" and the action "read":

<html>
Running...<br>
<?
$data =
array (
'currentPage' => 1,
'itemsPerPage' => 10
);
$hash = sha1(http_build_query($data) . sha1('password'));
$requestData = array(
'code' => 'usercode',
'username' => 'username',
'data' => $data,
'hash' => $hash);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://mktp-stage.emag.ro/api-3/vat/read');
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'POST');
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($requestData));
$result = curl_exec($ch);
print($result);
?>
</html>

4
The API needs authorization and has an IP level filtering. Before testing, sellers should provide a list of
whitelisted IP’s. eMAG Marketplace will only allow API calls only from those IP’s.
The POST data consist of 4 mandatory keys as following:

REQUEST

Key Description

username User name of seller. Will be provided on seller creation.

code Code of seller. Will be provided on seller creation.

data Data to be passed to the API. The following document will describe keys.

hash SHA1 hash of URL encoded data concatenated with SHA1 hash of user password.

1.3. Pagination and filters

In order to limit the number of items returned, read actions accept pagination by passing to POST data following
parameters:
PAGINATION

Key Description Default value Example

currentPage Set current page displayed 1 currentPage =3

itemsPerPage Set number of items to be displayed in one page. Maximum is set to 1000. 100 itemsPerPage=1000

Also, filters can be included in POST to refine result set. Filters vary depending on the resource called and are
exampled on every resource section.

1.4. Response

When an API call is made, the server MUST reply with a response. The response will ALWAYS be JSON formatted
and the header 'Content-type: application/json' will always be passed.
RESPONSE

Key Description

isError Boolean value representing response status.

messages Messages included in the response, like error messages, etc.

results Results included in the response, mostly when reading resources.

5
IMPORTANT: Every API request must have a response and the response must contain the key “isError” and its
value must be “false”. For each call that does not have the key and “false” value, we recommend setting up
alerts, as the call most likely was not interpreted. We also recommend logging all calls and the corresponding
API response for a 30 days period.
Every request must have at most 4000 elements. If the call surpasses this limit the call will have a response
with key “isError:true” and “message: Maximum input vars of 4000 exceeded”.
In the event of an documentation error when saving a product, the API will return and “isError:true” message,
but the new offer will be saved and processed.

2. Sending products and offers


We define a product as a list of elements displayed in in eMAG platform for a product page. These elements
are:

 Name
 Brand
 Part number
 Description
 Images
 Product characteristics (and product families)
 Category
 Barcodes (optional)
 Other attachments (optional)
We define an offer as a list of elements required for an offer to be available for a product. These elements are:

 Price
 VAT rate
 Warranty
 Numerical stock or availability info
 Handling_time
eMAG Marketplace API allows a seller to:

 Send new products and offers


 Send new offers for existing eMAG products (sold by eMAG or any other seller)
 Update existing own offers and/or products

2.1. Reading eMAG categories, characteristics and family_types

Every eMAG product has to be included in a certain category. Sellers cannot create new categories or change
existing ones. Also, a seller can only post products and offers in its allowed categories list.
Reading categories without parameters will generate a response containing the first 100 categories. The read
can be paginated thus obtaining a full list of categories. Only active categories will be returned.

6
When passing a category id, the API will return the category name and the list of available characteristics and
their corresponding IDs, as well as the available product family_types and their corresponding IDs.
You can read the categories and their characteristics through the API.

The resource is category and the available actions are read and count.

CATEGORY – read

Key – level 1 Key – level 2 Key – level 3 Description Type Example

id Category eMAG id Integer id=604

name Category name String name=”Music”

is_allowed Indicates if the seller can send Integer is_allowed=0


products and offers in the
category. In order to request
access to a specific category, you
can use the Marketplace
interface.
0 = No 1 = Yes.

parent_id Id of the parent category Integer parent = 12

characteristics All characteristics available in List of


category arrays

id Characteristic eMAG id Integer id=38

name Characteristic name String name=”Audio”

display_order Characteristic display order Integer display_order=6

is_mandatory Indicates if the characteristic is Integer is_mandatory=0


mandatory when sending a
product. Possible values are 0 (the
characteristic is not mandatory)
and 1 (the characteristic
mandatory).

allow_new_value Indicates if the current Integer allow_new_value=0


characteristic allows you to
submit new values that are
automatically validated.

values List the first 256 existing values of Array 0 => 'Value 1'
the current characteristic. 1 => 'Value 2'

family_types List of all family types available in List of


category arrays

id Family type id Integer Id=95

name Family name String name=”Quantity”

7
characteristics All characteristics of current List of
family type arrays

characteristic_id Characteristic Id Integer characteristic_id=44

characteristic_family_type_id Can only have 3 values, each Integer characteristic_family


corresponding to a different _type_id=2
display method:
“1" ="Thumbnails";
"2"="Combobox";
"3"="Graphic Selection"

is_foldable A foldable characteristic wraps all Integer Is_foldable=1


family members (with different
characteristic values) as one item
in the eMAG category listing

display_order Characteristic display order Integer

2.2. Reading VAT rates

When sending an offer, you have to send the VAT rate id by sending us a valid VAT id.

The resource is vat and the action is read. The API will return the list of available VAT rates and their corresponding id’s.

2.3. Sending a new product

Sending a product for the first time requires you to send the entire product documentation and all the offer
data. Please note that creating new products implies human validation, so a new product will not be displayed
in eMAG platform immediately.
The products that are not compliant with eMAG Documentation Standard will not pass the human validation;
in this case you will be notified by our support team. The eMAG Documentation Standard that is available upon
request for each category, and it contains the best practices for documenting a product.
In order to send a new product, the resource is product_offer and the available action is save.

PRODUCT OFFER – save and create/update product

Key – level 1 Key – level 2 Description Constraints Example

id Seller internal product id. This is Required. Integer value id=243409


the primary key for identifying a between 1 and 16777215.
product offer.

category_id Product category eMAG id. Required. Integer between 1 category _id=506
and 65535.

vendor_category_id Seller internal category id. Integer. Optional. vendor_category_id=506

8
PRODUCT OFFER – save and create/update product

Key – level 1 Key – level 2 Description Constraints Example

part_number_key eMAG part_number_key. Used Optional. String. Will be part_number_key=ES0NK


for attaching a product offer to validated. BBBM
an existing product in eMAG
platform. If you want to create
new product, don’t set this key.

name Product name. Should be Required. String between 1 name=”Test product”


consistent with eMAG Product and 255 characters long.
Documentation Standard.

part_number Manufacturer unique identifier Required. String between 1 part_number=”md788hc/


of the product. and 128 characters. a”

description Product description. Should be Optional. String between 1 description=”test”


consistent with eMAG Product and 16777215 characters. Can
Documentation Standard. contain basic HTML tags.

brand Brand name. Should be Required. String between 1 brand=”Brand test”


consistent with eMAG Product and 255 characters.
Documentation Standard.

weight The weight of the product Optional. Decimal value weight=12.123456


between 0 and 999999. Up to
six decimals.

images Product images data array. Optional. List of arrays.

display_type Image display type. Optional. Default value 0. display_type=1


1 – main image Integer value between 0 and
2 – secondary image 2.
0 – other images

url Seller image URL. Should be Required. String between 1 url=”http://valid-url.jpg”


consistent with eMAG Product and 1024 characters. Valid
Documentation Standard. Max URL. JPG, JPEG or PNG file
6000px x 6000px and 8 Mb in type.
size.

characteristics Characteristic data. Note that Optional. List of arrays.


characteristics have to be
category valid (be part of
category template). Should be

9
PRODUCT OFFER – save and create/update product

Key – level 1 Key – level 2 Description Constraints Example

consistent with eMAG Product


Documentation Standard.

id Characteristic eMAG id. Required. Integer value id=24


between 1 and 65535

value Characteristic value. Should be Required. String between 1 value=”test”


consistent with eMAG Product and 255 characters
Documentation Standard.

family Family array. Used to create a Optional. Array.


new family, add a product to an
existing family, or removing a
product from a family.

id The unique integer identifier of Required. Integer Id=0


the family in your platform. If set
to 0 (id=0), the product will be
removed from its current family.

name Required. Seller Family name. Required if family id is not name="Test product"
equal to 0;

family_type_id Required. eMAG Family type id Required if family id is not family_type_id=95


that can be acquired by API (the equal to 0. Integer.
resource is category and the
action is read).

url Product URL on the seller Required. String between 1 url=”http://valid-url.html”


website. and 2014 characters.

warranty The warranty offered in months. Optional. Default value 0 (no warranty=24
warranty). Integer between 0
and 255.

barcode Optional. No default value. barcode=Array('barcode1'


Product barcode identifier (EAN,
Array of strings between 1 and , 'barcode2')
UPC, ISBN, GTIN). Please use the
20 characters long.
supplier barcode, not your
internal barcodes.

10
PRODUCT OFFER – save and create/update product

Key – level 1 Key – level 2 Description Constraints Example

attachments Optional. List of arrays.


Product attachments data. Max
10 Mb in size.

id Seller attachment internal id. Optional. Integer value id=123


between 1 and 4294967295.

url Required. String between 1 url=”http://valid-url”


Seller attachment URL.
and 1024 characters. Valid
URL to document.

status Seller offer status. Required. Integer value, 1 or 0. status=1


1 – status active
0 – status inactive

sale_price Required. Decimal value sale_price=51.6477


Seller offer sale price without
greater than 0. Up to four
VAT
decimals.

recommended_price Optional. Decimal value recommended_price=51.6


Seller offer recommended retail
greater than 0. Up to four 477
price before discount, without
decimals. Must be greater
VAT. If set, the offer will be
than sale_price.
displayed as promo.

min_sale_price Seller’s min offer sale price Required on first product save. min_sale_price=40.6477
without VAT Decimal value greater than 0.
Up to four decimals.

max_sale_price Seller’s max offer sale price Required on first product save. max_sale_price=60.6477
without VAT Decimal value greater than 0.
Up to four decimals. Must be
greater than min_sale_price.

availability Offer availability array. Required. List of arrays. {


0=>{
warehouse_id=1,
id=3}}

availability warehouse_id The id of the warehouse. Required. Integer. warehouse_id=1


Use warehouse_id=1 for only
one warehouse.

availability id Offer availability id. Required. Integer. id=3

11
PRODUCT OFFER – save and create/update product

Key – level 1 Key – level 2 Description Constraints Example

2 = limited stock
3 = in stock
5 = out of stock

stock Offer available quantity array. Required. List of arrays. {


0=>{
warehouse_id=1,
value=20}}

stock warehouse_id The id of the warehouse. Required inside stock array. warehouse_id=1
Use warehouse_id=1 for only Integer.
one warehouse.

stock value Offer available quantity. Required inside stock array. value=20
Integer between 0 and 65535.
If present, stock overwrites
availability_id.

handling_time Handling time array. If no array is Optional. List of arrays. {


sent, the products are shipped 0=>{
the same day they are received. warehouse_id=1,
value=1}}

handling_time warehouse_id The id of the warehouse. Required inside handling_time warehouse_id=1


Use warehouse_id=1 for only array. Integer.
one warehouse.

handling_time value Handling time, in number of days Required inside handling_time value=0
counted from the day the order array. Integer value between 0
was received. If handling_time = and 255. Default value = 0.
0 the order will be shipped the
same day it is received.

start_date If it's a new offer, it represents Optional. Text in YYYY-MM-DD start_date=”2014-12-31”


the date your offer will be format. Date can be as far as
available from. For offer 60 days in the future (cannot
updates, it schedules value be earlier than tomorrow).
updates for the following data: Cannot be null.

 sale_price
 recommended_price
 stock

12
PRODUCT OFFER – save and create/update product

Key – level 1 Key – level 2 Description Constraints Example

 handling_time
 vat_id
 warranty
 status
 availability

All other data will be updated


on the fly. Using start_date, for
example, you can schedule the
inactivation of an offer, a price
update, etc.

vat_id Seller offer VAT rate id. Use Required. Integer. Ex: vat _id=1
/vat/read to display possible
values.

IMPORTANT:

 Min / Max sale price keys are used for price check purposes and are mandatory for all calls used to create
product/offers for the first time. As a best practice we recommend sending these keys only when you
want to change their values.
 Sale price will be validated against min_sale_price and max_sale_price. Any offer that is not within the
specified range will be rejected.
 In order to change a previously sent product image or attachment the url should be different from the
one already sent. We reload the images only if the URL differs.
 We recommend as a best practice sending one product in each product_offer call and multi-threading
requests rather than sending multiple at once. Also, we recommend sending the product data only upon
product create/update, as there is no need to resend product unless it changed. Also we recommend
sending the offer data upon changing (no matter the frequency) and at least weekly (even if the offer is
the same) rather using periodical sending (crons, agents). You should program marketing campaigns
using “start_date” campaign. Also please offer the possibility for an offer to be attached to an existing
eMAG product (using part_number_key).
 In the event of an documentation error when saving a product, the API will return and “isError:true”
message, but the new offer will be saved and processed.
 When adding a product to a family
o The category id of a product and the category id of its family type (family_type_id) must be the
same.
o All characteristics that define a family must be present and must have a valid value
o All characteristics that define a family must have a single value
o If a family is not valid, you will receive a warning response, but the product will be saved/updated
13
o When moving a product from one family to another you only have to send the product with its
new family type, id and name and make sure you follow the same rules as above

2.3.1. Example for a new product

Array(
Array(
"id" => "6050",
"family" => Array(
"id" => 111,
"family_type_id" => 97,
"name" => "test_family "
),
"category_id" => "1315",
"part_number" => "test-part-number",
"name" => "Test name",
"description" => "Test description",
"brand" => "Test brand name",
"images" => Array(
Array(
"display_type" => "1",
"url" => "http://www.image-url.test"
)
),
"url" => "http://www.product-url.test",
"status" => "1",
"sale_price" => "406.4515",
"recommended_price" => "506.4515",
"min_sale_price" => "200.0000",
"max_sale_price" => "700.0000",
"availability" => Array(
Array(
"warehouse_id" => "1",
"id" => "3"
)
),
"handling_time" => Array(
Array(
"warehouse_id" => "1",
"value" => "2"
)
),
"stock" => Array(
Array(
"warehouse_id" => "1",
"value" => "2"
)
),
"commission" => Array(
"type" => "percentage",
"value" => "8"
),
"vat_id" => "1",
"characteristics" => Array(
Array(
"id" => "5213",
"value" => "Characteristic 5213 value"
),
Array(
"id" => "1339",
"value" => "Characteristic 1339 1st value"
),

14
Array(
"id" => "1339",
"value" => " Characteristic 1339 2nd value"
)
)
)
)

2.4. Updating existing offer

When updating an existing offer for a product, you should send only the offer, without the documentation.
Mandatory when updating a product offer are the following keys:
 id
 status
 sale_price
 vat_id
 commission
 availability_id
 handling_time
 stock
Please note that although the API permits sending the entire documentation on each offer update (price change,
out-of-stock change, etc.) we do not recommend or encourage such a practice.
If you need to deactivate a valid offer on the website, you should send the offer with the “status = 0”.

Array(
Array(
"id" => "6050",
"family" => Array(
"id" => 111,
"family_type_id" => 97,
"name" => "test_family "
),
"category_id" => "1315",
"part_number" => "test-part-number",
"name" => "Test name",
"description" => "Test description",
"brand" => "Test brand name",
"images" => Array(
Array(
"display_type" => "1",
"url" => "http://www.image-url.test"
)
),
"url" => "http://www.product-url.test",
"status" => "1",
"sale_price" => "406.4543",
"sale_price" => "406.45",
"availability" => Array(
Array(
"warehouse_id" => "1",
"id" => "3"
)

15
),
"handling_time" => Array(
Array(
"warehouse_id" => "1",
"value" => "2"
)
),
"stock" => Array(
Array(
"warehouse_id" => "1",
"value" => "2"
)
),
"commission" => Array(
"type" => "percentage",
"value" => "8"
),
"vat_id" => "1",
)
)

Reading and counting products and offers

In order to check the existing products (offers) and their status, the resource is product_offer and the available
action are read and count.

PRODUCT_OFFER – read

Key – level 1 Key – level 2 Description Type Example

part_number_key eMAG part_number_key. String part_number_key=ES0


NKBBBM

number_of_offers How many sellers have active offers on this product Integer number_of_offers=3

buy_button_rank The rank of the offer in its race to win the <Add to cart> Integer buy_button_rank=1
button

best_offer_sale_price Best selling price available in eMAG for the same Product Decimal best_offer_sale_price
=51.6477

best_offer_recommen The corresponding recommended price for the offer Decimal best_offer_recommen
ded_price holding the best selling price ded_price=54.6477

category_id Product category eMAG id. Integer category _id=506

vendor_category_id Seller internal category id. Integer vendor_category_id=5


06

id Seller internal product id. This is the primary key for Integer id=243409
identifying a product offer.

brand Product brand name. String brand=”Brand test”

name Product name. String name=”Test product”

16
PRODUCT_OFFER – read

Key – level 1 Key – level 2 Description Type Example

part_number Product part number. String part_number=”md788


hc/a”

sale_price Seller offer sale price without VAT Decimal sale_price=51.6477

recommended_price Seller offer recommended retail price before discount, Decimal recommended_price=
without VAT. 54.6477

currency Product price currency. String currency='RON'

description Product description. String description=”test”

url Product URL on the seller website. String url=”http://valid-


url.html”

warranty The warranty offered in months. Integer warranty=24

general_stock The sum of the stock on all seller warehouses. Is Integer general_stock=20
decremented and incremented when orders are processed.

estimated_stock This key takes into account the reserved stock on Integer estimated_stock=20
unacknowledged orders.

weight The weight of the product Decimal weight=12.123456

status Seller offer status. Integer status=1

1 – status active
0 – status inactive

images List of
arrays

url Seller image URL. String url=”http://valid-


url.jpg”

display_type Image display type. Integer display_type=1


1 – main image
2 – secondary image
0 – other images

characteristics All characteristics available in category List of


arrays

id Characteristic eMAG id Integer id=38

value Characteristic value. String value=”test”

vat_id Seller offer VAT rate id. Integer vat _id=1

family Product family. Array

17
PRODUCT_OFFER – read

Key – level 1 Key – level 2 Description Type Example

id Family id. Integer id=295

name Family name. String name=”Test family”

handling_time List of
arrays

warehouse_id The id of the warehouse. Integer warehouse_id=1

value Handling time, in number of days counted from the day Integer value=0
the order was received.

validation_status Product validation status Array

value Product validation status value Integer value=4

Description Product validation status description String Description=”Rejected


documentation”

The following filters are available when counting and reading products and offers:
Key Description Constraints

id Displays the details for the corresponding Optional. Integer value between 1 and 4294967295.
ext_id.

currentPage Set current page displayed Optional, integer.


Ex: currentPage =3

itemsPerPage Set number of items to be displayed in one Optional, integer.


page. Maximum is set to 1000.
itemsPerPage=1000

status Returns only the offers with this status. Optional. Seller offer status.
1 – status active
0 – status inactive

availability_id Only the offers with this availability_id. Optional. Offer availability id.
2 = limited stock
3 = in stock
5 = out of stock
new value that supports both availabiity_id 2 and 3 at the same time

validation_status Returns only the results with this validation Optional.


status. 1 = New item
2 = Published offer
3 = Invalid offer
4 = Rejected documentation

18
Key Description Constraints

5 = Awaiting MKTP revalidation


6 = Awaiting documentation validation
7 = Offer in validation
8 = Invalid price

general_stock Returns only offers with numerical Optional


general_stock that have a value between 0 general_stock = 3
and the input.

estimated_stock Returns only offers with numerical Optional


estimated_stock that have a value between 0 reserved_stock = 3
and the input.

2.5. Product validation responses

After reading a product, all the elements previously sent are retuned, along with the key doc_errors. The key is
not null for products that were rejected due to improper documentation. Below the list of possible errors, when
they occur and the possible actions you need to take.
Table 1 - Product documentation error list

Product
documetation error list.xlsx

2.6. Matching products

In order to check if a product you sell already exists in eMAG catalog the resource is product_offer and the
available action is match. The matching action is similar to the saving action so you should simply send the entire
product documentation and all the offer data to the product matching resource. Please note that the matching
action is available only for one product at a time therefore the request must be encapsulated in a single array.
As a response to the matching request the following information will be returned:

Key – level 1 Description Type Example

part_number_key eMAG part_number_key. String part_number_key=ES0NKBBBM

name eMAG product name String name=”Test product”

emag_product_url eMAG product name String emag_product_url=”http://www.ema


g.ro/product/pd/ES0NKBBBM/”

19
2.7. Attaching offers on existing eMAG products

If the product already exists in eMAG catalog, just add the key “part_number_key” with product’s
part_number_key. The part_number_key is the last key found in the URL of an eMAG product. It will ALWAYS
have both numbers and characters. Ex: for product http://www.emag.ro/telefon-mobil-nokia-105-black-105-
black/pd/D5DD9BBBM/ the part_number_key is D5DD9BBBM.

3. Processing orders
An order consists of customer details, products and discounts from vouchers. It also has information about
payment method, shipping tax. Also, each order always has a status attached. The available statuses are:
0 - canceled
1 - new
2 - in progress
3 - prepared
4 - finalized
5 – returned
The resource is order and the available actions are read, save, count and acknowledge.

3.1. Order fields

An order has the following properties:


Key Description Constraints Example

id The number that uniquely identifies Required. Integer value between 1 and 4294967295. id=939393
an order.

status The order processing status. The Required. Integer value between 0 and 5. status=1
possible values are:
0 - cancelled
1 - new
2 - in progress
3 – prepared
4 - finalized
5 - returned

is_complete A flag indicating if the order is Optional. Integer value. is_complete=1


complete (has all details necessary
for processing) or not. The possible
values are:
0 - incomplete;
1 - complete.

payment_mode_id The order payment method. The Required. Integer. payment_mode_id=1


possible values are:
1 - COD (cash on delivery)
2 - bank transfer
3 - online card payment

20
Key Description Constraints Example

observation Additional customer notes. Optional. Text. observation=”delivery


after 6 PM”

date The cart submission timestamp. Optional. Text in YYYY-mm-dd HH:ii:ss format. date=”1970-01-01
23:59:59”

payment_status The online payment status. Only Required only for online payment methods. Integer. payment_status=0
used for online payment methods. It is highly recommended to also interpret the
The possible values are: payment status when reading orders with Card
0 - not paid Online payment method.
1 - paid

shipping_tax The shipment tax value. Optional. Decimal. shipping_tax=”19.99”

details A list with additional order details Optional. List.


that are not standard.

customer A list with the details about the Optional. List. The field list is detailed
customer, the shipping and the below.
billing addresses.

products A list of arrays describing the List. The field list is detailed
products in the order. below.

vouchers A list describing the voucher List.


discounts.

invoices A list describing seller invoice details. List.


Sellers may only save invoice details.

is_storno Mandatory key when products are Optional. Boolean. is_storno=true


returned for a finalized order. True indicates partial storno.
Further details here.

cancellation_reason The order cancellation reason. The Optional. Integer value between 1 and 5. cancellation_reason=1
possible values are:
1 - Out of stock
2 - Cancelled by the client
3 - No contact with the client
4 - Returned by courier - wrong
contact data
5 - Returned by courier – not
accepted by client

3.1.1. Product field in order details

Key – level Key – level 2 Description Constraints Example


1

id eMAG internal order product line id. Any Required. Integer value id=123
update on order product lines must use this between 1 and 9999999.
id. id=243409

21
Key – level Key – level 2 Description Constraints Example
1

product_id Seller internal product id. This is the Optional. Integer. product_id=3331
primary key for identifying a product offer.

status The status of product of the order. The Required. Integer. status=1
possible values are:
0 - cancelled
1 - active

part_number Manufacturer unique identifier for the Optional. String between 1 and part_number='682133frs'
product. 128 characters.

created The date when the order product line was Optional. Text in YYYY-mm-dd created='2014-07-24
created. HH:ii:ss format. 12:16:50'

modified The date when the order product line was Optional. Text in YYYY-mm-dd modified='2014-07-24
last modified. HH:ii:ss format. 12:18:53'

currency Product price currency. Optional. String. currency='RON'

quantity Product quantity. Required. Integer. Positive, quantity=2


different than 0.

sale_price The sale price without VAT. Required. Integer. sale_price=12.1234

details Additional product notes. Optional. Text. details=”text”

status The status of product of the order. The Required. Integer. status=1
possible values are:
0 - cancelled
1 - active

sale_price The sale price without VAT. Required. Integer. sale_price=12.1234

details Additional product notes. Optional. Text. details=”text”

3.1.2. Customer fields in order details

The customer field has the following properties:


Key Description Constraints Example

id The number that uniquely identifies a customer. Optional. Integer value id=1
between 1 and2147483647.

name The customer's name. Optional. Text. name=”Surname Name”

email This is a hash that uniquely identifies the Optional. Text. email=”1243536@emag.ro”
customer’s email.

company The name of the company. For physical person it Optional. Text. company=”Company name ltd.”
has the same value as name.

gender The customer gender. The possible values are: Optional. Text. gender=”M”
M - male

22
Key Description Constraints Example

F – female

code The company registration code. Optional. Text. code=”14399840”

registration_number The company registration number. Optional. Text registration_number=”


40/372/2002”

bank The bank name. Optional. Text. bank=”Bank name”

iban The bank account. Optional. Text. iban=”


RO24BACX0000000031430310”

fax The customer's fax number. Optional. Text. fax=”4021123123”

legal_entity A flag indicating if the customer is physical or Optional. Integer value. legal_entity=1
juridical entity. The possible values are:
0 - private entity;
1 - legal entity.

is_vat_payer A flag indicating it the customer is vat payer. The Optional. Integer value. is_vat_payer=0
possible values are>
0 - the customer is not vat payer;
1 - the customer is vat payer.

phone_1 The customer's first phone number. Optional. Text. phone_1=”4021123123”

phone_2 The customer's second phone number. Optional. Text.

phone_3 The customer's third phone number. Optional. Text.

billing_country The customer's invoice country. Optional. Text. billing_country=”Romania”

billing_suburb The customer's invoice county. Optional. Text. billing_suburb=”Suburb”

billing_city The customer's invoice city. Optional. Text. billing_city=”City”

billing_street The customer's invoice address. Optional. Text. billing_street=”Street Name”

billing_postal_code The customer's invoice postal code. Optional. Text. billing_postal_code=”23125”

shipping_contact The name of the contact person that will pick up Optional. Text. shipping_contact=”Name
the parcel. Should be printed on the AWB. Surname”

shipping_phone The phone used by the courrier to contact the Optional. Text. shipping_phone=”23125”
shipping person. Should be printed on the AWB.

shipping_country The customer's shipping country. Optional. Text. shipping_country=”Romania”

shipping_suburb The customer's shipping county. Optional. Text. shipping_suburb=”Suburb”

shipping_city The customer's shipping city. Optional. Text. shipping_city=”City name”

shipping_street The customer's shipping suburb. Optional. Text. shipping_street=”Street name”

shipping_postal_code The customer's shipping postal code. Optional. Text. shipping_postal_code=”23125”

23
Key Description Constraints Example

billing_locality_id This field uniquely identifies a locality in the Integer value between 1 billing_locality_id=”23”
eMAG database. and 4294967295.
It represents the billing locality.

shipping_locality_id This field uniquely identifies a locality in the Integer value between 1 shipping_locality_id=”23”
eMAG database. and 4294967295.
It represents the shipping locality.

3.1.3. Order invoices

When pushing orders into finalized status, you should also send the invoice PDF file location for the specific
order.
The resource is order/attachments and the available action is save.
The following keys should be sent in attachments array in order to display an invoice in the customer’s order
details: name, url, type.

An attachment has the following properties:


Key Description Constraints Example

order_id The number that uniquely identifies an order. Required. Integer value id=939393
between 1 and 4294967295.

name The name of the attachment displayed to the customer (in order Optional. String between 1 name='Invoice
history or in email) and 60 characters title'

url Attachment URL. Required. String between 1 url=”http://valid-


and 1024 characters. Valid url/invoice.pdf”
URL to document.

type The type of document attached to the order Integer. Optional. Default type=1
1=”Invoice”

force_download Flag used in order to force attachment download restrictions. If value Integer. Optional. Default force_download=0
is 0 and the attachment URL has not changed, the attachment will not value 0. Possible values: 0,1.
be downloaded again.

3.2. Order notification, acknowledgment and order filters

When a new order is placed in eMAG Marketplace for the first time, it’s status is 1 (new) and a GET request with
the order id is automatically made to an URL you provide (call-back URL).
Ex: http://valid_url/path?order_id=123
In the next step, you should read the order passing the id previously mentioned and after successfully saving
the order in your database you should notify us by calling back the API using the route MARKETPLACE _URL/api-
3/order/acknowledge/[orderId]. This stops the order notification system for the mentioned order. Unless
acknowledged, we will notify the new orders for up to 48 hours.
24
IMPORTANT:
 Order acknowledge is the only method of marking the order status as “in progress”.
 Clients may ask for an order to be canceled, this will be done by eMAG only if the order was not
acknowledged by the seller, thus some of the orders may be read directly with status 0 (canceled).

3.3. Order status matrix

The following matrix defines the order flow in eMAG Marketplace:


New status
Actual status 1 - new 2 - in progress 3 - prepared 4 - finalized 0 - canceled 5 - returned
1 - new No Yes by ACK only No No No No
2 - in progress No Yes Yes Yes Yes No
3 - prepared No No Yes Yes Yes No
4 - finalized No No Yes in 48h max Yes Yes in 48h max Yes in RT* + 5 days max
0 - canceled No Yes Yes Yes Yes No
5 - returned No No No No No No
*RT = return time allowed to customers

IMPORTANT:
 We recommend setting up a periodical /order/read (cron, agent) that should identify orders that were
not acknowledged. By default on /order/read we expose the last 100 orders, but you can request up to
1000 or use pagination. Do not forget to test the order status matrix against your internal order
workflow. As a best practice you should either acknowledge the order prior the read or re-read the order
after acknowledging it; an order can be modified by eMAG employees upon the client’s request as long
as it is not acknowledged.
 You can only edit the order (add/remove products modify quantity or price) when in status 2 (in
progress) or 3 (prepared).
 Once an order is finalized, you can change its status back to status 3 (prepared) or 0 (canceled) only in
the first 48 hours since finalization.
 Order status “finalized” will be set automatically when issuing the first AWB for that order. See chapter
Saving AWB’s.
 The order status “returned” is set automatically when all the products from the initial invoice are marked
as returned. The change is permitted only within the maximum return timeframe allowed to the
customer.

3.4. Order filters

You can read all your orders though the API, using filters.
The following filters are available when counting orders:
Key Description Constraints

id Only the order with this value. Optional. Integer value between 1
and4294967295.

25
Key Description Constraints

createdBefore Only the orders created before the specified date. Optional. Text in YYYY-mm-dd HH:ii:ss
Can only be set if “createdAfter” is present. Maximum 1 month format.
difference.

createdAfter Only the orders created after the specified date. Can only be set if Optional. Text in YYYY-mm-dd HH:ii:ss
“createdBefore” is present. Maximum 1 month difference. format.

modifiedBefore Only the orders modified before the specified date. Can only be set if Optional. Text in YYYY-mm-dd HH:ii:ss
“modifiedAfter” is present. Maximum 1 month difference. format.

modifiedAfter Only the orders after before the specified date. Can only be set if Optional. Text in YYYY-mm-dd HH:ii:ss
“modifiedBefore” is present. Maximum 1 month difference. format.

status Only the orders with the specified status. It is a single value or a list of Optional. Integer or list.
values.

payment_mode_ id Only the orders with the specified payment method id. It is a single Optional. Integer or list.
value or a list of values.

is_complete Only the orders with the specified completion status. Optional. Order completion status.
1 – complete orders
0 – incomplete orders

The following filters are available when reading orders:


Key Description Constraints

itemsPerPage The maximum number of orders to return. Optional. Integer value between 1
and 100.

currentPage The page offset. Optional. Integer value between 1


and 65535.

id Only the order with this value. Optional. Integer value between 1
and4294967295.

createdBefore Only the orders created before the specified date. Can only be set if Optional. Text in YYYY-mm-dd
“createdAfter” is present. Maximum 1 month difference. HH:ii:ss format.

createdAfter Only the orders created after the specified date. Optional. Text in YYYY-mm-dd
HH:ii:ss format.

modifiedBefore Only the orders modified before the specified date. Can only be set if Optional. Text in YYYY-mm-dd
“modifiedAfter” is present. Maximum 1 month difference. HH:ii:ss format.

modifiedAfter Only the orders after the specified date. Optional. Text in YYYY-mm-dd
HH:ii:ss format.

status Only the orders with the specified status. It is a single value or a list of values. Optional. Integer or list.

26
Key Description Constraints

payment_mode_id Only the orders with the specified payment method id. It is a single value or a Optional. Integer or list.
list of values.

is_complete Only the orders with the specified completion status. Optional. Order completion status.
1 – complete orders
0 – incomplete orders

3.5. Updating orders

You cannot create new orders through the API, you can only read and update them. When updating an order,
the seller should send ALL the fields initially read.
Example (order update with an invoice attached):
Array (
0 =>
Array (
'status' => 3,
'date' => '2014-07-24 12:16:47',
'observation' => NULL,
'id' => 41200,
'payment_mode_id' => 1,
'payment_status' => 0,
'vendor_name' => 'vendor1',
'customer' =>
Array (
'id' => 12556,
'name' => 'Name Surname',
'company' => 'Company name',
'gender' => 'M',
'code' => 128312xxxx212,
'email' => '',
'created' => '2014-07-24 12:17:20',
'modified' => '2014-07-24 12:17:32',
'bank' => '',
'iban' => '',
'fax' => '',
'mkt_id' => 312556,
'phone_1' => '0724xxxx32',
'phone_2' => '',
'phone_3' => '',
'registration_number' => '',
'billing_country' => 'RO',
'billing_suburb' => 'Suburb',
'billing_city' => 'City Name',
'billing_locality_id' => 3,
'billing_street' => 'Street,
'billing_postal_code' => '',
'shipping_country' => 'RO',
'shipping_suburb' => 'Suburb',
'shipping_city' => 'City',
'shipping_locality_id' => 3,
'shipping_street' => 'Street',
'shipping_postal_code' => '',
'is_vat_payer' => 1,
'legal_entity' => 0,
),
'details' =>
Array (
),
'products' =>
Array (
0 =>
Array (

27
'id' => 82407,
'product_id' => 1264,
'part_number' => '68133',
'quantity' => 1,
'sale_price' => '967.6613',
'currency' => 'RON',
'created' => '2014-07-24 12:16:50',
'modified' => '2014-07-24 12:17:32',
'status' => 1,
'details' =>
Array (
),
'vat' => '0.2400',
),
),
'shipping_tax' => '0.0000',
'vouchers' =>
Array (
"id":"1234",
"modified":"2015-04-23 11:30:09",
"created":"2015-04-23 11:30:09",
"status":"1",
"voucher_id":"387361",
"sale_price_vat":"-1.9355",
"sale_price":"-8.0645",
"voucher_name":"eMAG giftcard",
"vat":"0.24"
),
),
)

3.5.1. Removing products from an order

To remove a product from the order send the status=0 for the product or do not send it at all. Products can be
removed from an order only while in status 2 or 3 (in progress or prepared). For returned products (the order is
in status 4, finalized), please use the storno route.

3.5.2. Adding products to an existing order

To add a new product to an existing order, add it to the order by sending the product id (mandatory), name,
status and sale price.
IMPORTANT: virtual products such as internal discounts can be inserted in an order, even if they were not
previously sent to eMAG. Adding these products to an order will not make them available for purchase in the
eMAG Marketplace platform.

3.5.3. Returned products and storno route

A finalized order cannot be modified, it can be fully returned by changing the order status from finalized (4) to
returned (5) or have only some of the products returned using a call with is_storno key true.
The following conditions must be met in order for a partial storno to occur:
 Order must be in status 4
 At least one product quantity was reduced

The following scenarios can be used as a guideline for returning products (partial storno) from a finalized
order:

28
Current order status Request isError Order read

status' => 4, status' => 4, FALSE status' => 4,


'products' => 'products' => 'products' =>
array ( array ( array (
0 => 0 => 0 =>
array ( array ( array (
'id' => 1, 'id' => 1, 'id' => 1,
'product_id' => '1', 'product_id' => '1', 'product_id' => '1',
'quantity' => 2, 'quantity' => 1, 'quantity' => 1,
'sale_price' => '123.4567', 'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1, 'status' => 1,
), ), ),
1 => 1 => 1 =>
array ( array ( array (
'id' => 2, 'id' => 2, 'id' => 2,
'product_id' => '2', 'product_id' => '2', 'product_id' => '2',
'quantity' => 2, 'quantity' => 2, 'quantity' => 2,
'sale_price' => '123.4567', 'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1, 'status' => 1,
), ), ),
), ), ),
'is_storno'=true

status' => 4, status' => 4, FALSE status' => 4,


'products' => 'products' => 'products' =>
array ( array ( array (
0 => 0 => 0 =>
array ( array ( array (
'id' => 1, 'id' => 1, 'id' => 1,
'product_id' => '1', 'product_id' => '1', 'product_id' => '1',
'quantity' => 2, 'quantity' => 2, 'quantity' => 0,
'sale_price' => '123.4567', 'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1, 'status' => 1,
), ), ),
1 => 1 => ),
array ( array (
'id' => 2, 'id' => 2,
'product_id' => '2', 'product_id' => '2',
'quantity' => 2, 'quantity' => 0,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1,
), ),
), ),
'is_storno'=true

status' => 4, status' => 4, FALSE status' => 4,


'products' => 'products' => 'products' =>
array ( array ( array (
0 => 0 => 0 =>
array ( array ( array (
'id' => 1, 'id' => 1, 'id' => 1,
'product_id' => '1', 'product_id' => '1', 'product_id' => '1',
'quantity' => 2, 'quantity' => 2, 'quantity' => 0,
'sale_price' => '123.4567', 'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1, 'status' => 1,
), ), ),
1 => 1 => ),
array ( array (

29
Current order status Request isError Order read

'id' => 2, 'id' => 2,


'product_id' => '2', 'product_id' => '2',
'quantity' => 2, 'quantity' => 2,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 0,
), ),
), ),
'is_storno'=true

status' => 4, status' => 4, TRUE The request will be discarded, as you are
'products' => 'products' => trying to modify a finalized order without
array ( array ( is_storno key.
0 => 0 =>
array ( array (
'id' => 1, 'id' => 1,
'product_id' => '1', 'product_id' => '1',
'quantity' => 2, 'quantity' => 2,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1,
), ),
1 => 1 =>
array ( array (
'id' => 2, 'id' => 2,
'product_id' => '2', 'product_id' => '2',
'quantity' => 2, 'quantity' => 1,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1,
), ),
), ),

status' => 4, status' => 4, TRUE The request will be discarded, as you are
'products' => 'products' => sending is_storno key without any change
array ( array ( to an order line
0 => 0 =>
array ( array (
'id' => 1, 'id' => 1,
'product_id' => '1', 'product_id' => '1',
'quantity' => 2, 'quantity' => 2,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1,
), ),
1 => 1 =>
array ( array (
'id' => 2, 'id' => 2,
'product_id' => '2', 'product_id' => '2',
'quantity' => 2, 'quantity' => 2,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1,
), ),
), ),
'is_storno'=true

status' => 3, status' => 3, TRUE The request will be discarded, as you are
'products' => 'products' => sending is_storno key for an order with a
array ( array ( status different than 4
0 => 0 =>
array ( array (

30
Current order status Request isError Order read

'id' => 1, 'id' => 1,


'product_id' => '1', 'product_id' => '1',
'quantity' => 2, 'quantity' => 2,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1,
), ),
1 => 1 =>
array ( array (
'id' => 2, 'id' => 2,
'product_id' => '2', 'product_id' => '2',
'quantity' => 2, 'quantity' => 2,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1,
), ),
), ),
'is_storno'=true

status' => 4, status' => 4, TRUE The request will be discarded, as you are
'products' => 'products' => trying to send a negative quantity for a
array ( array ( product
0 => 0 =>
array ( array (
'id' => 1, 'id' => 1,
'product_id' => '1', 'product_id' => '1',
'quantity' => 2, 'quantity' => 2,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1,
), ),
1 => 1 =>
array ( array (
'id' => 2, 'id' => 2,
'product_id' => '2', 'product_id' => '2',
'quantity' => 2, 'quantity' => 2,
'sale_price' => '123.4567', 'sale_price' => '123.4567',
'status' => 1, 'status' => 1,
), ),
), 2 =>
array (
'id' => 2,
'product_id' => '2',
'quantity' => -1,
'sale_price' => '123.4567',
'status' => 1,
),
),
'is_storno'=true

4. Shipping eMAG Marketplace orders


For electronic deliveries and downloadable goods, please skip this section. Shipping an eMAG Marketplace order
requires the seller to issue an AWB using eMAG Marketplace API.
The resource is AWB and the available actions are read and save
31
4.1. Saving AWB's

To save an AWB just call the API with the following parameters:
Key Description Constraints

order_id Identifies the order Required. Integer value between 1 and 4294967295.

Must be a valid order in the eMAG database, and must be


owned by the seller.

sender *Array explained below

receiver *Array explained below

insured_value The insured value Optional. Double value between 0 and 999999999

weight The weight of delivery Optional. Double value between 0 and 99999

envelope_number Number of envelopes to be delivered Required. Integer value between 0 and 9999. If
parcel_number is 0, this parameter cannot be 0

parcel_number Number of parcels to be delivered Required. Integer value between 0 and 999. If
envelope_number is 0, this parameter cannot be 0

observation Observation text Optional. String value between 0 and 255

cod Cash on delivery Required. Double value between 0 and 999999999

courier_account_id Unique identifier for seller’s courier account. If not Optional. Integer.
provided, a default account will be used.

pickup_and_return If set to 1, sender expects something in return to this Optional. Value can only be 0 or 1.
expedition (documents, buy-back products, etc).

saturday_delivery If set to 1, sender requests the package to be delivered on Optional. Value can only be 0 or 1.
Saturday.

sameday_delivery If set to 1, sender requests the package to be delivered the Optional. Value can only be 0 or 1.
same day.

open_on_receipt If set to 1, the parcel/envelope can be opened on receipt. Optional. Value can only be 0 or 1. Default 1.

An AWB S/R (sender/receiver) has the following properties:


Key Description Constraints

name S/R's name Required. String value between 3 and 255

contact Receiver's contact person name Required. String value between 1 and 255

phone1 S/R first phone number Required. String value between 8 and 11 digits (only '+' character is allowed at the
beginning of the string)

32
Key Description Constraints

phone2 S/R second phone number Optional. String value between 8 and 11 digits (only '+' character is allowed at the
beginning of the string)

legal_entity If Receiver is legal entity (applicable only LEGAL_ENTITY_NO = 0


to receiver) LEGAL_ENTITY_YES = 1

locality_id S/R's locality_id Required. Integer value between 1 and 4294967295.

Must be a valid locality in the eMAG database.

street S/R's street Required. String value between 3 and 255

zipcode S/R's zipcode Optional. String value between 1 and 255

4.2. Reading AWB PDF files

To read an existing AWB PDF simply access the URL below and replace code, username with proper values and
hash value with sha1 value of password:
MARKETPLACE_URL/awb/read_pdf?emag_id=awb_id&code=my_code&username=my_username&hash=a28
bb826824c30ffddd47e9dce41dfb6c39bd655

Optional: You can set the paper format on PDF download link by using the parameter "awb_format=A4" in the
link. The possible values are A4, A5 and A6.

4.3. Counting Localities

In order to issue an AWB you need to submit the correct locality id. You can also use the id from the order.

The resource is locality and the available actions are read and count.

The following filters are available when counting localities:

Key Description Constraints

emag_id The locality with this id Integer

name All localities with this name String of length between 0 and 60

modified All localities modified after this date Date with the 'Y-m-d H:i:s' format

33
4.4. Reading Localities

The following filters are available when reading localities:


Key Description Constraints

emag_id The locality with this id Integer

name All localities with this name String of length between 0 and 60

modified All localities modified after this date Date with the 'Y-m-d H:i:s' format

itemsPerPage The maximum number of localities to return. Optional. Integer value between 1 and 100.

currentPage The page offset. Optional. Integer value between 1 and 65535.

A locality has the following properties:

Key Description Constraints

emag_id The id of the locality Integer

name The name of the locality String of length between 0 and 60

region([1-4]+) Region name String of length between 0 and 60

region([1-4]+)_latin Region name latin version String of length between 0 and 60

geoid Geographic id of the location Integer

modified Last modification date Date with the 'Y-m-d H:i:s' format

4.5. Reading AWB

The following filters are available when reading AWBs:


Key Description Constraints

emag_id The AWB's eMAG id. Integer value between 1 and 4294967295.

Must be a valid AWB in eMAG database.

34

You might also like