Pay for a Booking
A payment is an attempt to pay for the booking, which will confirm the booking for the user and enable them to get their tickets.
Path parameters
-
The ID of the booking to pay for.
Body Required
-
amount number
Amount intended to be collected by this payment. A positive decimal figure describing the amount to be collected.
-
currency string
Three-letter ISO currency code, in lowercase.
Values are
bam
,bgn
,chf
,eur
,gbp
,nok
,sek
, ortry
. source object
The payment source to take the payment from. This can be a card or a bank account. Some of these properties will be hidden on read to protect PII leaking.
POST
/bookings/{bookingId}/payment
payment
import { TrainTravelSDK } from "train-travel-sdk";
const trainTravelSDK = new TrainTravelSDK({
oAuth2: process.env["TRAINTRAVELSDK_O_AUTH2"] ?? "",
});
async function run() {
const result = await trainTravelSDK.bookings.payments.create({
bookingId: "1725ff48-ab45-4bb5-9d02-88745177dedb",
bookingPayment: {
amount: 49.99,
currency: "gbp",
source: {
name: "J. Doe",
number: "4242424242424242",
cvc: "123",
expMonth: 12,
expYear: 2025,
addressLine1: "123 Fake Street",
addressLine2: "4th Floor",
addressCity: "London",
addressCountry: "gb",
addressPostCode: "N12 9XX",
},
},
});
// Handle the result
console.log(result);
}
run();
curl \
-X POST https://try.microcks.io/rest/Train+Travel+API/1.0.0/bookings/1725ff48-ab45-4bb5-9d02-88745177dedb/payment \
-H "Authorization: Bearer $ACCESS_TOKEN" \
-H "Content-Type: application/json" \
-d '{"amount":49.99,"source":{"cvc":"123","name":"J. Doe","number":"4242424242424242","object":"card","exp_year":2025,"exp_month":12,"address_city":"London","address_line1":"123 Fake Street","address_line2":"4th Floor","address_country":"gb","address_post_code":"N12 9XX"},"currency":"gbp"}'
Request examples
Card Payment
{
"amount": 49.99,
"source": {
"cvc": "123",
"name": "J. Doe",
"number": "4242424242424242",
"object": "card",
"exp_year": 2025,
"exp_month": 12,
"address_city": "London",
"address_line1": "123 Fake Street",
"address_line2": "4th Floor",
"address_country": "gb",
"address_post_code": "N12 9XX"
},
"currency": "gbp"
}
{
"amount": 100.5,
"source": {
"name": "J. Doe",
"number": "00012345",
"object": "bank_account",
"country": "gb",
"bank_name": "Starling Bank",
"sort_code": "000123",
"account_type": "individual"
},
"currency": "gbp"
}
Response examples (200)
Card Payment
{
"id": "2e3b4f5a-6b7c-8d9e-0f1a-2b3c4d5e6f7a",
"links": {
"booking": "https://api.example.com/bookings/1725ff48-ab45-4bb5-9d02-88745177dedb/payment"
},
"amount": 49.99,
"source": {
"cvc": "123",
"name": "J. Doe",
"number": "************4242",
"object": "card",
"exp_year": 2025,
"exp_month": 12,
"address_country": "gb",
"address_post_code": "N12 9XX"
},
"status": "succeeded",
"currency": "gbp"
}
{
"id": "2e3b4f5a-6b7c-8d9e-0f1a-2b3c4d5e6f7a",
"links": {
"booking": "https://api.example.com/bookings/1725ff48-ab45-4bb5-9d02-88745177dedb"
},
"amount": 100.5,
"source": {
"name": "J. Doe",
"number": "*********2345",
"object": "bank_account",
"country": "gb",
"bank_name": "Starling Bank",
"sort_code": "000123",
"account_type": "individual"
},
"status": "succeeded",
"currency": "gbp"
}
Response examples (400)
{
"type": "https://example.com/errors/bad-request",
"title": "Bad Request",
"detail": "The request is invalid or missing required parameters.",
"status": 400
}
Response examples (400)
<?xml version="1.0" encoding="UTF-8"?>
<root>
<type>https://example.com/errors/bad-request</type>
<title>Bad Request</title>
<detail>The request is invalid or missing required parameters.</detail>
<status type="integer">400</status>
</root>
Response examples (401)
{
"type": "https://example.com/errors/unauthorized",
"title": "Unauthorized",
"detail": "You do not have the necessary permissions.",
"status": 401
}
Response examples (401)
<?xml version="1.0" encoding="UTF-8"?>
<root>
<type>https://example.com/errors/unauthorized</type>
<title>Unauthorized</title>
<detail>You do not have the necessary permissions.</detail>
<status type="integer">401</status>
</root>
Response examples (403)
{
"type": "https://example.com/errors/forbidden",
"title": "Forbidden",
"detail": "Access is forbidden with the provided credentials.",
"status": 403
}
Response examples (403)
<?xml version="1.0" encoding="UTF-8"?>
<root>
<type>https://example.com/errors/forbidden</type>
<title>Forbidden</title>
<detail>Access is forbidden with the provided credentials.</detail>
<status type="integer">403</status>
</root>
Response examples (429)
{
"type": "https://example.com/errors/too-many-requests",
"title": "Too Many Requests",
"detail": "You have exceeded the rate limit.",
"status": 429
}
Response examples (429)
<?xml version="1.0" encoding="UTF-8"?>
<root>
<type>https://example.com/errors/too-many-requests</type>
<title>Too Many Requests</title>
<detail>You have exceeded the rate limit.</detail>
<status type="integer">429</status>
</root>
Response examples (500)
{
"type": "https://example.com/errors/internal-server-error",
"title": "Internal Server Error",
"detail": "An unexpected error occurred.",
"status": 500
}
Response examples (500)
<?xml version="1.0" encoding="UTF-8"?>
<root>
<type>https://example.com/errors/internal-server-error</type>
<title>Internal Server Error</title>
<detail>An unexpected error occurred.</detail>
<status type="integer">500</status>
</root>