Run an unreferenced refund
A merchant can use their POS to initiate an unreferenced refund on their payment device.
Note: To run a referenced refund, view our refund guide.
Integration steps
To run an unreferenced refund using Payroc Cloud, integrate with the following:
Step 1. Create a refund instruction.
Step 2. View the status of a refund instruction.
Step 3. View the details of the refund.
Before you begin
Bearer tokens
Use our Identity Service to generate a Bearer token to include in the header of your requests. To generate a Bearer token, complete the following steps:
- Include your API key in the x-api-key parameter in the header of a POST request.
- Send your request to https://identity.payroc.com/authorize.
Note: You need to generate a new Bearer token before the previous Bearer token expires.
Example request
If your request is successful, we return a response that contains your Bearer token, information about its scope, and when it expires.
Example response
Headers
To create the header of each POST request, you must include the following parameters:
- Content-Type: Include application/json as the value for this parameter.
- Authorization: Include your Bearer token in this parameter.
- Idempotency-Key: Include a UUID v4 to make the request idempotent.
Errors
If your request is unsuccessful, we return an error. For more information about errors, see Errors.
Step 1. Create a refund instruction
To send a refund instruction to a device, send a POST request to the Devices endpoint.
Request parameters
To create the body of your request, use the following parameters:
Request
Example request
Response fields
If your request is successful, we send the refund instruction to the device.
Note: The response returns a value of inProgress
for status and an identifier for the instruction that you can use to check the status of the instruction. To get a link to the refund, go to Step 2.
The response contains the following fields:
Response
Example response
Step 2. View the status of a refund instruction
To check for updates to the status or view the details of the refund, send a GET request to the Refund Instructions endpoint.
Before our gateway sends a response, it waits for up to 30 seconds for the status of the instruction to change. We recommend that you keep the session open until the status of the instruction changes or the request times out.
If the status of the instruction doesn’t change, send another GET request. Our gateway waits up to 30 seconds for the status of the instruction to change. Continue to send GET requests until the status changes.
Important: Wait until you receive a response from our gateway before you send another request.
Request parameters
To create the body of your request, use the following parameters:
Path parameters
Example request
Response fields
If your request is successful, we return the details of the refund instruction.
If the status of the refund instruction is inProgress
, our gateway waits up to a minute for the status to change before it returns a response.
Response
Example response
Step 3. View the details of the refund
To check whether the processor approved or declined the refund, send a GET request to the Refunds endpoint.
Request parameters
To create the body of your request, use the following parameters:
Path parameters
Example request
Response fields
If your request is successful, we return the details of the refund.
Response
Example response
Before you test your integration
To test your integration with a payment device, first complete the following tasks:
- Get the serial number of the payment device.
- Connect the payment device to the internet.
Test cases
Create a refund instruction for when the card isn’t present
Step 1. Create a refund instruction
Send a POST request to the Devices test endpoint:
https://api.uat.payroc.com/v1/devices/{serialNumber}/refund-instructions
Example request
Step 2. Retrieve the status of the refund instruction
Send a GET request to the Refund Instructions test endpoint:
https://api.uat.payroc.com/v1/refund-instructions/{refundInstructionId}
If the status of the refund instruction is inProgress
, our gateway waits up to a minute for the status to change before it returns a response. Send GET requests until the value for status changes to completed
.
Note: If the status of the refund instruction is failed
or canceled
, contact your Payroc Integration Engineer.
Example response
Step 3. Retrieve the status of the refund instruction
Send a GET request to the Refunds test endpoint:
https://api.uat.payroc.com/v1/refunds/{refundId}
Use the refundID that you received in the response from Step 2.
Example response