Cancel a pending payment request
POST /v2/rtp/{id}/cancel
Cancels a Request to Pay (RTP) that is still in Pending status. The request cannot be cancelled if it has already been Accepted, Rejected, or Expired.
Request
HTTP Method: POST
Endpoint:
/v2/rtp/{id}/cancelHeaders
Authorization: Bearer {access_token}
Content-Type: application/jsonPath Parameters
rtpId
string (GUID)
Yes
RTP unique identifier (rtpId).
Request Body Parameters
reason
string (500)
Yes
Reason for initiating the cancellation.
Example Request
POST /v2/rtp/123e4567-e89b-12d3-a456-426614174000/cancel HTTP/1.1
Host: api.maibmerchants.md
Authorization: Bearer {access_token}
Content-Type: application/json
{
"reason": "Customer requested cancellation"
}(curl)
curl -X POST "https://api.maibmerchants.md/v2/rtp/123e4567-e89b-12d3-a456-426614174000/cancel" \
-H "Authorization: Bearer {{access_token}}" \
-H "Content-Type: application/json" \
-d '{"reason":"Customer requested cancellation"}'Response
Response Parameters
result
object
Response result object.
result.rtpId
string (GUID)
RTP unique identifier.
result.status
string (enum)
RTP status. Possible value: Cancelled.
ok
boolean
Request processing status (true on success).
errors
array
Present only if ok = false.
errors.errorCode
string
Error code.
errors.errorMessage
string
Error description.
Example Successful Response
{
"result": {
"rtpId": "123e4567-e89b-12d3-a456-426614174000",
"status": "Cancelled"
},
"ok": true
}Notes & Best Practices
Cancellation is only allowed while the RTP is Pending.
After cancellation, the RTP cannot be paid; create a new RTP if payment is still required.
Log both
rtpIdandreasonfor auditability and support workflows.Repeating the same cancellation call is safe; the RTP remains
Cancelled(idempotent behavior on the server side).
Last updated