Public keys
A public key is a cipher that allows you to verify if the source of the callback notification is valid and from a secure J.P. Morgan system.
How it works
- When you subscribe to a notification by performing a
POST
call to the/subscriptions
endpoint, a public key is sent back in the response. - The pairing private key is stored at J.P. Morgan.
- Every time a notification event occurs and a callback notification is sent to you, it is digitally signed with the private key.
- You can verify the authenticity of the callback notification using the public key that was sent to you.
The following is an example of how the public key would look in the response when you subscribe to a notification.
HTTP method: POST
Endpoint: /subscriptions
Scenario: Subscribing to a notification and receiving the public key as well in the response.
Json
{
"notifications": {
"tokenLifecycleNotification": [
"All"
],
"recurringProgramNotification": [
"PlanUpdated",
"ConsumerCommunicationUpdated",
"PaymentApplied",
"PaymentNotApplied",
"ProgramUpdated"
]
},
"securityPreferences": {
"webhookAuthorizationType": "token",
"tokenEndpointAuthorizationType": "private_key_jwt",
"mTLSEnabled": true,
"authorizationDetails": {
"clientId": "3e28334a-1b7d-480a-a35d-12345",
"tokenEndpoint": "https://api-idp-server.com/merchant/v1/getToken"
},
"headerFields": {
"Authorization": "Basic Y1Q1M0pEaEdKNGdCNWpsWnRPQVN6eWowaEd6QQ==",
"Api-Key": "12345678"
},
"signingAlgorithm": "RSA"
},
"subscriptionChannels": [
"WEBHOOK"
],
"callBackUrl": "https://merchant.notification.com"
}
Response:
Json
{
"notifications": {
"tokenLifecycleNotification": [
"All"
],
"recurringProgramNotification": [
"PlanUpdated",
"ConsumerCommunicationUpdated",
"PaymentApplied",
"PaymentNotApplied",
"ProgramUpdated"
]
},
"subscriptionId": "f07e8898-2819-44eb-989f-e04607766c10",
"subscriptionCreatedTimestamp": "2024-01-09T10:05:42.522Z",
"subscriptionUpdatedTimestamp": "2024-01-09T10:05:42.522Z",
"callbackURL": "https://merchant.notification.com",
"responseStatus": "SUCCESS",
"responseCode": "ACCEPTED",
"responseMessage": "Request Accepted",
"publicKey": {
"publicKeyIdentifier": "213db467b83c4db2a69da08705eff25a",
"publicKeyText": "MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEvsoc/9/GmHzXSw7JBpGc7zJx5TYRJXmQxG2Dnx2BZ+ELQEliL6oCOUpAxx+TW61BmVdCabh+i43biOPicgXY/A==",
"publicKeyExpirationDate": "2024-10-31T13:10:30.481Z"
},
"subscriptionChannels": [
"WEBHOOK"
]
}
Retrieve the public key
You can also retrieve the public key by performing a GET
call to the /publicKeys
endpoint.
HTTP method: GET
Endpoint: /publicKeys
Scenario: Retrieving a public key
Json
{
"publicKeyIdentifier": "213db467b83c4db2a69da08705eff25a",
"publicKeyText": "MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEvsoc/9/GmHzXSw7JBpGc7zJx5TYRJXmQxG2Dnx2BZ+ELQEliL6oCOUpAxx+TW61BmVdCabh+i43biOPicgXY/A==",
"publicKeyExpirationDate": "2024-10-31T13:10:30.481Z"
}