In the JSON payload you send to Real-Time Loon for updates, you must encrypt sensitive account details as a JWE token. To do so, you’ll use a RequestEncryptionKey to encrypt account details in an accountEncrypted
section of your request to Real-Time Loon. Note that this must happen before calculating the authentication header.
The response Pagos returns will similarly be encrypted as a JWE token; you’ll decrypt the response using your ResponseDecryptionKey.
Encryption Algorithm
Use the algorithm A256GCMKW to encrypt your payload. This is a key-wrapped, symmetric encryption, supported by most common jose-jwt libraries. Your request JWE header should include your KeyId, otherwise known as a kid.
Encryption Keys
When onboarding with Real-Time Loon, reach out to Pagos during your implementation to request your encryption keys. You’ll be issued two encryption keys—RequestEncryptionKey and ResponseDecryptionKey—and the accompanying Key Id (KID) with the following details:
- Key size: 256 bit
- Algorithm: A256GCMKW
- Encryption: A256GCM
Your keys will follow the format of these examples:
Key Type | KeyAsBase64 | Key Id (KID) |
---|---|---|
RequestEncryptionKey | YWJjZGVmMTIzNDU2Nzg5YWJjZGVmMTIzNDU2Nzg5MQo= | merchant-1-uuid-pagos-bound |
ResponseDecryptionKey | QWJjRGVmMTIwNDU2Nzg5QWJjRGVmLTEyNDU2NzgwMAo= | merchant-1-uuid-merchant-bound |
Request Encryption Example
You want to send the following example payload for updates:
{
"network": "visa",
"requestId": "d61c0dd7-7bd8-48d7-9bb2-6c46681fea09",
"account": {
"accountNumber": "4111111111111111",
"expiryYear": "2023",
"expiryMonth": "12",
"metadata": "51032475-bc83-46d8-8768-15e129f3c6e0"
},
"subMerchantId": null
}
To do so, you start by encrypting the account
object with your RequestEncryptionKey. Use the JWE token produced from the encryption process as the value for the accountEncrypted
key in the payload you will send to Pagos.
Your HTTP client will then send the following encrypted payload to Pagos for updates:
{
"network": "visa",
"requestId": "d61c0dd7-7bd8-48d7-9bb2-6c46681fea09",
"subMerchantId": null,
"accountEncrypted": "eyJ...-Q"
}
Response Decryption Example
When receiving a response from Real-Time Loon, decrypt the accountEncrypted
section with your ResponseDecryptionKey.
You receive the following example response from Real-Time Loon:
{
"accountEncrypted": "eyJ...qg",
"requestId": "d61c0dd7-7bd8-48d7-9bb2-6c46681fea09"
}
You will then decrypt the JWE token in the value of the accountEncrypted
key. Your response will now be decrypted into the following account object:
{
"requestId": "d61c0dd7-7bd8-48d7-9bb2-6c46681fea09",
"account": {
"accountNumber": "4111111111111111",
"expiryYear": "2023",
"expiryMonth": "12",
"newAccountNumber": "4166676667666746",
"newExpiryYear": null,
"newExpiryMonth": null,
"responseCode": "LAE",
"errorCode": null,
"metadata": "51032475-bc83-46d8-8768-15e129f3c6e0"
}
}
Resulting in the full decrypted response message:
{
"code": 200,
"requestId": "d61c0dd7-7bd8-48d7-9bb2-6c46681fea09",
"account": {
"accountNumber": "4111111111111111",
"expiryYear": "2023",
"expiryMonth": "12",
"newAccountNumber": "4166676667666746",
"newExpiryYear": null,
"newExpiryMonth": null,
"responseCode": "LAE",
"errorCode": null,
"metadata": "51032475-bc83-46d8-8768-15e129f3c6e0"
}
}
}