E-commerce API
POST /services/webshop/v1/customer/orders/list Auth

List customer orders

Returns a paginated list of the authenticated customer's past orders, most recent first. Only completed checkout orders are returned — quotes are excluded.

Request Body

FieldTypeRequiredDescriptionExample
per_page integer|null
min: 1 max: 100
No 10
search_query string|null
max: 255
No INV-5
sortKey string|null
id, order_number, invoice_id, status, payment_status, total_amount, created_at
No created_at
sortOrder string|null
asc, desc
No desc

Responses

200
422
401
429
Paginated list of orders
Headers
HeaderTypeDescriptionExample
X-RateLimit-Limit integer Maximum number of requests allowed per minute 60
X-RateLimit-Remaining integer Number of requests remaining in the current window 57
FieldTypeDescription
error boolean
message string
data object
data.current_page integer
data.data object[]
data.first_page_url string
data.from integer|null
data.last_page integer
data.last_page_url string
data.links mixed[]
data.next_page_url string|null
data.path string
data.per_page integer
data.prev_page_url string|null
data.to integer|null
data.total integer
Validation error
FieldTypeDescription
message string Errors overview.
errors object A detailed description of each field that failed validation.
Unauthenticated — missing or invalid Bearer token
Headers
HeaderTypeDescriptionExample
X-RateLimit-Limit integer Maximum number of requests allowed per minute 60
X-RateLimit-Remaining integer Number of requests remaining in the current window 57
FieldTypeDescription
error boolean
message string
Too Many Requests — rate limit exceeded
Headers
HeaderTypeDescriptionExample
X-RateLimit-Limit integer Maximum number of requests allowed per minute 60
X-RateLimit-Remaining integer Number of requests remaining in the current window 57
Retry-After integer Seconds until the rate limit resets 60
FieldTypeDescription
error boolean
message string
Base URL
https://api.wemasy.nl/api
Authentication

Request Sample
cURL
JS
PHP
Python
curl -X POST "https://api.wemasy.nl/api/services/webshop/v1/customer/orders/list" \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -H "Accept: application/json" \
  -H "Content-Type: application/json" \
  -d '{
    "per_page": 10,
    "search_query": "INV-5",
    "sortKey": "created_at",
    "sortOrder": "desc"
}'
fetch('https://api.wemasy.nl/api/services/webshop/v1/customer/orders/list', {
  method: 'POST',
  headers: {
    'Authorization': 'Bearer YOUR_API_TOKEN',
    'Accept': 'application/json',
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    "per_page": 10,
    "search_query": "INV-5",
    "sortKey": "created_at",
    "sortOrder": "desc"
})})
.then(r => r.json())
.then(data => console.log(data));
$response = Http::withToken('YOUR_API_TOKEN')
    ->accept('application/json')
    ->post('https://api.wemasy.nl/api/services/webshop/v1/customer/orders/list', {
    "per_page": 10,
    "search_query": "INV-5",
    "sortKey": "created_at",
    "sortOrder": "desc"
});
$data = $response->json();
import requests

headers = {
    "Authorization": "Bearer YOUR_API_TOKEN",
    "Accept": "application/json"
}
data = {
    "per_page": 10,
    "search_query": "INV-5",
    "sortKey": "created_at",
    "sortOrder": "desc"
}
r = requests.post("https://api.wemasy.nl/api/services/webshop/v1/customer/orders/list", headers=headers, json=data)
print(r.json())
Response Example
{
    "data": [
        {
            "id": 2502,
            "order_number": "8",
            "invoice_id": "INV-5",
            "status": "completed",
            "status_label": "Completed",
            "payment_status": "paid",
            "total_amount": 129.99,
            "created_at": "2026-04-20T14:20:00.000000Z"
        }
    ],
    "current_page": 1,
    "last_page": 1,
    "per_page": 10,
    "total": 1
}

Try It
Request Body Optional

Export