Pickup API
The Pickup API is used to book ad hoc pickup (to the terminal) that customers may need/want e.g. if they don't have a fixed pickup agreement with Bring for the relevant shipments. Two types of pickup are supported - cargo shipments in Norway and for parcels and business pallet in NO/SE/DK.
Authentication
To integrate with the Bring APIs, you will need a Mybring user account with an API key. Information about prerequisites and authentication headers can be found on the general API Getting Started page. In addition to authentication, you need to be authorized.
Rate limiting
Clients exceeding a certain number of requests per second will be throttled, and the response will contain http status code 429. If you have a use case requiring rates above the limit, please contact developer-booking@bring.com for assistance.
Formats
REST JSON over HTTP is recommended for all new integrations. While we currently also support XML, this is very likely to be phased out in the future. Pickup endpoints will assume all requests are UTF-8 encoded.
Special topics
Where is ad hoc pickup applicable?
For cargo services in Norway, ad hoc pickup orders are only applicable in the below scenarios.
Applicable:
- 5400 if shipment not booked with pickup
- 5100 if shipment not booked via Booking API (where pickup is always included)
Not applicable:
- 5300
- 5200
Endpoints
https://api.bring.com/pickup
Usage | Method | Endpoint |
---|---|---|
Order a pickup | POST |
/api/create
|
OpenAPI document
https://api.bring.com/pickup/api-docsOrder a pickup
https://api.bring.com/pickup/api/create
Request
header parameters
-
X-Mybring-API-Uid
Required -
- Description
- Mybring login ID
- Type
- any
-
X-Mybring-API-Key
Required -
- Description
- Your user's API key
- Type
- any
-
X-Bring-Test-Indicator
-
- Description
- A boolean value indicating whether this is a test or not
- Type
- any
Body schema
-
countryCode
Required - Two-letter ISO-3166-1 country codestring
-
Required
- object
-
-
companyName
Required - string
-
customerNumber
Required - string
-
-
Required
- object
-
-
city
Required - string
-
contactName
- string
-
deliveryInstruction
- Delivery instruction to the driverstring
-
email
Required - stringMax length: 60
-
message
- Generic message to the driverstring
-
phoneNumber
Required - string
-
postalCode
Required - string
-
street
Required - string
-
-
pickupDate
Required - string
- object
-
-
numberOfPackages
Deprecated - This is deprecated. Use packages and count insteadinteger <int32>
-
numberOfPallets
Deprecated - This is deprecated. Use pallets and count insteadinteger <int32>
-
numberOfPostContainers
Deprecated - This is deprecated. Use postContainers and count insteadinteger <int32>
- object
-
-
count
Required - For giving number of packages. Applicable for parcel pickups in Norway and Nordics and cargo pickupinteger <int32>
-
volumeInDm3
- Applicable and required for cargo pickupnumber
-
weightInGrams
- Applicable for parcel pickups in Norway and Nordics and required for cargo pickupinteger <int32>
-
- object
-
-
count
Required - For giving number of pallets. Applicable for parcel pickups in Norway and Nordicsinteger <int32>
-
weightInGrams
- Applicable for parcel pickups in Norway and Nordicsinteger <int32>
-
- object
-
-
count
Required - For giving number of postContainers. Applicable for parcel pickups in Norwayinteger <int32>
-
weightInGrams
- Applicable for parcel pickups in Norwayinteger <int32>
-
-
volumeInDm3
Deprecated - This is deprecated. Use packages and volumeInDm3 insteadnumber
-
weightInGrams
- Applicable for pickup in Nordicsinteger <int32>
-
-
pickupIsReadyAtTime
- Currently not in usestring
-
pickupTimeZone
- string
-
service
Required - The pickup service you want to bookstring
- Enum
PARCEL
CARGO
-
testIndicator
Deprecated - Deprecated, use HTTP header instead. For test orders, set this to trueboolean
- object
-
-
countryCode
Required - Two-letter ISO-3166-1 country codestring
-
Required
- object
-
-
companyName
Required - string
-
customerNumber
Required - string
-
-
Required
- object
-
-
city
Required - string
-
contactName
- string
-
deliveryInstructionToDriver
- Delivery instruction to the driverstring
-
email
Required - stringMax length: 60
-
messageToDriver
- Generic message to the driverstring
-
phoneNumber
Required - string
-
postalCode
Required - string
-
street
Required - string
-
-
pickupDate
Required - string
- object
-
-
numberOfPackages
Deprecated - This is deprecated. Use packages and count insteadinteger <int32>
-
numberOfPallets
Deprecated - This is deprecated. Use pallets and count insteadinteger <int32>
-
numberOfPostContainers
Deprecated - This is deprecated. Use postContainers and count insteadinteger <int32>
- object
-
-
count
Required - For giving number of packages. Applicable for parcel pickups in Norway and Nordics and cargo pickupinteger <int32>
-
volumeInDm3
- Applicable and required for cargo pickupnumber
-
weightInGrams
- Applicable for parcel pickups in Norway and Nordics and required for cargo pickupinteger <int32>
-
- object
-
-
count
Required - For giving number of pallets. Applicable for parcel pickups in Norway and Nordicsinteger <int32>
-
weightInGrams
- Applicable for parcel pickups in Norway and Nordicsinteger <int32>
-
- object
-
-
count
Required - For giving number of postContainers. Applicable for parcel pickups in Norwayinteger <int32>
-
weightInGrams
- Applicable for parcel pickups in Norwayinteger <int32>
-
-
volumeInDm3
Deprecated - This is deprecated. Use packages and volumeInDm3 insteadnumber
-
weightInGrams
- Applicable for pickup in Nordicsinteger <int32>
-
-
pickupIsReadyAtTime
- Currently not in usestring
-
pickupTimeZone
- string
-
service
Required - The pickup service you want to bookstring
- Enum
PARCEL
CARGO
-
testIndicator
Deprecated - Deprecated, use HTTP header instead. For test orders, set this to trueboolean attribute
-
Responses
200 OK
Schema
- array of objects
-
code
- string
-
consignmentCorrelationId
- string
- array of objects
-
lang
- string
-
message
- string
-
-
packageCorrelationId
- string
-
uniqueId
- string
-
- object
-
-
earliestPickupDate
Required - string <date-time>
-
isoFormattedEarliestPickupDateTime
- ISO formatted datestring <date-time>
-
isoFormattedLatestPickupDateTime
- ISO formatted datestring <date-time>
-
latestPickupDate
- string <date-time>
-
packageNumber
- string
-
status
Required - string
-
url
- string
-
- object
-
- array wrapped
-
- object
-
-
code
Required - string
-
consignmentCorrelationId
- string attribute
-
Required
- array wrapped
-
- object
-
-
lang
- string attribute
-
message
- string
-
-
packageCorrelationId
- string attribute
-
uniqueId
Required - string
-
- object
-
-
earliestPickupDate
Required - string <date-time>
-
isoFormattedEarliestPickupDateTime
- ISO formatted datestring <date-time>
-
isoFormattedLatestPickupDateTime
- ISO formatted datestring <date-time>
-
latestPickupDate
- string <date-time>
-
packageNumber
- string
-
status
Required - string
-
url
- string
-
400 Bad Request
Schema
- array of objects
- array of objects
-
code
- string
-
consignmentCorrelationId
- string
- array of objects
-
lang
- string
-
message
- string
-
-
packageCorrelationId
- string
-
uniqueId
- string
-
- object
-
-
earliestPickupDate
Required - string <date-time>
-
isoFormattedEarliestPickupDateTime
- ISO formatted datestring <date-time>
-
isoFormattedLatestPickupDateTime
- ISO formatted datestring <date-time>
-
latestPickupDate
- string <date-time>
-
packageNumber
- string
-
status
Required - string
-
url
- string
-
- array
-
- object
-
- array wrapped
-
- object
-
-
code
Required - string
-
consignmentCorrelationId
- string attribute
-
Required
- array wrapped
-
- object
-
-
lang
- string attribute
-
message
- string
-
-
packageCorrelationId
- string attribute
-
uniqueId
Required - string
-
- object
-
-
earliestPickupDate
Required - string <date-time>
-
isoFormattedEarliestPickupDateTime
- ISO formatted datestring <date-time>
-
isoFormattedLatestPickupDateTime
- ISO formatted datestring <date-time>
-
latestPickupDate
- string <date-time>
-
packageNumber
- string
-
status
Required - string
-
url
- string
-
Request examples
{
"countryCode": "NO",
"customerInformation": {
"companyName": "Norsk Bedrift AS",
"customerNumber": "*******"
},
"pickupAddress": {
"city": "OSLO",
"email": "norsk.bedrift@example.com",
"message": "Hentes på baksiden",
"phoneNumber": "+4712345678",
"postalCode": "0263",
"street": "Testsvingen 12"
},
"pickupDate": "2015-12-03",
"pickupDetails": {
"packages": {
"count": 2,
"volumeInDm3": 40,
"weightInGrams": 1000
}
},
"pickupIsReadyAtTime": null,
"pickupTimeZone": "Europe/Oslo",
"service": "CARGO",
"testIndicator": true
}
{
"countryCode": "SE",
"customerInformation": {
"companyName": "Svensk Bedrift AS",
"customerNumber": "************"
},
"pickupAddress": {
"city": "Stockholm",
"email": "svensk.bedrift@example.com",
"message": "Hentes på baksiden",
"phoneNumber": "+46781234567",
"postalCode": "12000",
"street": "Testsvingen 12"
},
"pickupDate": "2015-12-03",
"pickupDetails": {
"packages": {
"count": 2
},
"pallets": {
"count": 1
},
"weightInGrams": 15000
},
"pickupIsReadyAtTime": null,
"pickupTimeZone": null,
"service": "PARCEL",
"testIndicator": true
}
{
"countryCode": "NO",
"customerInformation": {
"companyName": "Norsk Bedrift AS",
"customerNumber": "************"
},
"pickupAddress": {
"city": "OSLO",
"email": "norsk.bedrift@example.com",
"message": "Hentes på baksiden",
"phoneNumber": "+4712345678",
"postalCode": "0263",
"street": "Testsvingen 12"
},
"pickupDate": "2015-12-03",
"pickupDetails": {
"packages": {
"count": 2,
"weightInGrams": 1000
},
"pallets": {
"count": 1,
"weightInGrams": 15000
},
"postContainers": {
"count": 0
}
},
"pickupIsReadyAtTime": null,
"pickupTimeZone": null,
"service": "PARCEL",
"testIndicator": true
}
<?xml version="1.0" encoding="UTF-8"?>
<pickupOrderRequest xmlns="http://www.bring.no/booking/" testIndicator="true">
<countryCode>NO</countryCode>
<customerInformation>
<companyName>Norsk Bedrift AS</companyName>
<customerNumber>*******</customerNumber>
</customerInformation>
<pickupAddress>
<city>OSLO</city>
<email>norsk.bedrift@example.com</email>
<messageToDriver>Hentes på baksiden</messageToDriver>
<phoneNumber>+4712345678</phoneNumber>
<postalCode>0263</postalCode>
<street>Testsvingen 12</street>
</pickupAddress>
<pickupDate>2015-12-03</pickupDate>
<pickupDetails>
<packages>
<count>2</count>
<volumeInDm3>40</volumeInDm3>
<weightInGrams>1000</weightInGrams>
</packages>
</pickupDetails>
<pickupTimeZone>Europe/Oslo</pickupTimeZone>
<service>CARGO</service>
</pickupOrderRequest>
<?xml version="1.0" encoding="UTF-8"?>
<pickupOrderRequest xmlns="http://www.bring.no/booking/" testIndicator="true">
<countryCode>SE</countryCode>
<customerInformation>
<companyName>Svensk Bedrift AS</companyName>
<customerNumber>************</customerNumber>
</customerInformation>
<pickupAddress>
<city>Stockholm</city>
<email>svensk.bedrift@example.com</email>
<messageToDriver>Hentes på baksiden</messageToDriver>
<phoneNumber>+46781234567</phoneNumber>
<postalCode>12000</postalCode>
<street>Testsvingen 12</street>
</pickupAddress>
<pickupDate>2015-12-03</pickupDate>
<pickupDetails>
<packages>
<count>2</count>
</packages>
<pallets>
<count>1</count>
</pallets>
<weightInGrams>15000</weightInGrams>
</pickupDetails>
<service>PARCEL</service>
</pickupOrderRequest>
<?xml version="1.0" encoding="UTF-8"?>
<pickupOrderRequest xmlns="http://www.bring.no/booking/" testIndicator="true">
<countryCode>NO</countryCode>
<customerInformation>
<companyName>Norsk Bedrift AS</companyName>
<customerNumber>************</customerNumber>
</customerInformation>
<pickupAddress>
<city>OSLO</city>
<email>norsk.bedrift@example.com</email>
<messageToDriver>Hentes på baksiden</messageToDriver>
<phoneNumber>+4712345678</phoneNumber>
<postalCode>0263</postalCode>
<street>Testsvingen 12</street>
</pickupAddress>
<pickupDate>2015-12-03</pickupDate>
<pickupDetails>
<packages>
<count>2</count>
<weightInGrams>1000</weightInGrams>
</packages>
<pallets>
<count>1</count>
<weightInGrams>15000</weightInGrams>
</pallets>
<postContainers>
</postContainers>
</pickupDetails>
<service>PARCEL</service>
</pickupOrderRequest>
Response examples
Pickup Order Response
{
"errors": null,
"pickupConfirmation": {
"earliestPickupDate": 1720159200000,
"isoFormattedEarliestPickupDateTime": "2024-05-27T08:00:00.000+00:00",
"isoFormattedLatestPickupDateTime": "2024-05-27T16:00:00.000+00:00",
"latestPickupDate": 1720188000000,
"packageNumber": "123456789012345678",
"status": "OK",
"url": "https://www.mybring.com/order/pickup/receipt/xxxxxxxxx"
}
}
Pickup Order Response
<pickupOrderResponse>
<pickupConfirmation>
<status>OK</status>
<earliestPickupDate>2024-05-27T08:00:00+00:00</earliestPickupDate>
<latestPickupDate>2024-05-27T16:00:00+00:00</latestPickupDate>
<url>https://www.mybring.com/order/pickup/receipt/xxxxxxxxx</url>
<packageNumber>123456789012345678</packageNumber>
</pickupConfirmation>
</pickupOrderResponse>
{
"errors": [
{
"code": "BOOK-INPUT-022",
"messages": [
{
"lang": "en",
"message": "Illegal product for country"
}
],
"uniqueId": "03aa5521-9729-4577-a2e7-2ae3381c6f04"
}
]
}
{
"errors": [
{
"code": "BOOK-INPUT-028",
"messages": [
{
"lang": "en",
"message": "Invalid country code"
}
],
"uniqueId": "1e60e8d6-3970-4711-a35e-7e0c50895060"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-012",
"messages": [
{
"lang": "en",
"message": "Selected pickup point should be in recipient country"
}
],
"uniqueId": "15e0b972-fc73-4d99-83a8-dfe94c145594"
}
]
}
{
"errors": [
{
"code": "BOOK-INPUT-020",
"messages": [
{
"lang": "en",
"message": "Invalid product ID"
}
],
"uniqueId": "75a97917-2034-4865-a066-b4d6fa22aa05"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-007",
"messages": [
{
"lang": "en",
"message": "Pickup date must be in the future"
}
],
"uniqueId": "70343d03-2dae-4c65-8377-0ebb0aae9cfe"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-001",
"messages": [
{
"lang": "en",
"message": "Error with input in pickupOrder"
}
],
"uniqueId": "48015cdf-c2d9-4fe0-b951-222b3cc57bad"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-003",
"messages": [
{
"lang": "en",
"message": "Cargo customer must provide cargoInformation element. Parcel customer must provide parcelsInformation element"
}
],
"uniqueId": "051a549f-5333-49ea-8b63-ad4eaa521aa8"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-015",
"messages": [
{
"lang": "en",
"message": "Chargeable weight must be below groupage max weight limit"
}
],
"uniqueId": "a46a0be7-5849-4c5f-97b3-97a336a329d5"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-006",
"messages": [
{
"lang": "en",
"message": "You must specify pickupDate element yyyy-MM-dd"
}
],
"uniqueId": "163a9cc4-9db3-41e1-b005-91b952b97701"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-016",
"messages": [
{
"lang": "en",
"message": "Must either have weightInGrams in pickupDetails, or on package or pallets level. Can not have both"
}
],
"uniqueId": "94006981-65be-446f-af84-3adb826d5e95"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-002",
"messages": [
{
"lang": "en",
"message": "Postal code must be given and be valid"
}
],
"uniqueId": "767aa5fe-ad0c-4676-99ef-fe44d26c1abc"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-005",
"messages": [
{
"lang": "en",
"message": "You must specify pickupIsReadyAtTime element HH:mm:ss"
}
],
"uniqueId": "2227eadc-48d5-42ab-af04-ed24ac20f409"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-008",
"messages": [
{
"lang": "en",
"message": "weightInGrams is required, and must be an integer larger than zero"
}
],
"uniqueId": "fbad693d-d400-4f2f-8ef1-586e90b8f1cc"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-010",
"messages": [
{
"lang": "en",
"message": "Country code is required"
}
],
"uniqueId": "0fcba0f2-1c80-42f8-91ad-5b7c82012428"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-009",
"messages": [
{
"lang": "en",
"message": "Must be an integer larger than zero"
}
],
"uniqueId": "56257b43-2a52-4ac0-b754-14e4ab53ce9f"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-004",
"messages": [
{
"lang": "en",
"message": "This customer number cannot be used to order Pickup"
}
],
"uniqueId": "12af2077-069e-4a62-a47e-ca6a20543d6f"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-013",
"messages": [
{
"lang": "en",
"message": "Combination pickupIsReadyAtTime and pickupDate must be in the future"
}
],
"uniqueId": "830bdd16-4ccc-4fc9-8d8c-c2f1d9d26777"
}
]
}
{
"errors": [
{
"code": "PICKUP-INTERNAL-001",
"messages": [
{
"lang": "en",
"message": "An unexpected error occured"
}
],
"uniqueId": "3373c7cb-129c-4a19-8399-6e7f7561c0f4"
}
]
}
{
"errors": [
{
"code": "PICKUP-INPUT-011",
"messages": [
{
"lang": "en",
"message": "Both Pickup Point ID and Country Code is Required"
}
],
"uniqueId": "7a59432e-c24e-4ef5-ac16-8d319390b7ef"
}
]
}
{
"errors": [
{
"code": "BOOK-AUTHORIZATION-001",
"messages": [
{
"lang": "en",
"message": "Your user is not authorized to perform this action"
}
],
"uniqueId": "857f9849-e2d6-403c-9c0f-6dc3022d70c7"
}
]
}
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->
<?xml version="1.0" encoding="UTF-8"?>
<!-- Example cannot be generated; root element name is undefined -->