ovpay/src/openapi/orders/orders-crud.yaml

2464 lines
124 KiB
YAML

openapi: 3.0.1
info:
title: ABT Orders CRUD APIs
version: "1.0"
description: CRUD APIs for ABT Orders database. These are NOT the functional APIs from Service Engine.
servers:
- url: https://services.acc.api.htm.nl/abt/abtorder/1.0
paths:
/orders:
get:
tags:
- Order
summary: Find orders.
description: Find orders.
servers:
- url: https://api.integratielaag.nl/v1
parameters:
- in: query
name: externalOrderId
schema:
type: string
example: EXT001
required: false
description: The order id in the external system.
- in: query
name: orderNumber
schema:
type: string
example: ORD123456
required: false
description: The human readable number of the order.
- in: query
name: customerProfileId
schema:
type: integer
example: 42
required: false
description: The technical id of the customer related to the order.
- in: query
name: totalAmount
schema:
type: integer
example: 112
required: false
description: The total amount of the order.
- in: query
name: touchPointId
schema:
type: integer
example: 1
required: false
description: The id of the touch point where the order was initiated.
- in: query
name: languageId
schema:
type: integer
example: 1
required: false
description: The id of the language in which the order was created.
- in: query
name: createdBefore
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp before which the order should have been created.
- in: query
name: createdAfter
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp after which the order should have been created.
- in: query
name: updatedBefore
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp before which the order should have been updated.
- in: query
name: updatedAfter
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp after which the order should have been updated.
- in: query
name: orderStatusId
schema:
type: array
items:
type: integer
explode: false
required: false
description: Filter on most recent order status. 1 = concept, 2 = awaitingPayment, 3 = pendingPayment, 4 = paid, 5 = delivered, 6 = cancelled.
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"orders":
[
{
"orderId": "afce35b2-1dff-4ace-98d0-4b9ac405c87d",
"externalOrderId": "bac3958b-804a-43e3-b5f7-0b0fffaae5b7",
"orderNumber": "123456",
"customerProfileId": 1337,
"totalAmount": 121,
"touchPoint":{
"touchPointId": 1,
"name": "Perplex"
},
"language":
{
"languageId": 1,
"name": "Nederlands",
"iso639Code": "nl-NL",
"ietfCode": "nl",
},
"createdOn": "2024-03-22T09:00:00",
"lastUpdatedOn": "2024-03-22T09:00:00",
"order_OrderStatus":
[
{
"order_orderStatusId": "f1d0e1a7-a3cf-4876-b8f2-073add10667f",
"orderStatus":
{ "orderStatusId": 4, "name": "paid" },
"createdOn": "2024-03-22T09:00:00",
"description": "Order succesvol betaald",
},
{
"order_orderStatusId": "2b9b7943-3a74-4f2e-ad65-012b62c80821",
"orderStatus":
{
"orderStatusId": 3,
"name": "pendingPayment",
},
"createdOn": "2024-03-22T08:55:00",
"description": "Betaling in behandeling",
},
],
"orderLines":
[
{
"orderLineId": "7a7a9d1a-3fc8-4058-a28b-082860aaa311",
"externalOrderLineId": "f5fddff0-7fbd-4285-bccb-e584f431ea69",
"productId": 1,
"productName": "HTM Maandkorting 20%",
"fikoArticleNumber": "FIKO-1234",
"productDescription": "HTM Maandkorting 20%",
"taxAmount": 21,
"taxCode": "V21",
"taxPercentage": 21,
"amountExclTax": 100,
"amountInclTax": 121,
"quantity": 1,
"orderLineTerms":
[
{
"orderLineTermsId": "fe354db7-12ad-4fc1-bc63-a704c4e0d91e",
"termsUrl": "generalTermsAndConditions.pdf",
},
],
"validFrom": "2024-03-22T09:00:00",
"validUntil": "2025-03-22T09:00:00",
"orderLineStatus":
{ "orderLineStatusId": 4, "name": "delivered" },
"createdOn": "2024-03-22T09:00:00",
"lastUpdatedOn": "2024-03-22T09:00:00",
"customerTokens":
[
{
"customerTokenId": "878ad7c1-cd8f-4bcf-a983-1bd8c6e6975e",
"tokenType":
{ "tokenTypeId": 1, "name": "EMV" },
"ovPayTokenId": 1,
"serviceReferenceId": "NLOV1234567ABCDEFG",
"amount": 34,
"ovpasNumber": "OV34567",
"verificationCode": "A7H6",
"personalAccountData":
{
"personalAccountDataId": "47db8a40-3238-4bf5-9284-759e3888bd47",
"name": "Jan de Vries",
"birthdate": "1970-01-01",
"photo": "" ,
"challengeType":
{
"challengeTypeId": 1,
"name": "email",
},
"oneTimePassword": "H5Iiz3JTaQeIV8p",
},
},
],
"orderAccountingStatuses":
[
{
"orderAccountingStatusId": "7c5118d0-8535-4464-9239-83a7ba8fd2db",
"accountingStatus":
{
"accountingStatusId": 1,
"name": "open",
},
"createdOn": "2024-03-22T09:00:00",
"description": "Financiele transactie voor de FIKO.",
},
],
},
],
"payments":
[
{
"paymentId": "3ba4a3c7-0803-4214-800b-365851b8903d",
"createdOn": "2024-03-22T09:00:00",
"amountDebit": 121,
"paymentMethod":
{
"paymentMethodId": 1,
"name": "ideal",
"provider": "Buckaroo",
},
"touchPoint":{
"touchPointId": 1,
"name": "Perplex"
},
"isRefund": false,
"htmPaymentReference": "HTM-1234",
"pspPaymentReference": "Buckaroo-1234",
"paymentStatuses":
[
{
"paymentStatusId": 1,
"createdOn": "2024-03-22T09:00:00",
"statusCode": "190",
"statusDescription": "Success",
"statusSubCode": "S001",
"statusSubDescription": "PaymentSuccessFul",
},
],
"mandateInput":
{
"mandateInputId": "0a875e67-dc9f-4825-a030-d732a2adbfbc",
"directDebitMandateType":
{
"directDebitMandateTypeId": 1,
"name": "import",
},
"createdOn": "2024-03-22T09:00:00",
"bic": "RABONL2U",
"iban": "NL44RABO0123456789",
"ascription": "J. de Vries",
"place": "Den Haag",
},
},
],
"orderCustomer":
{
"orderCustomerId": "19ef6882-8eda-43bf-b48e-9b4ff8745a50",
"birthname": "Jan",
"surname": "Vries",
"prefix": "de",
"emailAddress": "jandevries@outlook.com",
"dateOfBirth": "1970-01-01",
"orderCustomerAddresses":
[
{
"orderCustomerAddressId": "aa50047c-58ac-4f15-9448-ee000dfc6893",
"addressType":
{ "addressTypeId": 3, "name": "Billing" },
"street": "Kon. Julianaplein",
"houseNumber": 10,
"houseNumberSuffix": "a",
"postalCode": "2595 AA",
"city": "Den Haag",
"country": "NL",
},
],
},
},
],
"href": null,
}
post:
tags:
- Order
summary: Create a new order.
description: Create a new order.
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
examples:
Minimum order request body:
summary: Minimum order request
description: Minimum order request
value:
{
"totalAmount": 0,
"touchPointId": 1,
"createdOn": "2024-03-22T09:00:00",
"order_OrderStatus":
[
{
"orderStatusId": 1,
"createdOn": "2024-03-22T09:00:00",
}
],
}
Maximum order request :
summary: Maximum order request
description: Maximum order request
value:
{
"externalOrderId": "bac3958b-804a-43e3-b5f7-0b0fffaae5b7",
"customerProfileId": 1337,
"totalAmount": 121,
"touchPointId": 1,
"languageId": 1,
"createdOn": "2024-03-22T09:00:00",
"order_OrderStatus":
[
{
"orderStatusId": 4,
"createdOn": "2024-03-22T09:00:00",
"description": "Order succesvol betaald",
},
{
"orderStatusId": 3,
"createdOn": "2024-03-22T08:55:00",
"description": "Betaling in behandeling",
},
],
"orderLines":
[
{
"externalOrderLineId": "f5fddff0-7fbd-4285-bccb-e584f431ea69",
"productId": 1,
"productName": "HTM Maandkorting 20%",
"fikoArticleNumber": "HTM-MND-20",
"productDescription": "HTM Maandkorting 20%",
"taxAmount": 21,
"taxPercentage": 21,
"amountExclTax": 100,
"amountInclTax": 121,
"quantity": 1,
"orderLineTerms":
[{ "termsUrl": "generalTermsAndConditions.pdf" }],
"validFrom": "2024-03-22T09:00:00",
"validUntil": "2025-03-22T09:00:00",
"orderLineStatusId": 4,
"createdOn": "2024-03-22T09:00:00",
"customerTokens":
[
{
"tokenTypeId": 1,
"ovPayTokenId": 1,
"serviceReferenceId": "NLOV1234567ABCDEFG",
"amount": 34,
"ovpasNumber": "OV34567",
"verificationCode": "A7H6",
"personalAccountData":
{
"name": "Jan de Vries",
"birthdate": "1970-01-01",
"photo": "DSC_0502.JPG",
"challengeTypeId": 1,
"oneTimePassword": "H5Iiz3JTaQeIV8p",
},
},
],
"orderAccountingStatuses":
[
{
"accountingStatusId": 1,
"createdOn": "2024-03-22T09:00:00",
"description": "Financiele transactie voor de FIKO.",
},
],
},
],
"payments":
[
{
"createdOn": "2024-03-22T09:00:00",
"amountDebit": 121,
"paymentMethodId": 1,
"touchPointId": 1,
"isRefund": false,
"htmPaymentReference": "HTM-1234",
"pspPaymentReference": "Buckaroo-1234",
"paymentStatuses":
[
{
"createdOn": "2024-03-22T09:00:00",
"statusCode": "190",
"statusDescription": "Success",
"statusSubCode": "S001",
"statusSubDescription": "PaymentSuccessFul",
},
],
"mandateInput":
{
"directDebitMandateTypeId": 1,
"createdOn": "2024-03-22T09:00:00",
"bic": "RABONL2U",
"iban": "NL44RABO0123456789",
"ascription": "J. de Vries",
"place": "Den Haag",
},
},
],
"orderCustomer":
{
"birthname": "Jan",
"surname": "Vries",
"prefix": "de",
"emailAddress": "jandevries@outlook.com",
"dateOfBirth": "1970-01-01",
"orderCustomerAddresses":
[
{
"addressTypeId": 1,
"street": "Kon. Julianaplein",
"houseNumber": 10,
"houseNumberSuffix": "a",
"postalCode": "2595 AA",
"city": "Den Haag",
"country": "NL",
},
],
},
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"orderId": "afce35b2-1dff-4ace-98d0-4b9ac405c87d",
"orderNumber": "ORD123456",
}
/orders/{orderId}:
parameters:
- in: path
name: orderId
schema:
type: string
format: uuid
example: d1dd439b-6072-4b97-89c9-724268865b93
required: true
description: The id of the order to process.
get:
summary: Get a single order.
description: Get a single order.
tags:
- Order
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"orderId": "afce35b2-1dff-4ace-98d0-4b9ac405c87d",
"externalOrderId": "f5fddff0-7fbd-4285-bccb-e584f431ea69",
"orderNumber": "123456",
"customerProfileId": 1337,
"totalAmount": 121,
"touchPoint":{
"touchPointId": 1,
"name": "Perplex"
},
"language":
{
"languageId": 1,
"name": "Nederlands",
"iso639Code": "nl-NL",
"ietfCode": "nl",
},
"createdOn": "2024-03-22T09:00:00",
"lastUpdatedOn": "2024-03-22T09:00:00",
"order_OrderStatus":
[
{
"order_orderStatusId": "f1d0e1a7-a3cf-4876-b8f2-073add10667f",
"orderStatus": { "orderStatusId": 4, "name": "paid" },
"createdOn": "2024-03-22T09:00:00",
"description": "Order succesvol betaald",
},
{
"order_orderStatusId": "2b9b7943-3a74-4f2e-ad65-012b62c80821",
"orderStatus":
{ "orderStatusId": 3, "name": "pendingPayment" },
"createdOn": "2024-03-22T08:55:00",
"description": "Betaling in behandeling",
},
],
"orderLines":
[
{
"orderLineId": "7a7a9d1a-3fc8-4058-a28b-082860aaa311",
"externalOrderLineId": "f5fddff0-7fbd-4285-bccb-e584f431ea69",
"productId": 1,
"productName": "HTM Maandkorting 20%",
"fikoArticleNumber": "FIKO-1234",
"productDescription": "HTM Maandkorting 20%",
"taxAmount": 21,
"taxCode": "V21",
"taxPercentage": 21,
"amountExclTax": 100,
"amountInclTax": 121,
"quantity": 1,
"orderLineTerms":
[
{
"orderLineTermsId": "fe354db7-12ad-4fc1-bc63-a704c4e0d91e",
"termsUrl": "generalTermsAndConditions.pdf",
},
],
"validFrom": "2024-03-22T09:00:00",
"validUntil": "2025-03-22T09:00:00",
"orderLineStatus":
{ "orderLineStatusId": 4, "name": "delivered" },
"createdOn": "2024-03-22T09:00:00",
"lastUpdatedOn": "2024-03-22T09:00:00",
"customerTokens":
[
{
"customerTokenId": "878ad7c1-cd8f-4bcf-a983-1bd8c6e6975e",
"tokenType": { "tokenTypeId": 1, "name": "EMV" },
"ovPayTokenId": 1,
"serviceReferenceId": "NLOV1234567ABCDEFG",
"amount": 34,
"ovpasNumber": "OV34567",
"verificationCode": "A7H6",
"personalAccountData":
{
"personalAccountDataId": "47db8a40-3238-4bf5-9284-759e3888bd47",
"name": "Jan de Vries",
"birthdate": "1970-01-01",
"photo": "" ,
"challengeType":
{ "challengeTypeId": 1, "name": "email" },
"oneTimePassword": "H5Iiz3JTaQeIV8p",
},
},
],
"orderAccountingStatuses":
[
{
"orderAccountingStatusId": "7c5118d0-8535-4464-9239-83a7ba8fd2db",
"accountingStatus":
{ "accountingStatusId": 1, "name": "open" },
"createdOn": "2024-03-22T09:00:00",
"description": "Financiele transactie voor de FIKO.",
},
],
},
],
"payments":
[
{
"paymentId": "3ba4a3c7-0803-4214-800b-365851b8903d",
"createdOn": "2024-03-22T09:00:00",
"amountDebit": 121,
"paymentMethod":
{
"paymentMethodId": 1,
"name": "ideal",
"provider": "Buckaroo",
},
"touchPoint":{
"touchPointId": 1,
"name": "Perplex"
},
"isRefund": false,
"htmPaymentReference": "HTM-1234",
"pspPaymentReference": "Buckaroo-1234",
"paymentStatuses":
[
{
"paymentStatusId": 1,
"createdOn": "2024-03-22T09:00:00",
"statusCode": "190",
"statusDescription": "Success",
"statusSubCode": "S001",
"statusSubDescription": "PaymentSuccessFul",
},
],
"mandateInput":
{
"mandateInputId": "0a875e67-dc9f-4825-a030-d732a2adbfbc",
"directDebitMandateType":
{
"directDebitMandateTypeId": 1,
"name": "import",
},
"createdOn": "2024-03-22T09:00:00",
"bic": "RABONL2U",
"iban": "NL44RABO0123456789",
"ascription": "J. de Vries",
"place": "Den Haag",
},
},
],
"orderCustomer":
{
"orderCustomerId": "19ef6882-8eda-43bf-b48e-9b4ff8745a50",
"birthname": "Jan",
"surname": "Vries",
"prefix": "de",
"emailAddress": "jandevries@outlook.com",
"dateOfBirth": "1970-01-01",
"orderCustomerAddresses":
[
{
"orderCustomerAddressId": "aa50047c-58ac-4f15-9448-ee000dfc6893",
"addressType":
{ "addressTypeId": 3, "name": "Billing" },
"street": "Kon. Julianaplein",
"houseNumber": 10,
"houseNumberSuffix": "a",
"postalCode": "2595 AA",
"city": "Den Haag",
"country": "NL",
},
],
},
}
patch:
summary: Update an order.
description: Update an order.
tags:
- Order
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"customerProfileId": 1337,
"totalAmount": 121,
"languageId": 1,
"lastUpdatedOn": "2024-03-22T09:00:00",
}
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example: { "orderId": "afce35b2-1dff-4ace-98d0-4b9ac405c87d" }
delete:
summary: RFU. Delete an order.
description: Delete an order.
tags:
- Order
responses:
"200":
description: OK
/orders/{orderId}/statuses:
parameters:
- in: path
name: orderId
schema:
type: string
format: uuid
example: d1dd439b-6072-4b97-89c9-724268865b93
required: true
description: The id of the order to process.
post:
summary: Add an order status.
description: Add an order status.
tags:
- Order
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"orderStatusId": 1,
"createdOn": "2024-03-22T09:00:00",
"description": "Order verzonden",
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"order_orderStatusId": "b9cf0096-4211-4be6-ac21-7bc34bc8e066",
}
/orders/{orderId}/orderlines:
parameters:
- in: path
name: orderId
schema:
type: string
format: uuid
example: d1dd439b-6072-4b97-89c9-724268865b93
required: true
description: The id of the order to process.
post:
summary: Add a single order line to an order.
description: Add a single order line to an order.
tags:
- Order Line
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
examples:
Minimum orderline requestBody:
value:
{
"productId": 1,
"productName": "HTM Maandkorting 20%",
"productDescription": "HTM Maandkorting 20%",
"quantity": 0,
"orderLineTerms":
[{ "termsUrl": "generalTermsAndConditions.pdf" }],
"orderLineStatusId": 1,
"createdOn": "2024-03-22T09:00:00"
}
Maximum orderline requestBody:
value:
{
"externalOrderLineId": "f5fddff0-7fbd-4285-bccb-e584f431ea69",
"productId": 1,
"productName": "HTM Maandkorting 20%",
"fikoArticleNumber": "FIKO-1234",
"productDescription": "HTM Maandkorting 20%",
"taxAmount": 21,
"taxCode": "V21",
"taxPercentage": 21,
"amountExclTax": 100,
"amountInclTax": 121,
"quantity": 1,
"orderLineTerms":
[{ "termsUrl": "generalTermsAndConditions.pdf" }],
"validFrom": "2024-03-22T09:00:00",
"validUntil": "2025-03-22T09:00:00",
"orderLineStatusId": 4,
"createdOn": "2024-03-22T09:00:00",
"customerTokens":
[
{
"tokenTypeId": 1,
"ovPayTokenId": 1,
"serviceReferenceId": "NLOV1234567ABCDEFG",
"amount": 34,
"ovpasNumber": "OV34567",
"verificationCode": "A7H6",
"personalAccountData":
{
"birthdate": "1970-01-01"
},
},
],
"orderAccountingStatuses":
[
{
"accountingStatusId": 1,
"createdOn": "2024-03-22T09:00:00",
"description": "Financiele transactie voor de FIKO.",
},
],
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example: { "orderLineId": "1e441d7d-50d6-4006-aca7-5e87e2f218df" }
/orders/{orderId}/payments:
parameters:
- in: path
name: orderId
schema:
type: string
format: uuid
example: d1dd439b-6072-4b97-89c9-724268865b93
required: true
description: The id of the order to process.
post:
summary: Add a payment to an order.
description: Add a payment to an order.
tags:
- Payment
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
Minimum orderline requestBody:
value:
{
"createdOn": "2024-03-22T09:00:00",
"amountDebit": 121,
"paymentMethodId": 1,
"touchPointId": 1,
"isRefund": false,
"htmPaymentReference": "HTM-1234"
}
Maximum orderline requestBody:
value:
{
"createdOn": "2024-03-22T09:00:00",
"amountDebit": 121,
"paymentMethodId": 1,
"touchPointId": 1,
"isRefund": false,
"htmPaymentReference": "HTM-1234",
"pspPaymentReference": "Buckaroo-1234",
"paymentStatuses":
[
{
"createdOn": "2024-03-22T09:00:00",
"statusCode": "190",
"statusDescription": "Success",
"statusSubCode": "S001",
"statusSubDescription": "PaymentSuccessFul",
},
],
"mandateInput":
{
"directDebitMandateTypeId": 1,
"createdOn": "2024-03-22T09:00:00",
"bic": "RABONL2U",
"iban": "NL44RABO0123456789",
"ascription": "J. de Vries",
"place": "Den Haag",
},
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example: { "paymentId": "dfae0f6f-95f0-4eac-ab1a-36ffe1f31aac" }
/orders/{orderId}/ordercustomers:
parameters:
- in: path
name: orderId
schema:
type: string
format: uuid
example: d1dd439b-6072-4b97-89c9-724268865b93
required: true
description: The id of the order to process.
post:
summary: Add a customer to an order.
description: Add a customer to an order.
tags:
- Customer
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
Minimum orderCustomer requestBody:
value:
{
"emailAddress": "jandevries@outlook.com"
}
Maximum orderCustomer requestBody:
value:
{
"birthname": "Jan",
"surname": "Vries",
"prefix": "de",
"emailAddress": "jandevries@outlook.com",
"dateOfBirth": "1970-01-01",
"orderCustomerAddresses":
[
{
"addressTypeId": 3,
"street": "Kon. Julianaplein",
"houseNumber": 10,
"houseNumberSuffix": "a",
"postalCode": "2595 AA",
"city": "Den Haag",
"country": "NL",
},
],
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{ "orderCustomerId": "9c9ae71f-7de9-49f9-b676-b0fe103f6286" }
/orderlines:
get:
summary: Find order lines.
description: Find order lines.
tags:
- Order Line
parameters:
- in: query
name: orderLineId
schema:
type: string
format: uuid
example: 4ea492ff-8ffc-4a4e-901e-59f05e854285
required: false
description: The id of the order line.
- in: query
name: externalOrderLineId
schema:
type: string
format: uuid
example: 4e333615-6ecd-4b68-a4f8-4f66f6af9be1
required: false
description: The id of the order line in the external system.
- in: query
name: productId
schema:
type: integer
example: 42
required: false
description: The technical id of the product.
- in: query
name: productName
schema:
type: string
example: HTM Maandkorting 20%
required: false
description: The name of the product.
- in: query
name: fikoArticleNumber
schema:
type: string
example: FIKO-1234
required: false
description: The code of the product.
- in: query
name: taxAmount
schema:
type: integer
example: 21
required: false
description: The amount of tax calculated.
- in: query
name: taxCode
schema:
type: string
format: uuid
example: "V21"
required: false
description: The tax code.
- in: query
name: taxPercentage
schema:
type: string
format: uuid
example: 21
required: false
description: The tax percentage.
- in: query
name: amountExclTax
schema:
type: integer
example: 100
required: false
description: The amount of the order line before taxes.
- in: query
name: amountInclTax
schema:
type: integer
example: 121
required: false
description: The amount of the order line after taxes.
- in: query
name: quantity
schema:
type: integer
example: 1
required: false
description: The quantity of products for this order line.
- in: query
name: termsUrl
schema:
type: string
example: generalTermsAndConditions.pdf
required: false
description: The terms of conditions that apply on this order line.
- in: query
name: validFrom
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp from which the ordered product is valid.
- in: query
name: validUntil
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp from which the ordered product is valid.
- in: query
name: orderLineStatusId
schema:
type: array
items:
type: integer
explode: false
required: false
description: Filter on possible order line statuses. 1 = pending, 3 = delivered, 4 = cancelled, 5 = refunded, 7 = shipped.
- in: query
name: createdBefore
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp before which the order line should have been created.
- in: query
name: createdAfter
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp after which the order line should have been created.
- in: query
name: updatedBefore
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp before which the order line should have been updated.
- in: query
name: updatedAfter
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp after which the order line should have been updated.
- in: query
name: accountingStatusId
schema:
type: array
items:
type: integer
explode: false
required: false
description: Filter on current account statuses. 1 = open, 2 = sent, 3 = received, 4 = rejected.
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
[
{
"orderLineId": "7a7a9d1a-3fc8-4058-a28b-082860aaa311",
"orderId": "7ec1c3ae-0112-4aaf-adb9-c2436234fec6",
"externalOrderLineId": "4e333615-6ecd-4b68-a4f8-4f66f6af9be1",
"productId": 1,
"productName": "HTM Maandkorting 20%",
"fikoArticleNumber": "FIKO-1234",
"productDescription": "HTM Maandkorting 20%",
"taxAmount": 21,
"taxCode": "V21",
"taxPercentage": 21,
"amountExclTax": 100,
"amountInclTax": 121,
"quantity": 1,
"orderLineTerms":
[
{
"orderLineTermsId": "fe354db7-12ad-4fc1-bc63-a704c4e0d91e",
"termsUrl": "generalTermsAndConditions.pdf",
},
],
"validFrom": "2024-03-22T09:00:00",
"validUntil": "2025-03-22T09:00:00",
"orderLineStatus":
{ "orderLineStatusId": 4, "name": "delivered" },
"createdOn": "2024-03-22T09:00:00",
"lastUpdatedOn": "2024-03-22T09:00:00",
"customerTokens":
[
{
"customerTokenId": "878ad7c1-cd8f-4bcf-a983-1bd8c6e6975e",
"tokenType": { "tokenTypeId": 1, "name": "EMV" },
"ovPayTokenId": 1,
"serviceReferenceId": "NLOV1234567ABCDEFG",
"amount": 34,
"ovpasNumber": "OV34567",
"verificationCode": "A7H6",
"personalAccountData":
{
"personalAccountDataId": "47db8a40-3238-4bf5-9284-759e3888bd47",
"name": "Jan de Vries",
"birthdate": "1970-01-01",
"photo": "" ,
"challengeType":
{ "challengeTypeId": 1, "name": "email" },
"oneTimePassword": "H5Iiz3JTaQeIV8p",
},
},
],
"orderAccountingStatuses":
[
{
"orderAccountingStatusId": "7c5118d0-8535-4464-9239-83a7ba8fd2db",
"accountingStatus":
{ "accountingStatusId": 1, "name": "open" },
"createdOn": "2024-03-22T09:00:00",
"description": "Financiele transactie voor de FIKO.",
},
],
},
]
/orderlines/{orderLineId}:
parameters:
- in: path
name: orderLineId
schema:
type: string
format: uuid
example: 39d37066-c59d-4807-8ae5-45c249e28d68
required: true
description: The id of the order line to process.
patch:
summary: Update an order line.
description: Update an order line. All possible fields that can be patched
tags:
- Order Line
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"productId": 212,
"productName": "HTM maandkorting",
"fikoArticleNumber": "FIKO-1234",
"productDescription": "Reis met korting in HTM voertuigen",
"taxAmount": 21,
"taxCode": "V21",
"taxPercentage": 21,
"amountExclTax": 100,
"amountInclTax": 121,
"quantity": 1,
"validFrom": "2024-03-22T09:00:00",
"validUntil": "2025-03-22T09:00:00",
"orderLineStatusId": 1,
}
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example: { "orderLineId": "ee82686a-a9f6-4888-b336-8e2aab6f4e13" }
delete:
summary: RFU. Delete an order line.
description: Delete an order line.
tags:
- Order Line
responses:
"200":
description: OK
/orderlines/{orderLineId}/accountingstatuses:
parameters:
- in: path
name: orderLineId
schema:
type: string
format: uuid
example: 9ff2e034-ed4f-44d5-8f6c-d703bd4df332
required: true
description: The id of the order line to process.
post:
summary: Add an accounting status to an order line.
description: Add an accounting status to an order line.
tags:
- Order Line
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"accountingStatusId": 1,
"createdOn": "2024-03-22T09:00:00",
"description": "Financiele transactie voor de FIKO.",
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"orderAccountingStatusId": "60dbd8a7-0a22-40b5-9c53-1bc9aaf1a1ae",
}
/orderlines/{orderLineId}/customertokens:
parameters:
- in: path
name: orderLineId
schema:
type: string
format: uuid
example: 9ff2e034-ed4f-44d5-8f6c-d703bd4df332
required: true
description: The id of the order line to process.
post:
summary: Add a customer token to an order line.
description: Add acustomer token to an order line.
tags:
- Order Line
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"tokenTypeId": 1,
"ovPayTokenId": 1,
"serviceReferenceId": "NLOV1234567ABCDEFG",
"amount": 34,
"ovpasNumber": "OV34567",
"verificationCode": "A7H6",
"personalAccountData":
{
"birthdate": "1970-01-01",
}
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{ "customerTokenId": "eeec597c-36c4-41b2-aeeb-ab5c32f2365d" }
/customertokens:
get:
summary: Find customer tokens.
description: Find customer tokens.
tags:
- Order Line
parameters:
- in: query
name: customerTokenId
schema:
type: string
format: uuid
example: 74c07b9e-5979-4fcc-b98c-4f0be456838c
required: false
description: The id of the customer token.
- in: query
name: orderLineId
schema:
type: string
format: uuid
example: 4ea492ff-8ffc-4a4e-901e-59f05e854285
required: false
description: The id of the order line.
- in: query
name: tokenTypeId
schema:
type: array
items:
type: integer
explode: false
required: false
description: Filter on possible token types. 1 = EMV, 2 = OV-pas physical, 3 = OV-pas digital.
- in: query
name: ovPayTokenId
schema:
type: integer
example: 42
required: false
description: The id of the OVpay token.
- in: query
name: serviceReferenceId
schema:
type: string
example: NLOV1234567ABCDEFG
required: false
description: Service reference id of the token.
- in: query
name: amount
schema:
type: integer
example: 131
required: false
description: The amount corresponding to the SRID.
- in: query
name: ovpasNumber
schema:
type: string
example: 63AW974
required: false
description: Number of the OVpas.
- in: query
name: verificationCode
schema:
type: string
example: 8ZY2
required: false
description: Verification code corresponding to the OVpas.
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
[
{
"customerTokenId": "878ad7c1-cd8f-4bcf-a983-1bd8c6e6975e",
"orderId": "95454803-68fb-4735-a9b5-1251cdece3cd",
"orderLineId": "9b0d28a2-46ce-4e74-9cf5-497a5b91e86b",
"tokenType": { "tokenTypeId": 1, "name": "EMV" },
"ovPayTokenId": 1,
"serviceReferenceId": "NLOV1234567ABCDEFG",
"amount": 34,
"ovpasNumber": "OV34567",
"verificationCode": "A7H6",
"personalAccountData":
{
"personalAccountDataId": "47db8a40-3238-4bf5-9284-759e3888bd47",
"name": "Jan de Vries",
"birthdate": "1970-01-01",
"photo": "" ,
"challengeType":
{ "challengeTypeId": 1, "name": "email" },
"oneTimePassword": "H5Iiz3JTaQeIV8p",
},
},
]
/customertokens/{customerTokenId}:
parameters:
- in: path
name: customerTokenId
schema:
type: string
format: uuid
example: 510194ef-0038-45ef-94c7-262df93ef1d7
required: true
description: The id of the customer token.
patch:
summary: Update a customer token.
description: Update a customer token.
tags:
- Order Line
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"tokenTypeId": 1,
"ovPayTokenId": 1,
"serviceReferenceId": "NLOV1234567ABCDEFG",
"amount": 34,
"ovpasNumber": "OV34567",
"verificationCode": "A7H6",
}
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{ "customerTokenId": "0aedb483-2477-4720-aee6-7abcd016843b" }
delete:
summary: Delete a customer token.
description: Delete a customer token.
tags:
- Order Line
responses:
"200":
description: OK
/customertokens/{customerTokenId}/personalaccountdata:
parameters:
- in: path
name: customerTokenId
schema:
type: string
format: uuid
example: 510194ef-0038-45ef-94c7-262df93ef1d7
required: true
description: The id of the customer token.
post:
summary: Add personal account data to token.
description: Add personal account data to token.
tags:
- Order Line
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
examples:
birthdate PersonalAccountData:
summary: PersonalAccountData birthdate
description: Only record birthdate PersonalAccountData
value:
{
"birthdate": "1970-01-01"
}
name PersonalAccountData:
summary: PersonalAccountData name
description: Only record name PersonalAccountData
value:
{
"name": "Jan de Vries"
}
photo PersonalAccountData:
summary: PersonalAccountData photo
description: Only record photo in PersonalAccountData
value:
{
"photo": "" ,
}
full PersonalAccountData:
summary: PersonalAccountData full
description: Fill the entire record for PersonalAccountData
value:
{
"name": "Jan de Vries",
"birthdate": "1970-01-01",
"photo": "" ,
"challengeTypeId": 1,
"oneTimePassword": "H5Iiz3JTaQeIV8p",
}
existing PersonalAccountData:
summary: PersonalAccountData already exists for customerToken
description: PersonalAccountData already exists for customerToken
value:
{
"name": "Jan de Vries",
"birthdate": "1970-01-01",
"photo": "" ,
"challengeTypeId": 1,
"oneTimePassword": "H5Iiz3JTaQeIV8p",
}
responses:
"201":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{ "personalAccountDataId": "0aedb483-2477-4720-aee6-7abcd016843b" }
"405":
description: Method not allowed
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
examples:
existing PersonalAccountData:
summary: PersonalAccountData already exists for customerToken
description: PersonalAccountData already exists for customerToken
value:
{
"code": "405",
"type": "string",
"message": "Method not allowed",
"description": "PersonalAccountData resource already exists for customerToken with customerTokenId:510194ef-0038-45ef-94c7-262df93ef1d7"
}
/personalaccountdata:
get:
summary: Find personal account data.
description: Find customer tokens.
tags:
- Order Line
parameters:
- in: query
name: personalAccountDataId
schema:
type: string
format: uuid
example: 0743969c-4e4c-4123-bd45-0366f7add029
required: false
description: The id of the personal account data.
- in: query
name: customerTokenId
schema:
type: string
format: uuid
example: 9935456d-45e5-419a-91c0-5deb85119f2b
required: false
description: The id of the customer token.
- in: query
name: name
schema:
type: string
example: J. de Vries
required: false
description: The name of the customer.
- in: query
name: birthdate
schema:
type: string
format: date
example: 1970-01-01
required: false
description: "The date of birth of the customer (formatted: YYYY-MM-DD)."
- in: query
name: photo
schema:
type: string
example: 
required: false
description: A reference to the customer photo.
- in: query
name: challengeTypeId
schema:
type: array
items:
type: integer
explode: false
required: false
description: Filter on possible challenge types. 1 = email, 2 = sms.
- in: query
name: oneTimePassword
schema:
type: string
example: "H5Iiz3JTaQeIV8p"
explode: false
required: false
description: Filter on possible challenge types. 1 = email, 2 = sms.
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
[
{
"personalAccountDataId": "47db8a40-3238-4bf5-9284-759e3888bd47",
"customerTokenId": "7252ad91-3a4b-4ab4-b529-ec78a39a49b2",
"orderLineId": "858e31b9-67f0-46ca-bf88-91a382b9c079",
"orderId": "858e31b9-67f0-46ca-bf88-91a382b9c079",
"name": "Jan de Vries",
"birthdate": "1970-01-01",
"photo": "" ,
"challengeType": { "challengeTypeId": 1, "name": "email" },
"oneTimePassword": "H5Iiz3JTaQeIV8p",
},
]
/personalaccountdata/{personalAccountDataId}:
parameters:
- in: path
name: personalAccountDataId
schema:
type: string
format: uuid
example: e4e0d37d-d01e-4633-b849-87113ed207bd
required: true
description: The id of the personal account data.
patch:
summary: Update personal account data.
description: Update personal account data.
tags:
- Order Line
requestBody:
content:
application/jso"n:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"photo": "" ,
"challengeTypeId": 1,
"oneTimePassword": "H5Iiz3JTaQeIV8p",
"name": "Jan Pad",
"birthdate": "1992-04-20"
}
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"personalAccountDataId": "47041fde-7044-42e6-9ab5-091c05ce32f5",
}
delete:
summary: Delete personal account data.
description: Delete personal account data.
tags:
- Order Line
responses:
"200":
description: Ok
/orderlines/{orderLineId}/orderLineTerms:
parameters:
- in: path
name: orderLineId
schema:
type: string
format: uuid
example: 9ff2e034-ed4f-44d5-8f6c-d703bd4df332
required: true
description: The id of the order line to process.
post:
summary: Add a orderLine term to an order line.
description: Add a orderLine term to an order line.
tags:
- Order Line
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
termsUrl": "generalTermsAndConditions.pdf",
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{ "orderLineTermsId": "eeec597c-36c4-41b2-aeeb-ab5c32f2365d" }
/orderLineTerms/{orderLineTermsId}:
parameters:
- in: path
name: orderLineTermsId
schema:
type: string
format: uuid
example: 9ff2e034-ed4f-44d5-8f6c-d703bd4df332
required: true
description: The id of the order line terms to process.
patch:
summary: Update a orderLine term to an order line.
description: Update a orderLine term to an order line.
tags:
- Order Line
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"termsUrl": "generalTermsAndConditions.pdf",
}
responses:
"200":
description: Ok
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{ "orderLineTermsId": "eeec597c-36c4-41b2-aeeb-ab5c32f2365d" }
delete:
summary: Remove a orderLine term from an order line.
description: Remove a orderLine term from an order line.
tags:
- Order Line
responses:
"200":
description: OK
/payments:
get:
summary: Find payments.
description: Find payments.
tags:
- Payment
parameters:
- in: query
name: paymentId
schema:
type: string
format: uuid
example: 4ea492ff-8ffc-4a4e-901e-59f05e854285
required: false
description: The id of the payment.
- in: query
name: orderId
schema:
type: string
format: uuid
example: 292e5f86-cefc-4224-9506-d204ed3a426f
required: false
description: The id of the order where the payment belongs to.
- in: query
name: createdBefore
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp before which the payment should have been created.
- in: query
name: createdAfter
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp after which the payment should have been created.
- in: query
name: amountDebit
schema:
type: integer
example: 100
required: false
description: The amount of debit to pay.
- in: query
name: paymentMethodId
schema:
type: integer
example: 1
required: false
description: The technical id of the payment method used to pay.
- in: query
name: touchPointId
schema:
type: integer
example: 1
required: false
description: The id of the touch point where the payment was initiated.
- in: query
name: isRefund
schema:
type: boolean
example: false
required: false
description: If the payment concerns a refund or not.
- in: query
name: htmPaymentReference
schema:
type: string
example: HTM-1234
required: false
description: The payment reference on HTM side.
- in: query
name: pspPaymentReference
schema:
type: string
example: Buckaroo-1234
required: false
description: The payment reference on PSP side.
- in: query
name: paymentStatusCode
schema:
type: string
example: 190
required: false
description: The current status of the payment.
- in: query
name: paymentStatusSubCode
schema:
type: string
example: S001
required: false
description: The current substatus of the payment.
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
[
{
"paymentId": "3ba4a3c7-0803-4214-800b-365851b8903d",
"orderId": "afa89108-3e40-44ac-8bea-7c7f0f2d4006",
"createdOn": "2024-03-22T09:00:00",
"amountDebit": 121,
"paymentMethod":
{
"paymentMethodId": 1,
"name": "ideal",
"provider": "Buckaroo",
},
"touchPoint":{
"touchPointId": 1,
"name": "Perplex"
},
"isRefund": false,
"htmPaymentReference": "HTM-1234",
"pspPaymentReference": "Buckaroo-1234",
"paymentStatuses":
[
{
"paymentStatusId": 1,
"createdOn": "2024-03-22T09:00:00",
"statusCode": "190",
"statusDescription": "Success",
"statusSubCode": "S001",
"statusSubDescription": "PaymentSuccessFul",
},
],
"mandateInput":
{
"mandateInputId": "0a875e67-dc9f-4825-a030-d732a2adbfbc",
"directDebitMandateType":
{ "directDebitMandateTypeId": 1, "name": "import" },
"createdOn": "2024-03-22T09:00:00",
"bic": "RABONL2U",
"iban": "NL44RABO0123456789",
"ascription": "J. de Vries",
"place": "Den Haag",
},
},
]
/payments/{paymentId}:
parameters:
- in: path
name: paymentId
schema:
type: string
format: uuid
example: fd09f3c5-35d9-4a1b-a98b-e46addb663f2
required: true
description: The id of the payment to process.
patch:
summary: Update a payment.
description: Update a payment.
tags:
- Payment
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"htmPaymentReference": "HTM-1234",
"pspPaymentReference": "Buckaroo-1234",
}
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example: { "paymentId": "dbbc3913-414e-4528-9c95-6c11a11e04ac" }
/payments/{paymentId}/paymentstatuses:
parameters:
- in: path
name: paymentId
schema:
type: string
format: uuid
example: 4c7f67bd-175e-472b-86e8-f7b388754dce
required: true
description: The id of the payment to process.
post:
summary: Add a payment status.
description: Add a payment status.
tags:
- Payment
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
examples:
Minimum orderPaymentStatus requestBody:
value:
{
"createdOn": "2024-03-22T09:00:00",
"statusCode": "190",
"statusDescription": "Success"
}
Maximum orderPaymentStatus requestBody:
value:
{
"createdOn": "2024-03-22T09:00:00",
"statusCode": "190",
"statusDescription": "Success",
"statusSubCode": "S001",
"statusSubDescription": "PaymentSuccessFul",
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"paymentId": "f3919c07-8fa1-4ff4-a4a6-8f99106b9129",
"paymentStatusId": 2,
}
/mandateinputs:
get:
summary: Find mandate inputs.
description: Find mandate inputs.
tags:
- Payment
parameters:
- in: query
name: mandateInputId
schema:
type: string
format: uuid
example: 3448e3a7-8e66-4563-ae4f-2d3ec13ca97d
required: false
description: The id of the mandate input.
- in: query
name: paymentId
schema:
type: string
format: uuid
example: 24b6300a-1d43-4ed4-8b5f-034f6471c9cb
required: false
description: The id of the payment.
- in: query
name: directDebitMandateTypeId
schema:
type: array
items:
type: integer
explode: false
required: false
description: Filter on possible types of mandates. 1 = import, 2 = invite, 3 = paper.
- in: query
name: createdBefore
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp before which the mandate input should have been created.
- in: query
name: createdAfter
schema:
type: string
format: date-time
example: 2024-03-22T09:00:00
required: false
description: Timestamp after which the mandate input should have been created.
- in: query
name: bic
schema:
type: string
example: BUNQNL2A
required: false
description: The BIC of the mandate input.
- in: query
name: iban
schema:
type: string
example: NL15BUNQ0417164300
required: false
description: The IBAN of the mandate input.
- in: query
name: ascription
schema:
type: string
example: J. de Vries
required: false
description: The ascription of the mandate input.
- in: query
name: place
schema:
type: string
example: Den Haag
required: false
description: The place where the mandate was signed.
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
[
{
"mandateInputId": "0a875e67-dc9f-4825-a030-d732a2adbfbc",
"paymentId": "4a7ee6ec-d218-49b7-a5bf-0107945767ee",
"orderId": "afa89108-3e40-44ac-8bea-7c7f0f2d4006",
"directDebitMandateType":
{ "directDebitMandateTypeId": 1, "name": "import" },
"createdOn": "2024-03-22T09:00:00",
"bic": "RABONL2U",
"iban": "NL44RABO0123456789",
"ascription": "J. de Vries",
"place": "Den Haag",
},
]
/payments/{paymentId}/mandateinputs:
parameters:
- in: path
name: paymentId
schema:
type: string
format: uuid
example: fd09f3c5-35d9-4a1b-a98b-e46addb663f2
required: true
description: The id of the payment to process.
post:
summary: Create a mandateInput.
description: Create a mandateInput..
tags:
- Payment
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"directDebitMandateTypeId": 1,
"createdOn": "2024-03-22T09:00:00",
"bic": "RABONL2U",
"iban": "NL44RABO0123456789",
"ascription": "J. de Vries",
"place": "Den Haag",
}
responses:
"201":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example: { "mandateInputId": "dbbc3913-414e-4528-9c95-6c11a11e04ac" }
/mandateinputs/{mandateInputId}:
parameters:
- in: path
name: mandateInputId
schema:
type: string
format: uuid
example: 279dfaf5-b744-4d66-964a-d8c0a5c05809
required: true
description: The id of the mandate input to process.
delete:
summary: Delete a mandate input.
description: Delete a mandate input.
tags:
- Payment
responses:
"200":
description: Ok
/ordercustomers:
get:
summary: Find customers on an order.
description: Find customers on an order.
tags:
- Customer
parameters:
- in: query
name: orderCustomerId
schema:
type: string
format: uuid
example: 0743969c-4e4c-4123-bd45-0366f7add029
required: false
description: The id of the customer on the order.
- in: query
name: orderId
schema:
type: string
format: uuid
example: 9935456d-45e5-419a-91c0-5deb85119f2b
required: false
description: The id of order.
- in: query
name: birthname
schema:
type: string
example: Jan
required: false
description: The birth name of the customer.
- in: query
name: surname
schema:
type: string
example: Vries
required: false
description: The surname of the customer.
- in: query
name: prefix
schema:
type: string
example: de
required: false
description: The prefix of the customer.
- in: query
name: emailAddress
schema:
type: string
example: jandevries@outlook.com
required: false
description: The email address of the customer.
- in: query
name: dateOfBirth
schema:
type: string
format: date
example: 1970-01-01
required: false
description: "The date of birth of the customer (formatted: YYYY-MM-DD)."
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
[
{
"orderCustomerId": "19ef6882-8eda-43bf-b48e-9b4ff8745a50",
"orderId": "f59e4769-53a0-4156-8991-6f9119ba629f",
"birthname": "Jan",
"surname": "Vries",
"prefix": "de",
"emailAddress": "jandevries@outlook.com",
"dateOfBirth": "1970-01-01",
"orderCustomerAddresses":
[
{
"orderCustomerAddressId": "aa50047c-58ac-4f15-9448-ee000dfc6893",
"addressType":
{ "addressTypeId": 3, "name": "Billing" },
"street": "Kon. Julianaplein",
"houseNumber": 10,
"houseNumberSuffix": "a",
"postalCode": "2595 AA",
"city": "Den Haag",
"country": "NL",
},
],
},
]
/ordercustomers/{orderCustomerId}:
parameters:
- in: path
name: orderCustomerId
schema:
type: string
format: uuid
example: 4edbfe64-7858-44f0-b262-2bbb7e1af4a4
required: true
description: The id of the customer.
patch:
summary: Update a customer on an order.
description: Update a customer on an order.
tags:
- Customer
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"birthname": "Jan",
"surname": "Vries",
"prefix": "de",
"emailAddress": "jandevries@outlook.com",
"dateOfBirth": "1970-01-01",
}
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{ "orderCustomerId": "bcf2896d-1ff4-4c5a-ad57-db12fd3c94e7" }
/ordercustomers/{orderCustomerId}/ordercustomeraddresses:
parameters:
- in: path
name: orderCustomerId
schema:
type: string
format: uuid
example: d1dd439b-6072-4b97-89c9-724268865b93
required: true
description: The id of the customer on the order.
post:
summary: Add an addresses to a customer of the order.
description: Add an addresses to a customer of the order.
tags:
- Customer
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"addressTypeId": 3,
"street": "Kon. Julianaplein",
"houseNumber": 10,
"houseNumberSuffix": "a",
"postalCode": "2595 AA",
"city": "Den Haag",
"country": "NL",
}
responses:
"201":
description: Created
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"orderCustomerAddressId": "9c9ae71f-7de9-49f9-b676-b0fe103f6286",
}
/ordercustomeraddresses:
get:
summary: Find addresses of a customer on an order.
description: Find addresses of a customer on an order.
tags:
- Customer
parameters:
- in: query
name: orderCustomerAddressId
schema:
type: string
format: uuid
example: 0743969c-4e4c-4123-bd45-0366f7add029
required: false
description: The id of the addresses of a customer on the order.
- in: query
name: orderCustomerId
schema:
type: string
format: uuid
example: 9935456d-45e5-419a-91c0-5deb85119f2b
required: false
description: The id of the customer on the order.
- in: query
name: addressTypeId
schema:
type: array
items:
type: integer
explode: false
required: false
description: Filter on possible types of addresses. 1 = Shipping, 3 = Billing.
- in: query
name: street
schema:
type: string
example: Kon. Julianaplein
required: false
description: The street of the address.
- in: query
name: houseNumber
schema:
type: integer
example: 10
required: false
description: The house number of the address.
- in: query
name: houseNumberSuffix
schema:
type: string
example: A
required: false
description: The suffix of the house number.
- in: query
name: postalCode
schema:
type: string
example: 2595 AA
required: false
description: The postal code of the address.
- in: query
name: city
schema:
type: string
example: Den Haag
required: false
description: The city of the address.
- in: query
name: country
schema:
type: string
example: NL
required: false
description: The country of the address.
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
[
{
"orderCustomerAddressId": "aa50047c-58ac-4f15-9448-ee000dfc6893",
"orderCustomerId": "540d8b7a-d626-443f-8f99-c24398604d7a",
"orderId": "73cca95a-81d1-468f-a8bf-99b36367001a",
"addressType": { "addressTypeId": 3, "name": "Billing" },
"street": "Kon. Julianaplein",
"houseNumber": 10,
"houseNumberSuffix": "a",
"postalCode": "2595 AA",
"city": "Den Haag",
"country": "NL",
},
]
/ordercustomeraddresses/{orderCustomerAddressId}:
parameters:
- in: path
name: orderCustomerAddressId
schema:
type: string
format: uuid
example: 4edbfe64-7858-44f0-b262-2bbb7e1af4a4
required: true
description: The id of the customer address.
patch:
summary: Update an address of a customer on an order.
description: Update an address of a customer on an order.
tags:
- Customer
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"addressTypeId": 1,
"street": "Kon. Julianaplein",
"houseNumber": 10,
"houseNumberSuffix": "a",
"postalCode": "2595 AA",
"city": "Den Haag",
"country": "NL",
}
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example:
{
"orderCustomerAddressId": "d5005529-d4f2-4552-a5b8-477dab7836ec",
}
delete:
summary: Delete an address of a customer on an order.
description: Delete an address of a customer on an order.
tags:
- Customer
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: "#/components/schemas/unavailable"
example: {}
components:
securitySchemes:
bearerToken:
type: http
scheme: bearer
bearerFormat: JWT
schemas:
unavailable:
type: object
rfc9457:
type: object
properties:
type:
type: string
format: url
example: https://example.com/probs/out-of-credit
title:
type: string
example: You do not have enough credit.
detail:
type: string
example: Your current balance is 30, but that costs 50.
instance:
type: string
example: /account/12345/msgs/abc
balance:
type: string
example: 30
accounts:
type: array
items:
type: string
example:
- /account/12345
- /account/67890