{"info":{"_postman_id":"afe9e8cb-7768-4d3d-b430-aa2be2080b1f","name":"Paysecure API Documentation - Live","description":"<html><head></head><body><h1 id=\"overview\">Overview</h1>\n<hr>\n<p>Paysecure is a payment gateway optimization and intelligence service that merchants can use to provide a remote and frictionless payment experience.</p>\n<p>This documentation will help you get started with integrating Paysecure but if you have any questions, please do not hesitate to reach out to us via email at <a href=\"https://\">info@paysecure.net</a></p>\n<p>Please be advised that our support team is only available during standard business hours.</p>\n<h1 id=\"environments\">Environments</h1>\n<hr>\n<p>These are the BaseUrls for the APIs on different environments:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Environment</strong></th>\n<th><strong>Base URL</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Production</td>\n<td><a href=\"https://\">https://api.paysecure.net/api/v1</a></td>\n</tr>\n<tr>\n<td>Sandbox</td>\n<td><a href=\"https://\">https://api.paysecure.net/api/v1</a>  <br><code>Note: set the Sandbox flag true (checked) in your merchant account. As shown in the image below</code></td>\n</tr>\n</tbody>\n</table>\n</div><h1 id=\"authentication\">Authentication</h1>\n<hr>\n<p>To access the API, you must acquire your unique API key from the merchant dashboard -&gt; API Keys section in your account. Make sure to use this key as a <strong>bearer token</strong> in the Authorization header for every request you send.</p>\n<p><code>AUTHORIZATION: Bearer Token</code></p>\n<p><code>Token: {{APIKey}} .</code></p>\n<p>Access your sandbox API key credentials by navigating to your merchant login and checking the 'is sandbox' option, located in the top right corner under merchant profile.</p>\n<img src=\"https://content.pstmn.io/dfe64a66-8699-45c8-9f10-b00f7df380b7/U2NyZWVuc2hvdCAyMDIzLTA5LTE1IGF0IDE2LjU2LjQyLnBuZw==\">\n\n<p>To get to the live API key, uncheck the <strong>'Is Sandbox'</strong> option in the top right corner of your merchant dashboard. After unchecking, the page will refresh, and you can generate an API key for live transactions in this environment.\"</p>\n<img src=\"https://content.pstmn.io/afa2574d-8438-4a63-9b29-81feb0f755e5/U2NyZWVuc2hvdCAyMDIzLTA5LTE1IGF0IDE3LjE0LjI4LnBuZw==\">\n\n<p>Reiterating, the API keys in Sandbox mode are for testing (when 'is sandbox' is CHECKED in the top right corner under merchant profile). The live API key credentials are for processing actual card transactions in Live mode (when 'is sandbox' is UNCHECKED in the same location)</p>\n<h1 id=\"request-headers\">Request Headers</h1>\n<hr>\n<p>Use these headers on every API call unless noted.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Header</th>\n<th>Value</th>\n<th>Required</th>\n<th>Notes</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><code>Content-Type</code></td>\n<td><code>application/json</code></td>\n<td>Yes</td>\n<td>All endpoints. Send JSON payloads.</td>\n</tr>\n<tr>\n<td><code>Authorization</code></td>\n<td><code>Bearer {MERCHANT_API_KEY}</code></td>\n<td>Yes</td>\n<td>All endpoints.  <br>Replace with your merchant API key.</td>\n</tr>\n<tr>\n<td><code>BrandId</code></td>\n<td><code>{YOUR_BRAND_ID}</code></td>\n<td>Conditional</td>\n<td><strong>Session</strong> and <strong>Customer</strong>APIs.  <br>optional in customer APIs but Mandatory in Session APIs</td>\n</tr>\n</tbody>\n</table>\n</div></body></html>","schema":"https://schema.getpostman.com/json/collection/v2.0.0/collection.json","toc":[{"content":"Overview","slug":"overview"},{"content":"Environments","slug":"environments"},{"content":"Authentication","slug":"authentication"},{"content":"Request Headers","slug":"request-headers"}],"owner":"28741908","collectionId":"afe9e8cb-7768-4d3d-b430-aa2be2080b1f","publishedId":"2s946o4pFx","public":true,"customColor":{"top-bar":"FFFFFF","right-sidebar":"303030","highlight":"5d26c9"},"publishDate":"2025-05-06T10:36:05.000Z"},"item":[{"name":"⚙️ Integration Steps","item":[],"id":"59eff974-f700-40fb-b5c0-e7618ebb7d13","description":"<p>To start integrating you should already have your Merchant access to our admin portal and sandbox credentials which you will need to complete the integration.</p>\n<h1 id=\"1-setup--check-merchant-details\">1. Setup &amp; check merchant details</h1>\n<p>The first step in getting your integration ready is to check whether all the details about you as a merchant are correct on our Merchant portal. If you detect anomalies, then please contact your Account Manager.</p>\n<p>Start with sandbox mode (see top right-hand corner on your merchant portal to toggle between modes) and generate API Key, Brand ID and Public Key and also set up the callback URLs for subscribing to webhooks.</p>\n<ol>\n<li><p><strong>API Key</strong> - necessary to send transactions via API</p>\n</li>\n<li><p><strong>Brand ID</strong> - needed to send transaction. Use different brand IDs for different shops or brands.</p>\n</li>\n<li><p><strong>Public Key -</strong> needed to signature verification received in headers of the webhook</p>\n</li>\n<li><p><strong>Webhook</strong> - recommended to get notifications from our server to your server to inform you of transaction status changes and notifications about transactions. You can check all the details of how our webhooks work on the Webhooks page.</p>\n</li>\n</ol>\n<h1 id=\"2-test-the-integration-in-sandbox-mode\">2. Test the integration in Sandbox Mode</h1>\n<p>After finishing your integration, make sure your code is working as intended and test the purchase flow in the staging environment.</p>\n<h3 id=\"testing-credentials-only-on-sandbox-mode\">Testing Credentials (only on Sandbox mode)</h3>\n<p>You have the opportunity to test the APIs by performing test purchases using the below test cards. We have introduced new test cards from 18th December 2025 onwards, which will have more exhaustive error messages helping you test different types of card transactions.</p>\n<p>The cards mentioned above will stop working and the below mentioned cards will be used:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>card_type</strong></th>\n<th><strong>Card Numbers</strong></th>\n<th>auth_type</th>\n<th>Behaviour</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Master</td>\n<td>5141922635866282</td>\n<td>3D Secure</td>\n<td>Authentication Successful</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5169811636324572</td>\n<td>3D Secure</td>\n<td>Authentication Failed</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5143312606271514</td>\n<td>2D Secure</td>\n<td>Insufficient funds</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5199805409482512</td>\n<td>2D Secure</td>\n<td>Pending execution</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5146669487735546</td>\n<td>2D Secure</td>\n<td>Incorrect card expiry</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5151735930865446</td>\n<td>3D Secure</td>\n<td>Incorrect cvv</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5185151885032695</td>\n<td>3D Secure</td>\n<td>Processor timeout</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5149446104369687</td>\n<td>2D Secure</td>\n<td>Refund failed</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5127160683722580</td>\n<td>3D Secure</td>\n<td>Transaction expired</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5159971600530380</td>\n<td>3D Secure</td>\n<td>Risk check failed</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5198134892284199</td>\n<td>2D Secure</td>\n<td>Issuer decline</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5116213113429327</td>\n<td>2D Secure</td>\n<td>Authentication successful</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5112857124909935</td>\n<td>2D Secure</td>\n<td>Authentication failed</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5156216152193051</td>\n<td>3D Secure</td>\n<td>Insufficient funds</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5170361568993009</td>\n<td>3D Secure</td>\n<td>Pending execution</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5559161923541480</td>\n<td>3D Secure</td>\n<td>Incorrect card expiry</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5110339832985475</td>\n<td>2D Secure</td>\n<td>Incorrect cvv</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5136528486494418</td>\n<td>2D Secure</td>\n<td>Processor timeout</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5162164630471008</td>\n<td>3D Secure</td>\n<td>Refund failed</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5140378358642890</td>\n<td>2D Secure</td>\n<td>Transaction expired</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5192488343990234</td>\n<td>2D Secure</td>\n<td>Risk check failed</td>\n</tr>\n<tr>\n<td>Master</td>\n<td>5115438560834809</td>\n<td>3D Secure</td>\n<td>Issuer decline</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4079722589318630</td>\n<td>2D Secure</td>\n<td>Authentication successful</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4878397953290146</td>\n<td>3D Secure</td>\n<td>Authentication successful</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4125485445527190</td>\n<td>2D Secure</td>\n<td>Authentication failed</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4984823599573265</td>\n<td>3D Secure</td>\n<td>Insufficient funds</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4710793097358785</td>\n<td>2D Secure</td>\n<td>Pending execution</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4500682811540204</td>\n<td>3D Secure</td>\n<td>Incorrect card expiry</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4935648707390280</td>\n<td>2D Secure</td>\n<td>Incorrect cvv</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4241214813524459</td>\n<td>3D Secure</td>\n<td>Refund failed</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4342346318195134</td>\n<td>3D Secure</td>\n<td>Risk check failed</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4618889598319798</td>\n<td>3D Secure</td>\n<td>Issuer decline</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4195258724913240</td>\n<td>3D Secure</td>\n<td>Authentication failed</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4662922293431520</td>\n<td>2D Secure</td>\n<td>Insufficient funds</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4994455060632359</td>\n<td>3D Secure</td>\n<td>Pending execution</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4460652052832634</td>\n<td>2D Secure</td>\n<td>Incorrect card expiry</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4383025225665997</td>\n<td>3D Secure</td>\n<td>Incorrect cvv</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4568730114361775</td>\n<td>2D Secure</td>\n<td>Processor timeout</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4163340122068617</td>\n<td>3D Secure</td>\n<td>Processor timeout</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4405935956954713</td>\n<td>2D Secure</td>\n<td>Refund failed</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4945208335596614</td>\n<td>2D Secure</td>\n<td>Transaction expired</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4566329901944380</td>\n<td>3D Secure</td>\n<td>Transaction expired</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4588381711517694</td>\n<td>2D Secure</td>\n<td>Risk check failed</td>\n</tr>\n<tr>\n<td>VISA</td>\n<td>4401279985739470</td>\n<td>2D Secure</td>\n<td>Issuer decline</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong><br />You can enter any expiry month and year which is larger or equal to the current month/year.<br />You can enter any cvv.<br />OTP will only be 123456 for 3ds cases.</p>\n<p>Currently, only card payment testing is supported in the sandbox environment. Testing Alternative Payment Methods (APMs) is not available in the sandbox at this time.</p>\n<h1 id=\"3-create-and-test-credentials-on-the-live-mode\">3. Create and test credentials on the Live Mode</h1>\n<p>After finishing your integration in sandbox mode, set up your production environment by turning off the sandbox mode from merchant dashboard and following the same steps mentioned in step one. Test the integration using small amounts to ensure everything is working.</p>\n<h1 id=\"4-go-live\">4. Go live!</h1>\n<p>Inform your Account Manager when the setup is done to get started with processing live traffic.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"b0fee6a4-c980-4c8e-982b-f7d878761e73","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"5c58d67b-e29d-4fd9-8ebb-adbdbbbf7c05","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"59eff974-f700-40fb-b5c0-e7618ebb7d13"},{"name":"🔌 Webhooks","item":[{"name":"PayIn","item":[],"id":"8fef98f2-b1cd-4a19-88e8-34e6b5439a9d","description":"<h2 id=\"overview\"><strong>Overview</strong></h2>\n<p>When a transaction status changes to a terminal state (e.g., paid, refunded, expired), our payment gateway sends a server-to-server POST callback to the merchant's configured Webhook URL.</p>\n<p>The callback includes full transaction details so the merchant can update order status in real time.</p>\n<h3 id=\"webhook-events-for-payins\"><strong>Webhook Events for Payins</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Event type</strong></th>\n<th><strong>Status</strong></th>\n<th><strong>When is the event triggered</strong></th>\n<th><strong>Is this a terminal event?</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><strong>purchase created</strong></td>\n<td><code>created</code></td>\n<td>Triggered when a new purchase request is initialized and recorded in the system.</td>\n<td>❌ No</td>\n</tr>\n<tr>\n<td><strong>payment in process</strong></td>\n<td><code>payment_in_process</code></td>\n<td>Triggered when the payment is initiated and awaiting confirmation from the PSP/bank.</td>\n<td>❌ No</td>\n</tr>\n<tr>\n<td><strong>purchase overdue</strong></td>\n<td><code>overdue</code></td>\n<td>Triggered when a purchase remains in the CREATED state and the configured <em>Transaction Overdue Hours</em> (from Admin Settings) have elapsed, the system automatically updates the purchase status to OVERDUE</td>\n<td>❌ No (may lead to failed/expired/paid later)</td>\n</tr>\n<tr>\n<td><strong>purchase paid</strong></td>\n<td><code>paid</code></td>\n<td>Triggered when the payment is successfully completed and confirmed.</td>\n<td>✅ Yes</td>\n</tr>\n<tr>\n<td><strong>purchase failed</strong></td>\n<td><code>error</code></td>\n<td>Triggered when the payment attempt fails due to technical error, insufficient funds, or rejection by PSP/bank.</td>\n<td>✅ Yes</td>\n</tr>\n<tr>\n<td><strong>purchase cancelled</strong></td>\n<td><code>cancelled</code></td>\n<td>Triggered when the customer or system cancels the purchase before completion.</td>\n<td>✅ Yes</td>\n</tr>\n<tr>\n<td><strong>purchase expired</strong></td>\n<td><code>expired</code></td>\n<td>Triggered when the purchase is not paid within the allowed expiry time.</td>\n<td>✅ Yes</td>\n</tr>\n<tr>\n<td><strong>refund in process</strong></td>\n<td><code>refund_in_process</code></td>\n<td>Triggered when a refund has been initiated but is not yet completed/settled.</td>\n<td>❌ No</td>\n</tr>\n<tr>\n<td><strong>payment refund</strong></td>\n<td><code>refunded</code> / <code>fraud_refunded</code></td>\n<td>Triggered when the completed payment is refunded, refunded due to fraud, or reversed via chargeback.</td>\n<td>✅ Yes</td>\n</tr>\n<tr>\n<td><strong>Chargeback</strong></td>\n<td><code>chargeback</code></td>\n<td>Triggered when a chargeback is applied</td>\n<td>✅ Yes</td>\n</tr>\n</tbody>\n</table>\n</div><h4 id=\"webhook-payload-specification\"><strong>Webhook Payload Specification</strong></h4>\n<p><strong>Fields Description</strong></p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Key</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>message.purchaseId</td>\n<td>Unique identifier of the purchase generated by Paysecure.</td>\n</tr>\n<tr>\n<td>message.client</td>\n<td>Customer’s ID in merchant’s system (if available), otherwise \"NA\".</td>\n</tr>\n<tr>\n<td>message.client.email</td>\n<td>Customer’s email address.</td>\n</tr>\n<tr>\n<td>message.client.phone</td>\n<td>Customer’s phone number (with country code).</td>\n</tr>\n<tr>\n<td>message.client.full_name</td>\n<td>Full name of the customer.</td>\n</tr>\n<tr>\n<td>message.client.date_of_birth</td>\n<td>Customer’s date of birth in YYYY-MM-DD format.</td>\n</tr>\n<tr>\n<td>message.client.street_address</td>\n<td>Customer’s full street address.</td>\n</tr>\n<tr>\n<td>message.client.country</td>\n<td>ISO 2-letter country code of the customer.</td>\n</tr>\n<tr>\n<td>message.client.city</td>\n<td>City name (and state, if applicable).</td>\n</tr>\n<tr>\n<td>message.client.zip_code</td>\n<td>Postal / ZIP code.</td>\n</tr>\n<tr>\n<td>message.client.stateCode</td>\n<td>ISO 2-letter state code.</td>\n</tr>\n<tr>\n<td>message.updated_on</td>\n<td>UNIX timestamp of the last update to the transaction.</td>\n</tr>\n<tr>\n<td>message.type</td>\n<td>Type of transaction (e.g., \"purchase\").</td>\n</tr>\n<tr>\n<td>message.paymentMethod</td>\n<td>Comma-separated list of payment methods used (e.g., \"MASTER,VISA,JCB\").</td>\n</tr>\n<tr>\n<td>message.amountUnit</td>\n<td>Unit of amount — \"MAJOR\" for full currency unit, \"MINOR\" for subunits.</td>\n</tr>\n<tr>\n<td>message.errorMsg</td>\n<td>Message describing the transaction result — success message or error details.</td>\n</tr>\n<tr>\n<td>message.created_on</td>\n<td>UNIX timestamp when the purchase was created.</td>\n</tr>\n<tr>\n<td>message.merchantRef</td>\n<td>Unique transaction reference from the merchant.</td>\n</tr>\n<tr>\n<td>message.merchantName</td>\n<td>Registered merchant name in PaySecure.</td>\n</tr>\n<tr>\n<td>message.purchase.currency</td>\n<td>Currency code (ISO 4217).</td>\n</tr>\n<tr>\n<td>message.purchase.products</td>\n<td>Array of product details (name, quantity, price, discount, tax).</td>\n</tr>\n<tr>\n<td>message.purchase.total</td>\n<td>Total amount for all products (in amount unit).</td>\n</tr>\n<tr>\n<td>message.purchase.language</td>\n<td>Language code for the transaction (ISO 639-1).</td>\n</tr>\n<tr>\n<td>message.payment.payment_type</td>\n<td>Type of payment (e.g., \"PURCHASE\").</td>\n</tr>\n<tr>\n<td>message.payment.amount</td>\n<td>Payment amount.</td>\n</tr>\n<tr>\n<td>message.payment.currency</td>\n<td>Payment currency.</td>\n</tr>\n<tr>\n<td>message.payment.paid_on</td>\n<td>UNIX timestamp when the payment was completed.</td>\n</tr>\n<tr>\n<td>message.status</td>\n<td>Current transaction status.</td>\n</tr>\n<tr>\n<td>message.status_history</td>\n<td>Array of all past statuses with timestamps.</td>\n</tr>\n<tr>\n<td>message.reference</td>\n<td>PaySecure’s unique transaction reference.</td>\n</tr>\n<tr>\n<td>status (root-level)</td>\n<td>Duplicate of current status for quick access.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"possible-status-values\"><strong>Possible Status Values</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>status</th>\n<th>description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>error</td>\n<td>purchase failed due to an error.</td>\n</tr>\n<tr>\n<td>cancelled</td>\n<td>purchase was cancelled by the user or system.</td>\n</tr>\n<tr>\n<td>created</td>\n<td>purchase record created but not paid yet.</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>payment link or session expired.</td>\n</tr>\n<tr>\n<td>overdue</td>\n<td>payment overdue.</td>\n</tr>\n<tr>\n<td>paid</td>\n<td>payment completed successfully.</td>\n</tr>\n<tr>\n<td>refunded</td>\n<td>payment refunded.</td>\n</tr>\n<tr>\n<td>fraud_refunded</td>\n<td>refunded due to fraud detection.</td>\n</tr>\n<tr>\n<td>chargeback</td>\n<td>reversed due to chargeback.</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>payment is in progress.</td>\n</tr>\n<tr>\n<td>refund_in_process</td>\n<td>refund process started but not completed.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"🔐-key-pair-generation\"><strong>🔐 Key Pair Generation</strong></h2>\n<p><strong>Paysecure uses RSA key pairs to digitally sign webhooks, ensuring all notifications are both secure and authentic.</strong></p>\n<hr />\n<p><strong>1. Generate Your Keys</strong></p>\n<img src=\"https://content.pstmn.io/6e17a656-3d35-471b-9eb3-9b4e22306c02/U2NyZWVuc2hvdCAyMDI1LTExLTE3IGF0IDguMzIuNDTigK9BTS5wbmc=\" />\n\n<ul>\n<li><p>Click “Generate Key Pair” in the dashboard.</p>\n</li>\n<li><p>A unique RSA private key and public key are created for your merchant ID.</p>\n</li>\n</ul>\n<p><strong>2. Key Storage</strong></p>\n<img src=\"https://content.pstmn.io/336ed3b4-84ad-4df2-bfbb-d59ac9427185/U2NyZWVuc2hvdCAyMDI1LTExLTE3IGF0IDguMzUuMDLigK9BTS5wbmc=\" />\n\n<ul>\n<li><p>Private Key → Stored securely by Paysecure (never exposed).</p>\n</li>\n<li><p>Public Key → Displayed to you once on the screen. Copy and save it for verifying signatures.</p>\n</li>\n</ul>\n<p><strong>3. Webhook Signing</strong></p>\n<ul>\n<li><p>Every webhook payload is signed using Paysecure’s private key.</p>\n</li>\n<li><p>The signature is included in webhook headers:</p>\n<ul>\n<li>paysecure-sign or paysecure_sign</li>\n</ul>\n</li>\n</ul>\n<p><strong>4. Verification</strong></p>\n<ul>\n<li><p>Use your public key to verify the paysecure-sign header against the webhook body.</p>\n</li>\n<li><p>This ensures the webhook came from Paysecure and was not tampered with.</p>\n</li>\n</ul>\n<h2 id=\"🔏-signature-paysecure-sign-or-paysecure_sign\"><strong>🔏 Signature: paysecure-sign (or paysecure_sign)</strong></h2>\n<p><strong>The paysecure-sign header is a Base64-encoded digital signature generated using your merchant-specific RSA private key.</strong></p>\n<hr />\n<h3 id=\"🔨-how-the-signature-is-generated\"><strong>🔨 How the Signature is Generated</strong></h3>\n<ol>\n<li>Message Construction</li>\n</ol>\n<p>Concatenate the following fields in order:</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{purchaseId}|{message.status}|{brandId}\n\n</code></pre>\n<p>Example</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code>1234567890|PAID|BRAND_001\n\n</code></pre><p>2. Signing Algorithm</p>\n<ul>\n<li><p>Algorithm: SHA256withRSA</p>\n</li>\n<li><p>Output: Base64-encoded signature (sent in the paysecure-sign header).</p>\n</li>\n</ul>\n<h3 id=\"✅-how-to-verify-the-signature\"><strong>✅ How to Verify the Signature</strong></h3>\n<ol>\n<li>Rebuild the Message</li>\n</ol>\n<p>From the webhook JSON body, extract:</p>\n<ul>\n<li><p>purchaseId</p>\n</li>\n<li><p>status (convert to uppercase)</p>\n</li>\n<li><p>brandId</p>\n</li>\n</ul>\n<p>Reconstruct the string in the same format:<br />{purchaseId}|{message.status}|{brandId}</p>\n<p>2. Verification Steps</p>\n<ul>\n<li><p>Use your stored public key.</p>\n</li>\n<li><p>Decode the paysecure-sign header from Base64.</p>\n</li>\n<li><p>Verify using SHA256withRSA.</p>\n</li>\n<li><p>If verification succeeds, the webhook is authentic and untampered.</p>\n</li>\n</ul>\n<hr />\n<h3 id=\"💻-java-verification-example\"><strong>💻 Java Verification Example</strong></h3>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-java\">public static boolean verifySignature(String message, String signatureBase64, PublicKey publicKey) throws Exception {\n    Signature signature = Signature.getInstance(\"SHA256withRSA\");\n    signature.initVerify(publicKey);\n    signature.update(message.getBytes());\n    byte[] signatureBytes = Base64.getDecoder().decode(signatureBase64);\n    return signature.verify(signatureBytes);\n}\n\n</code></pre>\n<ul>\n<li><p>message → The reconstructed string (purchaseId|STATUS|brandId)</p>\n</li>\n<li><p>signatureBase64 → Value from paysecure-sign header</p>\n</li>\n<li><p>publicKey → Your saved Paysecure public key</p>\n</li>\n</ul>\n<p><strong>Sample Webhook</strong>  </p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n  \"message\": {\n    \"purchaseId\": \"6808127876673d75156df3e6\",\n    \"client\": {\n      \"customerId\": \"NA\",\n      \"email\": \"daler101@hotmail.com\",\n      \"phone\": \"+17808752869\",\n      \"full_name\": \"Dale Richardson\",\n      \"date_of_birth\": \"1800-01-01\",\n      \"street_address\": \"48 AVE , ALBERTA BEACH\",\n      \"country\": \"CA\",\n      \"city\": \"ALBERTA\",\n      \"zip_code\": \"T0E 0A0\",\n      \"shipping_street_address\": \" \",\n      \"shipping_country\": \"\",\n      \"shipping_city\": \"\",\n      \"shipping_zip_code\": \"\",\n      \"cc\": [],\n      \"bcc\": [],\n      \"stateCode\": \"AB\"\n    },\n    \"updated_on\": 1745359929,\n    \"type\": \"purchase\",\n    \"isFraud\": \"NO\",\n    \"paymentMethod\": \"INTERAC,MASTER,VISA,JCB\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"Transaction succeeded-APPROVED\",\n    \"detailedMsg\": \"Transaction succeeded-APPROVED\",\n    \"redirectType\": \"POST\",\n    \"force_recurring\": false,\n    \"created_on\": 1745359481,\n    \"merchantRef\": \"7235\",\n    \"merchantName\": \"firstinvestacademy\",\n    \"pspReference\": \"pKlSYNsPOdOL2FCmSAjXEOHzDDpSP5\",\n    \"bankmid\": \"waverlite\",\n    \"bankname\": \"waverlite\",\n    \"purchase\": {\n      \"currency\": \"CAD\",\n      \"products\": [\n        {\n          \"name\": \"Payment\",\n          \"quantity\": 1,\n          \"price\": 294,\n          \"discount\": 0,\n          \"tax_percent\": \"0.00\"\n        }\n      ],\n      \"total\": 294,\n      \"language\": \"en\",\n      \"notes\": \"Micro+ Plan\",\n      \"debt\": 0,\n      \"total_formatted\": 1,\n      \"expireInMin\": \"43800\",\n      \"taxAmount\": 0,\n      \"taxPercent\": 0,\n      \"request_client_details\": [],\n      \"email_message\": \"\"\n    },\n    \"payment\": {\n      \"is_outgoing\": false,\n      \"payment_type\": \"PURCHASE\",\n      \"amount\": 294,\n      \"currency\": \"CAD\",\n      \"net_amount\": 294,\n      \"fee_amount\": 0,\n      \"pending_amount\": 0,\n      \"pending_unfreeze_on\": null,\n      \"description\": \"\",\n      \"paid_on\": 1745359487,\n      \"remote_paid_on\": 1745359487\n    },\n    \"issuer_details\": {\n      \"website\": \"\",\n      \"legal_street_address\": \"\",\n      \"legal_country\": \"\",\n      \"legal_city\": \"\",\n      \"legal_zip_code\": \"\",\n      \"bank_accounts\": [\n        {}\n      ],\n      \"legal_name\": \"FISCOM\",\n      \"brand_name\": \"FISCOM\",\n      \"registration_number\": \"\",\n      \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n      \"payment_method\": \"\",\n      \"flow\": \"payform\",\n      \"extra\": {\n        \"amount\": 294,\n        \"masked_pan\": \"INTERAC\"\n      },\n      \"country\": \"\",\n      \"attempts\": [\n        {\n          \"client_ip\": \"185.199.101.249\",\n          \"type\": \"execute\",\n          \"payment_method\": \"INTERAC\",\n          \"flow\": \"payform\",\n          \"successful\": true,\n          \"country\": \"INTERAC\",\n          \"processing_time\": 1745359487,\n          \"extra\": {\n            \"amount\": 294,\n            \"masked_pan\": \"INTERAC\"\n          }\n        }\n      ]\n    },\n    \"status\": \"PAID\",\n    \"status_history\": [\n      {\n        \"status\": \"created\",\n        \"timestamp\": 1745359481\n      },\n      {\n        \"status\": \"pending_execute\",\n        \"timestamp\": 1745359487\n      },\n      {\n        \"status\": \"payment_in_process\",\n        \"timestamp\": 1745359491\n      },\n      {\n        \"status\": \"viewed\",\n        \"timestamp\": 1745359500\n      },\n      {\n        \"status\": \"paid 294.0\",\n        \"timestamp\": 1745359929\n      }\n    ],\n    \"viewedOn\": 1745359932,\n    \"is_test\": false,\n    \"brand_id\": \"88f25364-8d96-4c2f-8dae-d4aa2756e4e3\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS4754\",\n    \"reference\": \"7235\",\n    \"issued\": \"2025-04-22\",\n    \"due\": 1745359481,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"Africhange Technologies\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"fx_Currency\": \"CAD\",\n    \"fx_Amount\": \"294.00\",\n    \"transFees\": \"0.44\",\n    \"refundFee\": \"NA\",\n    \"chargeBackFee\": \"NA\",\n    \"rollingReserve\": \"0.00\",\n    \"cascade_Num\": \"NA\",\n    \"debitOrcredit\": \"NA\",\n    \"conversionRiskFactorApplied\": \"0\",\n    \"payInDetails\": {\n      \"name\": \"INTERAC E-TRANSFER\",\n      \"emailAddress\": \"transfer@ieft.ca\",\n      \"secretQA\": \"q4754199\",\n      \"secretAnswer\": \"a4754199\"\n    },\n    \"paidOn\": 1745359929,\n    \"receivedAmt\": 294,\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://firstinvestschool.com/?wc-api=wc_gateway_paysecure_payments&amp;id=7235&amp;action=paid\",\n    \"failure_redirect\": \"https://firstinvestschool.com/?wc-api=wc_gateway_paysecure_payments&amp;id=7235&amp;action=cancel\",\n    \"cancel_redirect\": \"https://firstinvestschool.com/?wc-api=wc_gateway_paysecure_payments&amp;id=7235&amp;action=cancel\",\n    \"success_callback\": \"https://firstinvestschool.com/?wc-api=wc_gateway_paysecure_payments&amp;id=7235&amp;action=paid\",\n    \"failure_callback\": \"\",\n    \"creator_agent\": \"PaySecure Payments for WooCommerce: v1.2.3\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"54.229.186.248, 172.70.58.20, 15.158.56.19\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6808127876673d75156df3e6/\",\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/6808127876673d75156df3e6/\",\n    \"mdr\": \"13.52\",\n    \"payoutProcess\": false\n  },\n  \"status\": \"paid\"\n}\n\n</code></pre>\n","_postman_id":"8fef98f2-b1cd-4a19-88e8-34e6b5439a9d"},{"name":"Payout","item":[],"id":"9f0e2fed-b4e6-4f9c-804c-7b5a1a18e9a2","description":"<h3 id=\"overview\">Overview</h3>\n<p>When a transaction status changes to a terminal state (e.g., paid, pending_review (in development)), our payment gateway sends a server-to-server POST callback to the merchant's configured Webhook URL.</p>\n<p>The callback includes full transaction details so the merchant can update order status in real time.</p>\n<h3 id=\"webhook-events-for-payouts\">Webhook Events for Payouts</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Event type (Condition applied in code)</th>\n<th>Status</th>\n<th>When is the event triggered</th>\n<th>Is this a terminal event</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Payout – Created</td>\n<td>created</td>\n<td>When the payout request is created</td>\n<td>No</td>\n</tr>\n<tr>\n<td>Payout – in Process</td>\n<td>payout_in_process</td>\n<td>When the Payout request is triggered to the bank, and the status is in pending</td>\n<td>No</td>\n</tr>\n<tr>\n<td>Payout – Pending Review</td>\n<td>pending_review</td>\n<td>When the payout request needs manual review from the merchant</td>\n<td>No</td>\n</tr>\n<tr>\n<td>payout – failure</td>\n<td>error</td>\n<td>Triggered when the payout request fails (system/PSP error, rejection, etc.).</td>\n<td>✅ Yes</td>\n</tr>\n<tr>\n<td>payout – success</td>\n<td>paid</td>\n<td>Triggered when the payout is processed successfully and funds are released.</td>\n<td>✅ Yes</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"webhook-payload-specification\"><strong>Webhook Payload Specification</strong></h2>\n<h3 id=\"fields-description\"><strong>Fields Description</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Key</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>payload.payoutId</td>\n<td>Unique identifier of the payout generated by Paysecure.</td>\n</tr>\n<tr>\n<td>payload.client.customerId</td>\n<td>Customer’s ID in the merchant’s system (if available), otherwise \"NA\".</td>\n</tr>\n<tr>\n<td>payload.client.email</td>\n<td>Customer’s email address.</td>\n</tr>\n<tr>\n<td>payload.client.phone</td>\n<td>Customer’s phone number (with country code).</td>\n</tr>\n<tr>\n<td>payload.client.full_name</td>\n<td>Full name of the customer.</td>\n</tr>\n<tr>\n<td>payload.client.country</td>\n<td>ISO 2-letter country code of the customer.</td>\n</tr>\n<tr>\n<td>payload.updated_on</td>\n<td>UNIX timestamp of the last update to the payout transaction.</td>\n</tr>\n<tr>\n<td>payload.payoutMethod</td>\n<td>Payout method used (e.g., \"PAYOUT-INTERAC\").</td>\n</tr>\n<tr>\n<td>payload.amountUnit</td>\n<td>Unit of amount — \"MAJOR\" for full currency unit, \"MINOR\" for subunits.</td>\n</tr>\n<tr>\n<td>payload.amount</td>\n<td>Total payout amount.</td>\n</tr>\n<tr>\n<td>payload.errorMsg</td>\n<td>Message describing the payout result — success message or error details.</td>\n</tr>\n<tr>\n<td>payload.purpose</td>\n<td>Purpose/description of the payout.</td>\n</tr>\n<tr>\n<td>payload.created_on</td>\n<td>UNIX timestamp when the payout was created.</td>\n</tr>\n<tr>\n<td>payload.merchantRef</td>\n<td>Unique transaction reference from the merchant.</td>\n</tr>\n<tr>\n<td>payload.merchantName</td>\n<td>Registered merchant name in Paysecure.</td>\n</tr>\n<tr>\n<td>payload.currency</td>\n<td>Currency code of the payout (ISO 4217).</td>\n</tr>\n<tr>\n<td>payload.fx_Currency</td>\n<td>FX (foreign exchange) currency used (if applicable).</td>\n</tr>\n<tr>\n<td>payload.fx_Amount</td>\n<td>FX-adjusted payout amount.</td>\n</tr>\n<tr>\n<td>payload.transFees</td>\n<td>Transaction fee amount.</td>\n</tr>\n<tr>\n<td>payload.paymentOn</td>\n<td>UNIX timestamp when the payout was completed/paid.</td>\n</tr>\n<tr>\n<td>payload.payOutDetails.name</td>\n<td>Payout instrument name (e.g., \"INTERAC E-TRANSFER\").</td>\n</tr>\n<tr>\n<td>payload.payOutDetails.emailAddress</td>\n<td>Payout recipient email address.</td>\n</tr>\n<tr>\n<td>payload.payOutDetails.secretQA</td>\n<td>Security question used for payout (if applicable).</td>\n</tr>\n<tr>\n<td>payload.payOutDetails.secretAnswer</td>\n<td>Security answer used for payout (if applicable).</td>\n</tr>\n<tr>\n<td>payload.taxAmount</td>\n<td>Tax amount applied to the payout.</td>\n</tr>\n<tr>\n<td>payload.taxPercent</td>\n<td>Tax percentage applied to the payout.</td>\n</tr>\n<tr>\n<td>payload.redirectType</td>\n<td>Redirect method after payout completion (e.g., \"POST\").</td>\n</tr>\n<tr>\n<td>payload.pendingReview</td>\n<td>Indicates if the payout is under review (\"Yes\"/\"No\").</td>\n</tr>\n<tr>\n<td>payload.surcharge</td>\n<td>Surcharge amount applied (if any).</td>\n</tr>\n<tr>\n<td>payload.success_callback</td>\n<td>Callback URL invoked on payout success.</td>\n</tr>\n<tr>\n<td>payload.failure_callback</td>\n<td>Callback URL invoked on payout failure.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"possible-status-values\"><strong>Possible Status Values</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>status</th>\n<th>description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>error</td>\n<td>Payout failed due to an error.</td>\n</tr>\n<tr>\n<td>created</td>\n<td>Payout record created but not paid yet.</td>\n</tr>\n<tr>\n<td>paid</td>\n<td>payment completed successfully.</td>\n</tr>\n<tr>\n<td>payout_in_process</td>\n<td>Payout is in progress.</td>\n</tr>\n<tr>\n<td>pending_review</td>\n<td>Payout needs to be reviewed</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"🔐-key-pair-generation\"><strong>🔐 Key Pair Generation</strong></h2>\n<p><strong>Paysecure uses RSA key pairs to digitally sign webhooks, ensuring all notifications are both secure and authentic.</strong></p>\n<hr />\n<h3 id=\"1-generate-your-keys\"><strong>1. Generate Your Keys</strong></h3>\n<img src=\"https://content.pstmn.io/7518adf1-d6ec-4b0e-b1bb-b6710a5173f1/U2NyZWVuc2hvdCAyMDI1LTExLTE3IGF0IDExLjM4LjIw4oCvQU0ucG5n\" />\n\n<ul>\n<li><p>Click “Generate Key Pair” in the dashboard.</p>\n</li>\n<li><p>A unique RSA private key and public key are created for your merchant ID</p>\n</li>\n</ul>\n<h3 id=\"2-key-storage\"><strong>2. Key Storage</strong></h3>\n<img src=\"https://content.pstmn.io/0a39578e-0796-4671-80f6-d68ca391bdef/U2NyZWVuc2hvdCAyMDI1LTExLTE3IGF0IDExLjM4LjMw4oCvQU0ucG5n\" />\n\n<ul>\n<li><p>Private Key → Stored securely by Paysecure (never exposed).</p>\n</li>\n<li><p>Public Key → Displayed to you once on the screen. Copy and save it for verifying signatures.</p>\n</li>\n</ul>\n<h3 id=\"3-webhook-signing\"><strong>3. Webhook Signing</strong></h3>\n<ul>\n<li><p>Every webhook payload is signed using Paysecure’s private key.</p>\n</li>\n<li><p>The signature is included in webhook headers:</p>\n<ul>\n<li>paysecure-sign or paysecure_sign</li>\n</ul>\n</li>\n</ul>\n<h3 id=\"4-verification\"><strong>4. Verification</strong></h3>\n<ul>\n<li><p>Use your public key to verify the paysecure-sign header against the webhook body.</p>\n</li>\n<li><p>This ensures the webhook came from Paysecure and was not tampered with.</p>\n</li>\n</ul>\n<h2 id=\"🔏-signature-paysecure-sign-or-paysecure_sign\"><strong>🔏 Signature: paysecure-sign (or paysecure_sign)</strong></h2>\n<p><strong>The paysecure-sign header is a Base64-encoded digital signature generated using your merchant-specific RSA private key.</strong></p>\n<h3 id=\"🔨-how-the-signature-is-generated\"><strong>🔨 How the Signature is Generated</strong></h3>\n<ol>\n<li><strong>Message Construction</strong></li>\n</ol>\n<p>Concatenate the following fields in order:</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code>{payoutId}|{payload.status}\n\n</code></pre><p><strong>Example:</strong></p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code>1234567890|paid\n\n</code></pre><p><strong>2. Signing Algorithm</strong></p>\n<ol>\n<li><p>Algorithm: SHA256withRSA</p>\n</li>\n<li><p>Output: Base64-encoded signature (sent in the paysecure-sign header).</p>\n</li>\n</ol>\n<h3 id=\"✅-how-to-verify-the-signature\"><strong>✅ How to Verify the Signature</strong></h3>\n<ol>\n<li><strong>Rebuild the Message</strong></li>\n</ol>\n<p>From the webhook JSON body, extract:</p>\n<ul>\n<li><p>payoutId</p>\n</li>\n<li><p>payload.status (convert to lowercase)</p>\n</li>\n</ul>\n<p>Reconstruct the string in the same format:<br />{payoutId}|{payload.status}</p>\n<p><strong>2. Verification Steps</strong></p>\n<ul>\n<li><p>Use your stored public key.</p>\n</li>\n<li><p>Decode the paysecure-sign header from Base64.</p>\n</li>\n<li><p>Verify using SHA256withRSA.</p>\n</li>\n<li><p>If verification succeeds, the webhook is authentic and untampered.</p>\n</li>\n</ul>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-java\">public static boolean verifySignature(String message, String signatureBase64, PublicKey publicKey) throws Exception {\n    Signature signature = Signature.getInstance(\"SHA256withRSA\");\n    signature.initVerify(publicKey);\n    signature.update(message.getBytes());\n    byte[] signatureBytes = Base64.getDecoder().decode(signatureBase64);\n    return signature.verify(signatureBytes);\n}\n\n</code></pre>\n<ul>\n<li><p>message → The reconstructed string (payoutId|status)</p>\n</li>\n<li><p>signatureBase64 → Value from paysecure-sign header</p>\n</li>\n<li><p>publicKey → Your saved Paysecure public key</p>\n</li>\n</ul>\n<p><strong>Sample Webhook:</strong></p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n  \"payload\": {\n    \"payoutId\": \"68b02af16c4f71530ae1d73b\",\n    \"client\": {\n      \"customerId\": \"NA\",\n      \"email\": \"ashishm.21190@gmail.com\",\n      \"phone\": \"+14377717874\",\n      \"full_name\": \"Ashish Mistry\",\n      \"country\": \"CA\"\n    },\n    \"updated_on\": 1756375793,\n    \"payoutMethod\": \"PAYOUT-INTERAC-ETRANSFER\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 6,\n    \"errorMsg\": \"\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1756375793,\n    \"merchantRef\": \"68b02af16c4f71530ae1d73b\",\n    \"merchantName\": \"arunsinghal\",\n    \"status\": \"PAID\",\n    \"status_history\": [\n      {\n        \"status\": \"created\",\n        \"timestamp\": 1756375793\n      },\n      {\n        \"status\": \"paid\",\n        \"timestamp\": 1756375810\n      }\n    ],\n    \"currency\": \"CAD\",\n    \"fx_Currency\": \"CAD\",\n    \"fx_Amount\": \"6.00\",\n    \"transFees\": \"0.3\",\n    \"paymentOn\": 1756375810,\n    \"payOutDetails\": {\n      \"name\": \"INTERAC E-TRANSFER\",\n      \"emailAddress\": \"ashishm.21190@gmail.com\",\n      \"secretQA\": \"q680216471530173202\",\n      \"secretAnswer\": \"a680216471530173202\"\n    },\n    \"taxAmount\": 0,\n    \"taxPercent\": 0,\n    \"redirectType\": \"POST\",\n    \"pendingReview\": \"No\",\n    \"surcharge\": 0,\n    \"success_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\",\n    \"failure_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\",\n    \"mdr\": \"0.00\"\n  },\n  \"status\": \"paid\"\n}\n\n</code></pre>\n","_postman_id":"9f0e2fed-b4e6-4f9c-804c-7b5a1a18e9a2"}],"id":"b31c2a9d-e72e-44fa-b865-ad8d121e7639","description":"<p>To receive information about various transaction status and events, you will need to set up an endpoint which accepts payloads sent by Paysecure. Your endpoint will receive <strong>POST</strong> requests with <strong>content-type: application/json</strong>.</p>\n<h3 id=\"configuring-the-webhook-endpoint\">Configuring the webhook endpoint</h3>\n<p>The webhook endpoint can be set up on <code>Partner Dashboard -&gt; Webhooks -&gt; New Webhook</code>.</p>\n<img src=\"https://content.pstmn.io/3b411aa7-0e42-44bd-985e-9c1f1155a729/U2NyZWVuc2hvdCAyMDI1LTExLTE2IGF0IDkuNDcuMDnigK9QTS5wbmc=\" />\n\n<p>Make sure you save the endpoint by clicking \"Create\".</p>\n<p>Paysecure will post all payloads to the specified URLs. Please note that if merchant face any issues with accepting the webhook, it will not be resent. Alternatively the merchant can call Paysecure get status API to verify the status of a purchase.</p>\n<h3 id=\"steps-to-configure-a-webhook\"><strong>Steps to Configure a Webhook</strong></h3>\n<img src=\"https://content.pstmn.io/3cd636a8-4106-48ed-a66b-ae591c3daf1f/U2NyZWVuc2hvdCAyMDI1LTExLTE2IGF0IDEwLjU3LjAz4oCvUE0ucG5n\" />\n\n<p><strong>1.Add a New Webhook:</strong></p>\n<ul>\n<li>Click on the “New Webhook” button.</li>\n</ul>\n<p><strong>2. Provide Details:</strong></p>\n<ul>\n<li><p>Name: Give the webhook a descriptive name.</p>\n</li>\n<li><p>Payment Method Selection:</p>\n</li>\n</ul>\n<p>a. Choose a specific payment method or select “All” for universal callbacks.</p>\n<ul>\n<li>Enter URL:</li>\n</ul>\n<p>a. Provide the callback URL where the event notifications will be sent.</p>\n<p><strong>3. Select Event Triggers:</strong></p>\n<p>a. Choose from a list of available events (Note: Depending on the payment method, not all events may be available.)</p>\n<p><strong>4. Save configuration:</strong></p>\n<p>a. Click “Save” to store the webhook settings.**</p>\n<h2 id=\"notes\">Notes:</h2>\n<ol>\n<li><p>You can setup one URL for all the events or individual URLs for each of the events. Paysecure would call the webhooks based on whatever the setup is. If only one URL, the developer will need to extract the message from the payload information.</p>\n</li>\n<li><p>In case of a success_callback (webhook) or failure_callback (webhook) is given the <code>/purchases</code> API or <code>/createSession</code> API, then priority will be given to API callback webhooks, and not the webhooks set in the merchant dashboard. In other words, the webhooks given in the API will override the webhooks set in the merchant dashboard. The webhook posted would be a JSON object (either purchase or payout object as the case might be) containing the status. This object is the same as the one you will get in the <code>/getStatus</code> API call <code>https://api.paysecure.net/api/v1/purchases/{purchaseId}/</code></p>\n</li>\n</ol>\n<h2 id=\"available-event-for-subscription\">Available Event for subscription</h2>\n<p>When a transaction status changes to a terminal state (e.g., paid, refunded, expired), our payment gateway sends a server-to-server POST callback to the merchant's configured Webhook URL.</p>\n<p>The callback includes full transaction details so the merchant can update order status in real time.</p>\n<h2 id=\"http-method--headers\"><strong>HTTP Method &amp; Headers</strong></h2>\n<p><strong>Method: POST</strong></p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Header</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Content-Type</td>\n<td><strong>application/json; charset=utf-8 — Indicates the payload format is JSON in UTF-8 encoding.</strong></td>\n</tr>\n<tr>\n<td>User-Agent</td>\n<td>Always set to \"PaySecure\" — Identifies the request origin as PaySecure.</td>\n</tr>\n<tr>\n<td>paysecure_sign</td>\n<td><strong>Present only if a signature value (paysecure_sign) is generated(</strong><a href=\"https://docs.google.com/document/d/1qgsO7_jxMOXASnezEw-RU70WNddCfKrXWCwPGJLmqUs/edit?tab=t.nwoa2ohizyre#heading=h.rlwjz036ocez\"><b>see the logic below</b></a><strong>). This is used for validating the authenticity of the callback.</strong></td>\n</tr>\n<tr>\n<td>paysecure-sign</td>\n<td><strong>Same signature value as paysecure_sign but provided in an alternate header name for better compatibility.</strong></td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"webhook-structure\"><strong>Webhook structure</strong></h3>\n<p>We add a signature as “<strong>paysecure_sign</strong>” or <strong>\"paysecure-sign\"</strong> in the webhook header for verifying the payload, If you have already created a <strong>public key</strong> from your merchant dashboard.</p>\n<p>To verify this signature, decrypt the signature with your public key. Compare this with the values which you received in your payload.</p>\n<p>Use the following method (in Java) for signature verification.</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-java\"> private static boolean verify(String message,String signature, PublicKey publicKey) throws Exception \n{\n    Signature verifier = Signature.getInstance(\"SHA256withRSA\");\n    verifier.initVerify(publicKey);\n    verifier.update(message.getBytes());\n    return verifier.verify(Base64.getDecoder().decode(signature.getBytes()));\n}\n\n</code></pre>\n<ol>\n<li><p>Where the <strong>message</strong> is the combination of values which you received in the payload:</p>\n<ol>\n<li><p>For Payins: the message is a combination of <strong><code>purchaseId+\"|\"+status(uppercase)+\"|\"+brandId</code></strong></p>\n</li>\n<li><p>Payouts: this message is a combination of p**<code>ayoutId+\"|\"+status(lowercase)</code>**</p>\n</li>\n</ol>\n</li>\n<li><p>The signature is the value of the “<strong>paysecure_sign</strong>” or <strong>\"paysecure-sign\"</strong> you received in webhook.</p>\n</li>\n<li><p>You can obtain the <strong>Public Key</strong> from your merchant dashboard.</p>\n</li>\n</ol>\n","_postman_id":"b31c2a9d-e72e-44fa-b865-ad8d121e7639"},{"name":"🖥️ Status Code","item":[{"name":"Transaction Status and Their Meaning","item":[],"id":"db757d6e-696b-4b9d-874e-a7cefebbd893","description":"<p>The lifecycle of a transaction is reflected through the status of the transaction.</p>\n<p>This section details various statuses of a transaction and what it means and when does it appears.</p>\n<p>The status of a transaction can be read from the <code>\"status\"</code> field of the responses or webhook payload.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Description</strong></th>\n<th><strong>When it Appears</strong></th>\n<th><strong>Is it Final?</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>CREATED</td>\n<td>Purchase is created in the system.</td>\n<td>When Purchase API is called, the transaction is created as \"CREATED\".</td>\n<td>N</td>\n</tr>\n<tr>\n<td>CANCELLED</td>\n<td>Purchase is cancelled in the system. Only transactions in \"CREATED\" status can be cancelled.</td>\n<td>When Cancel API is called.</td>\n<td>Y</td>\n</tr>\n<tr>\n<td>PENDING EXECUTE</td>\n<td>Purchase hasn't been completed yet. Only transactions in \"CREATED\" status can become \"PENDING EXECUTE\" after S2S API call.</td>\n<td>The callback URL provided in the S2S call response hasn't been called by merchant yet.</td>\n<td>N</td>\n</tr>\n<tr>\n<td>OVERDUE</td>\n<td>Purchase hasn't been completed yet. Only transactions in \"CREATED\" status can become \"OVERDUE\" if S2S API hasn't been called in 2 hours.</td>\n<td>S2S API hasn't been called within 2 hours since transaction creation.</td>\n<td>N</td>\n</tr>\n<tr>\n<td>EXPIRED</td>\n<td>Purchase hasn't been completed. Only transactions in \"PAYMENT IN PROCESS\" and \"PENDING EXECUTE\" status can become \"EXPIRED\". After payment in process, no data is provided.</td>\n<td>The callback URL provided in the S2S call response hasn't been called by the merchant after the specific time period.</td>\n<td>Y</td>\n</tr>\n<tr>\n<td>PAID</td>\n<td>Purchase has been completed successfully. Only transactions in \"PAYMENT IN PROCESS\" status can become \"PAID\".</td>\n<td>The callback URL provided in the S2S call response has been called by the merchant.</td>\n<td>Y</td>\n</tr>\n<tr>\n<td>PAYMENT IN PROCESS</td>\n<td>Purchase hasn't been completed. Only transactions in \"PENDING EXECUTE\" status can become \"PAYMENT IN PROCESS\".</td>\n<td>When the user's action is pending (e.g., OTP confirmation). Transaction can stay in this status for 24 hours since creation.</td>\n<td>N</td>\n</tr>\n<tr>\n<td>CHARGEBACK</td>\n<td>Transaction type that allows customers to receive money back.</td>\n<td>When requested by customer or merchant (manual process).</td>\n<td>Y</td>\n</tr>\n<tr>\n<td>REFUNDED</td>\n<td>Only transactions in \"REFUND IN PROCESS\" status can become \"REFUNDED\".</td>\n<td>When the provider confirms the refund.</td>\n<td>Y</td>\n</tr>\n<tr>\n<td>REFUND IN PROCESS</td>\n<td>Only transactions in <strong>\"PAID\"</strong> status can become <strong>\"REFUND IN PROCESS\"</strong>.</td>\n<td>When Refund API is called and a response is received with \"REFUND IN PROCESS\" status.</td>\n<td>N</td>\n</tr>\n<tr>\n<td>ERROR</td>\n<td>Only transactions in statuses: <strong>\"PENDING EXECUTE\"</strong>, <strong>\"PAYMENT IN PROCESS\"</strong>, <strong>\"PAYOUT IN PROCESS\"</strong> or <strong>\"REFUND IN PROCESS\"</strong> can become \"ERROR\".</td>\n<td>Refers to the Errors list for possible errors.</td>\n<td>Y</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong></p>\n<p>If you want a more detailed error message, please rely on the <strong>\"errorMsg\"</strong> field in the responses or webhook payload.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"c18652d6-0b63-4997-ac16-ed0655c4d1ce","type":"text/javascript","exec":[""]}},{"listen":"test","script":{"id":"67fa5379-1145-4c79-b212-a91a973540d8","type":"text/javascript","exec":[""]}}],"_postman_id":"db757d6e-696b-4b9d-874e-a7cefebbd893"}],"id":"cff0cac7-c1d7-4853-b5a2-b71c01b0d681","description":"<h1 id=\"http-response-code\">HTTP Response Code</h1>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Code</strong></th>\n<th><strong>Triggering Event</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>200</td>\n<td>Successful Response</td>\n</tr>\n<tr>\n<td>202</td>\n<td>Successful / Accepted</td>\n</tr>\n<tr>\n<td>400</td>\n<td>Bad request, the given data is invalid, or additional data is required</td>\n</tr>\n<tr>\n<td>401</td>\n<td>unauthorized request</td>\n</tr>\n<tr>\n<td>404</td>\n<td>page not found</td>\n</tr>\n<tr>\n<td>405</td>\n<td>Method Not Allowed (GET/POST)</td>\n</tr>\n<tr>\n<td>415</td>\n<td>unsupported media type</td>\n</tr>\n<tr>\n<td>422</td>\n<td>Unprocessable content, data is required</td>\n</tr>\n<tr>\n<td>429</td>\n<td>Too many request attempt</td>\n</tr>\n<tr>\n<td>500</td>\n<td>Internal server error</td>\n</tr>\n</tbody>\n</table>\n</div><p>You will not get Error codes if HTTPS response code is 200 or 202.</p>\n<h2 id=\"error-codes-and-messages\">Error Codes and Messages</h2>\n<h3 id=\"with-http-code-400-404-401-405-415\">with http code (400, 404, 401, 405, 415)</h3>\n<p>Below is the list of possible error codes and the corresponding messages from Paysecure System</p>\n<h2 id=\"format\">Format</h2>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Code</strong></th>\n<th><strong>Message</strong></th>\n<th><strong>APIs that could generate the error code</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Authentication_failed</td>\n<td>Authorization header missing</td>\n<td>All</td>\n</tr>\n<tr>\n<td>already_in_process</td>\n<td>Some Processing is running on this purchaseId</td>\n<td>All</td>\n</tr>\n<tr>\n<td>unsupported_media_type</td>\n<td>Unsupported media type \"text/plain; charset=ISO-8859-1\" in request.</td>\n<td>All</td>\n</tr>\n<tr>\n<td>authentication_failed</td>\n<td>Incorrect secret_key/Invalid Merchant Type</td>\n<td>All</td>\n</tr>\n<tr>\n<td>transaction_error</td>\n<td>See the table below</td>\n<td>See the table below</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"transaction_error-message-list\">\"transaction_error\" Message List</h2>\n<p>All the Messages possible when \"transaction_error\" is in reponse:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Message</strong></th>\n<th><strong>APIs that generate the error Message</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Cvv_error</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Expired card</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>expiry_date_error</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Insufficient fund</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Invalid card number</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Issuing bank - do not honer</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Picking card</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Temp error - card blocked</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Transaction declined - try again</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>PurchaseId Not found.</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Only purchases that can be paid for can be initiated for payment.</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Customer/Ip is Blocked</td>\n<td>after executing callback_url</td>\n</tr>\n<tr>\n<td>Client Ip could not be match with Merchant Ip</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>Invalid Card Information</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>Card is Blocked</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>Different Type of key used to create purchase and payment</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>You charges setting is in complete .Please Contact to Administrator.</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>Allowed Attempt for this Transaction has been consumed</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>Customer not allowed For transaction</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>Invalid Card Expiry(Valid Format:MM/YY) must be greater than current month/year</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>Customer profile is Blocked</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>Customer/Card not allowed for transaction</td>\n<td>s2s calling</td>\n</tr>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>some Mandatory Parameter are missing</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Invalid_Parameter</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Invalid Email Format</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Merchant Limit is not set</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Brand not found!</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Only “curr_name” currency is allowed</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>Transaction amount must not be greater to maximum trans amount</td>\n<td>create purchase</td>\n</tr>\n<tr>\n<td>This Purchase was already fully refunded.</td>\n<td><code>/refund/</code></td>\n</tr>\n<tr>\n<td>Previous Refund Request already in Process</td>\n<td><code>/refund/</code></td>\n</tr>\n<tr>\n<td>Max Time for Refund was elapsed.</td>\n<td><code>/refund/</code></td>\n</tr>\n<tr>\n<td>Refund can not be initiated .Please contact Administrator.</td>\n<td><code>/refund/</code></td>\n</tr>\n<tr>\n<td>Only Purchases with `status == (paid)` can be refunded.</td>\n<td><code>/refund/</code></td>\n</tr>\n<tr>\n<td>Only purchases that can be paid for can be cancelled.</td>\n<td><code>/cancel/</code></td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"c18652d6-0b63-4997-ac16-ed0655c4d1ce","type":"text/javascript","exec":[""]}},{"listen":"test","script":{"id":"67fa5379-1145-4c79-b212-a91a973540d8","type":"text/javascript","exec":[""]}}],"_postman_id":"cff0cac7-c1d7-4853-b5a2-b71c01b0d681"},{"name":"Payment Methods","item":[{"name":"💳 Card Payments","item":[{"name":"Concepts","item":[],"id":"4aab1160-21ae-40b9-b1a1-804a3cced1b7","description":"<h1 id=\"paysecure-card-payments\">Paysecure Card Payments</h1>\n<h1 id=\"get-started\"><strong>Get started</strong></h1>\n<p>Paysecure’s Server-to-Server (S2S) integration allows merchants to process card payments entirely from their backend systems. In this model, the client application or browser does not interact directly with Paysecure APIs. All sensitive payment operations are handled securely on the server.</p>\n<p>This integration is recommended for merchants who require:</p>\n<ul>\n<li><p>Full control over the checkout experience</p>\n</li>\n<li><p>Reduced exposure of platform endpoints</p>\n</li>\n<li><p>A secure and compliant payment architecture</p>\n</li>\n</ul>\n<h1 id=\"how-it-works\"><strong>How it works</strong></h1>\n<p>The S2S card payment flow follows a three-step process:</p>\n<ol>\n<li><p>Create a purchase<br /> Register the transaction and generate a unique purchaseId.</p>\n</li>\n<li><p>Submit card details (S2S)<br /> Send card and device details securely from your server.</p>\n</li>\n<li><p>Handle callbacks and redirects<br /> Complete the transaction using 2D or 3D Secure flows.</p>\n</li>\n</ol>\n<p><strong>This integration supports:</strong></p>\n<ul>\n<li><p>2D (non-3DS) transactions</p>\n</li>\n<li><p>3D Secure Frictionless transactions</p>\n</li>\n<li><p>3D Secure Challenge transactions</p>\n</li>\n</ul>\n<h1 id=\"before-you-begin\"><strong>Before you begin</strong></h1>\n<p>Before starting the integration, ensure the following prerequisites are met:</p>\n<ul>\n<li><p>You have received your API credentials from Paysecure</p>\n</li>\n<li><p>Your server can make secure HTTPS requests</p>\n</li>\n<li><p>You are PCI-DSS compliant for handling card data</p>\n</li>\n<li><p>You have configured the following redirect URLs:</p>\n<ul>\n<li><p>success_redirec</p>\n</li>\n<li><p>pending_redirect</p>\n</li>\n<li><p>failure_redirect</p>\n</li>\n</ul>\n</li>\n<li><p>You have a valid brand_id provided by Paysecure</p>\n</li>\n</ul>\n<h1 id=\"create-a-new-payment-session\"><strong>Create a New Payment Session</strong></h1>\n<p>A payment session is created when a purchase is initialized in the Paysecure system. This session represents the starting point of a transaction and is required before submitting any payment details or initiating authentication flows.</p>\n<p>Creating a payment session registers the transaction details, configures redirect URLs, and generates a unique identifier (purchaseId) that is used in all subsequent Server-to-Server (S2S) payment operations.</p>\n<h2 id=\"when-to-create-a-payment-session\"><strong>When to create a payment session</strong></h2>\n<p>You must create a new payment session when:</p>\n<ul>\n<li><p>A customer initiates a new checkout</p>\n</li>\n<li><p>A new payment attempt is required</p>\n</li>\n<li><p>You want to process a card payment using S2S integration</p>\n</li>\n<li><p>You need to support 2D or 3D Secure payment flows</p>\n</li>\n</ul>\n<p>Each payment session corresponds to one transaction attempt.</p>\n<h2 id=\"payment-session-flow\"><strong>Payment Session Flow</strong></h2>\n<ol>\n<li><p>Your server sends a request to the Create Purchase API with customer, product, and redirect details.</p>\n</li>\n<li><p>Paysecure validates the request and creates a new payment session.</p>\n</li>\n<li><p>A unique purchaseId is generated for the session.</p>\n</li>\n<li><p>The payment session remains in the CREATED state until payment details are submitted.</p>\n</li>\n<li><p>The purchaseId is used to continue the payment flow via S2S APIs.</p>\n</li>\n</ol>\n<h1 id=\"card-payments\"><strong>Card Payments</strong></h1>\n<p>Card payments enable customers to pay online using debit or credit cards issued by card networks such as Visa, Mastercard, and others. During a card payment , the customer’s card details are submitted securely and sent through the payment processor , card network, and issuing bank to determine whether the transaction can be authorized.</p>\n<h3 id=\"card-payment-checks-include\">Card payment checks include:</h3>\n<ul>\n<li><p>Card validity and available balance</p>\n</li>\n<li><p>Risk and fraud assessment</p>\n</li>\n<li><p>Authorization by the issuing bank</p>\n</li>\n</ul>\n<p>Depending on the security requirements, region, and risk profile, a card payment can be processed as either:</p>\n<ul>\n<li><p><strong>2D (Non-3DS) payment</strong></p>\n</li>\n<li><p><strong>3D Secure (3DS) payment</strong></p>\n</li>\n</ul>\n<h2 id=\"2d-non-3ds-payments\"><strong>2D (non-3DS) Payments</strong></h2>\n<p>2D payments are standard card transactions that do not include an additional cardholder authentication step by issuing bank. Authorization is based on the card details and internal risk checks performed by the payment processor and issuer.</p>\n<h3 id=\"2d-payment-flow\"><strong>2D Payment Flow</strong></h3>\n<ul>\n<li><p>The customer provide card details (card number, expiry, cvv)</p>\n</li>\n<li><p>The transaction is authorized or declined by the issuing bank</p>\n</li>\n<li><p>The customer is directly redirected to the final outcome URL</p>\n</li>\n</ul>\n<h3 id=\"characteristics\">Characteristics</h3>\n<ul>\n<li><p>Faster checkout experience</p>\n</li>\n<li><p>Lower protection against fraud and chargebacks</p>\n</li>\n<li><p>No callback URL generated</p>\n</li>\n<li><p>No 3D Secure authentication</p>\n</li>\n</ul>\n<h3 id=\"typical-use-case\"><strong>Typical Use Case</strong></h3>\n<ul>\n<li><p>Low-risk transactions</p>\n</li>\n<li><p>Trusted customers</p>\n</li>\n<li><p>Regions or scenarios where 3DS is not mandatory</p>\n</li>\n</ul>\n<h2 id=\"3d-secure-3ds-payments\"><strong>3D Secure (3DS) Payments</strong></h2>\n<p>3D secure (3DS) Payments add an extra layer of security by requiring the cardholder to be authenticated by issuing bank. This helps reduce fraud and protects merchants against certain types of chargebacks.</p>\n<h3 id=\"3ds-payment-flow\"><strong>3DS Payment Flow</strong></h3>\n<ul>\n<li><p>The transaction is evaluated by the card network and issuing bank</p>\n</li>\n<li><p>Based on risk assessment, the transaction proceeds through either a Frictionless or Challenge flow</p>\n</li>\n<li><p>After authentication, the transaction is authorized or declined</p>\n</li>\n<li><p>The customer is redirected to the appropriate URL</p>\n</li>\n</ul>\n<h2 id=\"3ds-authentication-flows\"><strong>3DS Authentication Flows</strong></h2>\n<h3 id=\"3d-secure-challenge-flow\"><strong>3D Secure Challenge Flow</strong></h3>\n<ul>\n<li><p>The customer is redirected to the issuer’s ACS (Access Control Server)</p>\n</li>\n<li><p>The cardholder must authenticate (OTP, biometric, or password)</p>\n</li>\n<li><p>After authentication, the customer is redirected to the appropriate URL</p>\n</li>\n</ul>\n<p>3DS payments provide higher security, better fraud prevention, and improved compliance with regulatory requirements such as PSD2 (Second Payment Service Directive).</p>\n<h3 id=\"3d-secure-frictionless-flow\"><strong>3D Secure Frictionless Flow</strong></h3>\n<ul>\n<li><p>No user interaction is required</p>\n</li>\n<li><p>Authentication is completed automatically in the background</p>\n</li>\n<li><p>The customer is directly redirected to the appropriate URL</p>\n</li>\n</ul>\n<h2 id=\"2d-vs-3d-secure---comparison-table\"><strong>2D vs 3D Secure - Comparison Table</strong></h2>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Feature</th>\n<th>2D (Non-3DS) Payments</th>\n<th>3D Secure (3DS) Payments</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Cardholder authentication</td>\n<td>Not required</td>\n<td>Required (Frictionless or Challenge)</td>\n</tr>\n<tr>\n<td>User interaction</td>\n<td>Not required</td>\n<td>Required only in Challenge flow</td>\n</tr>\n<tr>\n<td>Security level</td>\n<td>Standard</td>\n<td>High</td>\n</tr>\n<tr>\n<td>Fraud protection</td>\n<td>Limited</td>\n<td>Strong</td>\n</tr>\n<tr>\n<td>Chargeback liability shift</td>\n<td>No</td>\n<td>Yes (subject to scheme rules)</td>\n</tr>\n<tr>\n<td>Callback URL</td>\n<td>Not generated</td>\n<td>Generated when authentication is required</td>\n</tr>\n<tr>\n<td>Redirect handling</td>\n<td>Direct redirect to final URL</td>\n<td>Redirect after authentication</td>\n</tr>\n<tr>\n<td>Checkout speed</td>\n<td>Faster</td>\n<td>Slightly slower (Challenge flow only)</td>\n</tr>\n<tr>\n<td>Regulatory compliance</td>\n<td>Not always sufficient</td>\n<td>Helps meet PSD2 and similar regulations</td>\n</tr>\n<tr>\n<td>Typical use case</td>\n<td>Low-risk transactions</td>\n<td>Medium to high-risk transactions</td>\n</tr>\n</tbody>\n</table>\n</div><h1 id=\"required-configuration\"><strong>Required configuration</strong></h1>\n<p>To successfully create a payment session, the following must be provided:</p>\n<ul>\n<li><p>Customer information (name, email, location)</p>\n</li>\n<li><p>Purchase details (currency and products)</p>\n</li>\n<li><p>A valid brand_id</p>\n</li>\n<li><p>Redirect URLs to handle the final transaction outcome:</p>\n<ul>\n<li><p>success_redirect</p>\n</li>\n<li><p>pending_redirect</p>\n</li>\n<li><p>failure_redirect</p>\n</li>\n</ul>\n</li>\n</ul>\n<p>These redirect URLs are mandatory and are used later during 2D or 3D Secure flows.</p>\n<h2 id=\"redirect-handling\"><strong>Redirect Handling</strong></h2>\n<p>After successful background authentication, the user is redirected to one of the following URLs, which must be configured during the Purchase Creation step:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Redirect URL</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>success_redirect</td>\n<td>Payment completed successfully</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Payment is still under processing</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Payment failed or was declined</td>\n</tr>\n</tbody>\n</table>\n</div><p>The final redirect depends on the authorization and authentication outcome returned by the issuer.</p>\n<h1 id=\"api-used-for-card-payment\"><strong>API Used for Card Payment</strong></h1>\n<p>| <a href=\"https://docs.google.com/document/d/1MilHvtokUqxMGBXH63qgdYkHUJXuSr3f0_VPDkHtgdQ/edit?pli=1&amp;tab=t.1nd7mvcmvmby\"><b>POST /api/v1/purchases</b></a> |</p>\n<h2 id=\"step-1-transaction-initiation--create-a-purchase\">Step 1: Transaction Initiation – Create a Purchase</h2>\n<h3 id=\"overview\"><strong>Overview</strong></h3>\n<p>To begin a transaction, a Purchase must first be created in the system. This is done by initiating a purchase request that registers all required transaction details and prepares the system for further processing.</p>\n<p>This step applies equally to both 2D and non-2D transactions and follows the same flow regardless of transaction type.</p>\n<h3 id=\"purchase-creation-process\">Purchase Creation Process</h3>\n<ol>\n<li><p>A purchase is initiated by sending a POST request to the purchase creation endpoint ({baseURL}/purchase/).</p>\n</li>\n<li><p>During this step, the system validates the request and creates a Purchase record.</p>\n</li>\n<li><p>Once the Purchase is successfully created, the system generates a unique purchaseId, which is required for subsequent server-to-server operations.</p>\n</li>\n</ol>\n<h3 id=\"mandatory-redirect-urls\"><strong>Mandatory Redirect URLs</strong></h3>\n<p>To successfully create a Purchase, the following redirect URLs must be defined and must contain valid URLs:</p>\n<ul>\n<li><p>success_redirect<br />  Redirects the customer after a successful transaction.</p>\n</li>\n<li><p>pending_redirect<br />  Redirects the customer when the transaction remains in a pending or processing state.</p>\n</li>\n<li><p>failure_redirect<br />  Redirects the customer if the transaction fails.</p>\n</li>\n</ul>\n<h3 id=\"merchantref-merchant-reference\"><strong>merchantRef (Merchant Reference)</strong></h3>\n<p>Although not mandatory, the merchantRef parameter is strongly recommended for all merchants.</p>\n<h3 id=\"purpose-and-benefits\"><strong>Purpose and Benefits</strong></h3>\n<ol>\n<li><p><strong>Prevention of Duplicate Transactions</strong></p>\n<ul>\n<li><p>merchantRef acts as a unique merchant-defined reference.</p>\n</li>\n<li><p>If a subsequent purchase request is sent using the same merchantRef, the system identifies it as a duplicate and prevents accidental repeat transactions.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Transaction Retrieval and Recovery</strong></p>\n<ul>\n<li><p>If the purchase creation response times out or the purchaseId is not received,<br />  the merchant can use merchantRef to retrieve the corresponding transaction details.</p>\n</li>\n<li><p>This ensures reliable tracking and reconciliation even when immediate responses are unavailable.</p>\n</li>\n</ul>\n</li>\n</ol>\n<h3 id=\"system-behavior-without-merchantref\"><strong>System Behavior Without merchantRef</strong></h3>\n<ul>\n<li><p>If merchantRef is not provided, the platform automatically assigns an internal purchaseId.</p>\n</li>\n<li><p>This internally generated purchaseId then becomes the sole reference for that transaction.</p>\n</li>\n</ul>\n<h3 id=\"purchase-creation-outcome\"><strong>Purchase Creation Outcome</strong></h3>\n<ul>\n<li><p>On successful creation of a Purchase:</p>\n<ul>\n<li><p>The system returns a purchaseId.</p>\n</li>\n<li><p>This purchaseId uniquely identifies the transaction within the platform.</p>\n</li>\n</ul>\n</li>\n</ul>\n<h2 id=\"step-2-server-to-server-s2s-processing\"><strong>Step 2: Server-to-Server (S2S) Processing</strong></h2>\n<p>After receiving the purchaseId, merchants must proceed with the server-to-server (S2S) call using the following pattern:</p>\n<p>This call is required to continue processing the transaction securely on the server side.</p>\n<p>| <strong>p/{purchaseId}/?s2s=true</strong> |</p>\n<h2 id=\"step-3-transaction-flows-after-calling-callback_url\">Step 3: Transaction Flows After Calling callback_url</h2>\n<p>After the callback URL is invoked, the transaction can proceed through one of the following three flows:</p>\n<h3 id=\"3d-secure-challenge-flow-1\"><strong>3D Secure Challenge Flow</strong></h3>\n<ul>\n<li><p>The user is redirected to the ACS (Access Control Server) page of the issuing bank.</p>\n</li>\n<li><p>The cardholder is required to complete authentication (e.g., OTP, biometric, or password).</p>\n</li>\n<li><p>After successful or failed authentication, the user is redirected to one of the URLs configured during the Purchase Creation API:</p>\n<ul>\n<li><p>Success_redirect</p>\n</li>\n<li><p>Pending_redirect</p>\n</li>\n<li><p>failure_redirect</p>\n</li>\n</ul>\n</li>\n</ul>\n<p>The final redirect depends on the transaction outcome.</p>\n<h3 id=\"3d-secure-frictionless-flow-1\"><strong>3D Secure Frictionless Flow</strong></h3>\n<p>The 3D Secure Frictionless Flow is a streamlined authentication process where the cardholder does not need to perform any additional action. The authentication is completed automatically in the background based on risk assessment performed by the card network and the issuing bank.</p>\n<p>This flow is designed to deliver a fast and seamless checkout experience while still complying with 3D Secure regulations.</p>\n<h4 id=\"when-frictionless-flow-occurs\"><strong>When Frictionless Flow Occurs</strong></h4>\n<p>A transaction may qualify for the frictionless flow when:</p>\n<ul>\n<li><p>The transaction amount is considered low risk</p>\n</li>\n<li><p>The issuing bank trusts the merchant and transaction context</p>\n</li>\n<li><p>Accurate device and browser information is provided</p>\n</li>\n<li><p>The cardholder has a positive transaction history</p>\n</li>\n</ul>\n<p><strong>Note</strong>: The final decision to apply frictionless authentication is made solely by the issuing bank.</p>\n<p><strong>Important:</strong></p>\n<ul>\n<li><p>Calling the callback_url is mandatory for all transactions returning a 202 response.</p>\n</li>\n<li><p>All redirect URLs must be predefined during the Purchase Creation step.</p>\n</li>\n<li><p>Merchants should ensure proper handling of all three redirect outcomes to deliver a seamless user experience.</p>\n</li>\n</ul>\n<h1 id=\"operational-flow\"><strong>Operational Flow</strong></h1>\n<ol>\n<li><p>The merchant submits the card payment request using the Server-to-Server (S2S) API.</p>\n</li>\n<li><p>Paysecure sends the transaction details to the card network and issuing bank for 3D Secure evaluation.</p>\n</li>\n<li><p>The issuing bank determines that no challenge is required based on:</p>\n<ul>\n<li><p>Cardholder risk profile</p>\n</li>\n<li><p>Transaction amount</p>\n</li>\n<li><p>Device and browser data</p>\n</li>\n<li><p>Merchant trust level</p>\n</li>\n</ul>\n</li>\n<li><p>Authentication is successfully completed in the background without redirecting the user to an authentication (ACS) page.</p>\n</li>\n<li><p>Once authentication and authorization are completed, the user is automatically redirected to the appropriate URL configured during the Purchase Creation API.</p>\n</li>\n</ol>\n<h1 id=\"http-response-codes\"><strong>HTTP Response Codes</strong></h1>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Code</th>\n<th>Triggering Event</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>200</td>\n<td>Request processed successfully</td>\n</tr>\n<tr>\n<td>202</td>\n<td>Request accepted and processing is pending</td>\n</tr>\n<tr>\n<td>400</td>\n<td>Bad request – invalid data provided or required data is missing</td>\n</tr>\n<tr>\n<td>401</td>\n<td>Unauthorized request – invalid or missing authentication credentials</td>\n</tr>\n<tr>\n<td>404</td>\n<td>Resource or page not found</td>\n</tr>\n<tr>\n<td>405</td>\n<td>Method not allowed (unsupported HTTP method such as GET or POST)</td>\n</tr>\n<tr>\n<td>415</td>\n<td>Unsupported media type</td>\n</tr>\n<tr>\n<td>422</td>\n<td>Unprocessable content – required data is missing or invalid</td>\n</tr>\n<tr>\n<td>429</td>\n<td>Too many requests – rate limit exceeded</td>\n</tr>\n<tr>\n<td>500</td>\n<td>Internal server error</td>\n</tr>\n</tbody>\n</table>\n</div><p>Please see the <a href=\"https://\">Status Code</a> section for further details.</p>\n<p>If the response code is 202, upon receiving the response body, redirect the customer to the callback_url provided in the response.</p>\n<p>If the card requires 3D Secure verification, the user will be redirected to a verification or challenge screen by the card issuing bank. After successful user verification, the user will be redirected to the success URL provided in the <code>/purchase</code> API from Step 1.</p>\n<p>If, for any reason, the transaction is unsuccessful, the user will be redirected the failure URL provided in the /purchase API from Step 1.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"d020f0d7-6cbd-40c1-ba58-1e8b8bf80c3a","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"6d5bfdc1-4b21-4660-9cb2-95eed04e3400","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"4aab1160-21ae-40b9-b1a1-804a3cced1b7"},{"name":"APIs","item":[{"name":"Purchase","id":"429384e2-dc8c-4abf-8b1f-e48baf280311","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"bearer","bearer":{"basicConfig":[]},"isInherited":false},"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"example@paysecure.net\",\r\n        \"country\": \"IN\",\r\n        \"city\": \"123\",\r\n        \"stateCode\": \"ca\",\r\n        \"street_address\": \"test test\",\r\n        \"zip_code\": \"234567\",\r\n        \"phone\": \"+91 9999999999\"\r\n    },\r\n    \"purchase\": {\r\n        \"products\": [\r\n            {\r\n                \"name\": \"dk\",\r\n                \"price\": \"10\"\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"created\",\r\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e \",\r\n    \"merchantRef\": \"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>The customer's email.</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>purchase.products</td>\n<td>An object which contains the list of products which the customer is buying.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>The name of the product.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"essential-optional-parameters\">Essential Optional Parameters</h2>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<p>Upon successul create on a Purchase you'd get a <code>\"purchaseId\"</code> . Use this ID for the next step in Server to server call by calling <code>p/{purchaseId}/?s2s=true .</code></p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n</tr>\n<tr>\n<td>some Mandatory Parameter are missing</td>\n</tr>\n<tr>\n<td>Invalid format of Date_of_Birth [allowed format: yyyy-mm-dd]</td>\n</tr>\n<tr>\n<td>Invalid Email Format</td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n</tr>\n<tr>\n<td>Merchant Limit is not set</td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n</tr>\n<tr>\n<td>Brand not found !</td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n</tr>\n<tr>\n<td>Only {{currencyCode}} currency is allowed.</td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n</tr>\n<tr>\n<td>Invalid_Parameter  <br />You'd usually get it when one or more mandatory parameters are not present in the request.</td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"path":["purchases"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"2c161d24-e1ea-4c18-866e-bcddb1d03e21","name":"Purchase","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text","disabled":true}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"example@paysecure.net\",\r\n        \"country\": \"IN\",\r\n        \"city\": \"123\",\r\n        \"stateCode\": \"ca\",\r\n        \"street_address\": \"test test\",\r\n        \"zip_code\": \"234567\",\r\n        \"phone\": \"9999999999\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"product name\",\r\n                \"price\": \"10\"\r\n            }\r\n        ]\r\n    },\r\n    \"merchantRef\": \"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\r\n    \"status\": \"created\",\r\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e \",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Thu, 13 Jul 2023 17:22:14 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64b032c3c6dccf7d329d9e7e\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"dev@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1689268934,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1689268934,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 10,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 10,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1689268934\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"is_recurring_token\": false,\n    \"reference_generated\": \"PS161\",\n    \"merchantRef\":\"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\n    \"issued\": \"2023-07-13\",\n    \"due\": 1689268934,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64b032c3c6dccf7d329d9e7e/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64b032c3c6dccf7d329d9e7e/\"\n}"}],"_postman_id":"429384e2-dc8c-4abf-8b1f-e48baf280311"},{"name":"S2S","id":"7271ec81-a2ed-4e99-bc52-446f55e7c0a9","protocolProfileBehavior":{"disableBodyPruning":true,"disableUrlEncoding":false},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"cardholder_name\": \"dk\",\r\n    \"card_number\": \"4111111111111111\",\r\n    \"expires\": \"10/23\",\r\n    \"cvc\": \"345\",\r\n    \"remember_card\": \"on\",\r\n    \"remote_ip\": \"157.38.242.7\",\r\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\r\n    \"accept_header\": \"text/html\",\r\n    \"language\": \"en-US\",\r\n    \"java_enabled\": false,\r\n    \"javascript_enabled\": true,\r\n    \"color_depth\": 24,\r\n    \"utc_offset\": 0,\r\n    \"screen_width\": 1920,\r\n    \"screen_height\": 1080\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/p/64bff4fff63e36669499e9c8/?s2s=true","description":"<p>This API would be the 2nd in sequence to call if the call to <code>/purchases/</code> was successful in step 1. and you want to do the transaction via Server-to-Server mode.</p>\n<p>The request body would contain the details of the card that's to be transacted upon.</p>\n<h3 id=\"mandatory-parameters-in-request-body\"><strong>Mandatory parameters in request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>remote_ip</td>\n<td>IP address of the customer’s device used for transaction. Helps in fraud checks and risk scoring. Ex- 157.38.242.7</td>\n</tr>\n<tr>\n<td>user_agent</td>\n<td>Full browser and operating system details captured from HTTP header. EX- Chrome/5.0 (X11; Linux x86_64)</td>\n</tr>\n<tr>\n<td>accept_header</td>\n<td>Browser’s accepted content types (from HTTP header). Used for validating request origin and device info. EX- text/html</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong><br />If you want to use token_reference for doing a card transaction, please have a look at Network Tokenisation Section.</p>\n<h3 id=\"essential-parameters-in-request-body\"><strong>Essential parameters in request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>cardholder_name</td>\n<td>Name of the cardholder</td>\n</tr>\n<tr>\n<td>card_number</td>\n<td>The card numbers Must be 10-20 characters.</td>\n</tr>\n<tr>\n<td>expires</td>\n<td>must be greater than the current month/year.</td>\n</tr>\n<tr>\n<td>cvc</td>\n<td>3 or 4 digit</td>\n</tr>\n</tbody>\n</table>\n</div><p>**<br />Other optional parameters in request body:**</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>language</td>\n<td>Preferred language of the user’s browser . EX - en-US</td>\n</tr>\n<tr>\n<td>java_enabled</td>\n<td>Indicates if Java is enabled in the browser. Helps PSPs in device profiling. Ex- true/false</td>\n</tr>\n<tr>\n<td>javascript_enabled</td>\n<td>Indicates if JavaScript is enabled in the client browser. Used for 3DS or risk-based checks. Ex- true</td>\n</tr>\n<tr>\n<td>color_depth</td>\n<td>Bit depth of the display screen. Ex- 24</td>\n</tr>\n<tr>\n<td>utc_offset</td>\n<td>Difference in minutes between local time and UTC. Used for location and timezone checks. Ex- 330</td>\n</tr>\n<tr>\n<td>screen_width</td>\n<td>Width of the device screen in pixels. Used in device profiling. Ex- 1920</td>\n</tr>\n<tr>\n<td>screen_height</td>\n<td>Height of the device screen in pixels. Ex- 1080</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"successful-response\">Successful Response</h3>\n<p>If all the details are correct you'll get a 202 response with staus as Pending</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"status\": \"pending\",\n    \"callback_url\": \"https://paysecure.net/payment/63bd0bf80fb42a076e8a4dd1/\",\n    \"method\": \"GET\"\n}\n\n</code></pre>\n<p>If the response code is 202, after receiving the response body, direct the customer to the callback_url provided in the response.</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Client Ip could not be matched with Merchant Ip</td>\n</tr>\n<tr>\n<td>Invalid Card Information</td>\n</tr>\n<tr>\n<td>Card is Blocked</td>\n</tr>\n<tr>\n<td>Different Type of key used to create purchase and payment</td>\n</tr>\n<tr>\n<td>You charges setting is incomplete .Plese Contact to adminstrartor.</td>\n</tr>\n<tr>\n<td>Allowed Attempt for this Transaction has been consumed</td>\n</tr>\n<tr>\n<td>Invalid Card Expiry(Valid Format:MM/YY) must be greator than current month/year</td>\n</tr>\n<tr>\n<td>Customer profile is Blocked</td>\n</tr>\n<tr>\n<td>Customer/Card not allowed for transaction</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"b20ed466-3953-4fdc-88ca-adb9afe12944","id":"b20ed466-3953-4fdc-88ca-adb9afe12944","name":"APIs","type":"folder"}},"urlObject":{"path":["p","64bff4fff63e36669499e9c8",""],"host":["https://api.paysecure.net/api/v1"],"query":[{"key":"s2s","value":"true"}],"variable":[]}},"response":[{"id":"d1d1dfc1-063d-4b80-ae8a-00d9431205b4","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"cardholder_name\": \"dk\",\r\n    \"card_number\": \"411111111111111\",\r\n    \"expires\": \"10/23\",\r\n    \"cvc\": \"345\",\r\n    \"remember_card\": \"on\",\r\n    \"remote_ip\": \"157.38.242.7\",\r\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\r\n    \"accept_header\": \"text/html\",\r\n    \"language\": \"en-US\",\r\n    \"java_enabled\": false,\r\n    \"javascript_enabled\": true,\r\n    \"color_depth\": 24,\r\n    \"utc_offset\": 0,\r\n    \"screen_width\": 1920,\r\n    \"screen_height\": 1080\r\n}","options":{"raw":{"language":"json"}}},"url":{"raw":"https://api.paysecure.net/api/v1/p/64bff4fff63e36669499e9c8/?s2s=true","host":["https://api.paysecure.net/api/v1"],"path":["p","64bff4fff63e36669499e9c8",""],"query":[{"key":"s2s","value":"true"}]}},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Thu, 13 Jul 2023 17:31:55 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"status\": \"pending\",\n    \"callback_url\": \"http://18.214.100.20/api/v1/payment/64b034ecc6dccf7d329d9eb3/\",\n    \"method\": \"GET\"\n}"},{"id":"3e8ea4ba-cf41-42ab-9ff0-1c5455fae76b","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"cardholder_name\": \"dk\",\r\n    \"card_number\": \"4111111111111111\",\r\n    \"expires\": \"10/23\",\r\n    \"cvc\": \"345\",\r\n    \"remember_card\": \"on\",\r\n    \"remote_ip\": \"157.38.242.7\",\r\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\r\n    \"accept_header\": \"text/html\",\r\n    \"language\": \"en-US\",\r\n    \"java_enabled\": false,\r\n    \"javascript_enabled\": true,\r\n    \"color_depth\": 24,\r\n    \"utc_offset\": 0,\r\n    \"screen_width\": 1920,\r\n    \"screen_height\": 1080\r\n}","options":{"raw":{"language":"json"}}},"url":{"raw":"https://api.paysecure.net/api/v1/p/64bff4fff63e36669499e9c8/?s2s=true","host":["https://api.paysecure.net/api/v1"],"path":["p","64bff4fff63e36669499e9c8",""],"query":[{"key":"s2s","value":"true"}]}},"status":"Unauthorized","code":401,"_postman_previewlanguage":null,"header":[{"key":"Date","value":"Tue, 06 Jan 2026 05:57:10 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"cc434220-0bcd-42c7-9078-53503b81a221"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 9bce423254194c16408d5cf7234126e2.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"FgTt6KEGIk0CH79DQDOvB1tYb1pGfaz0ryIVmQ0CCpDShyhsJGuAkA=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=9SnHJOEjnd1y7hArGsRLWmrk8H9ExaiR%2Fc%2BQMWhAvHlNPYCNEjS60wTjIyODXpca0ZD9%2BalkhLJ63boMGg%2B8iI6eFtXfW%2BxwGaBP1p1ZcwpA\"}]}"},{"key":"CF-RAY","value":"9b98f9f4684505e7-IAD"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Authorization header missing\",\n    \"code\": \"authentication_failed\"\n}"}],"_postman_id":"7271ec81-a2ed-4e99-bc52-446f55e7c0a9"},{"name":"Payment (To be initiated From client browser)","id":"d658d8ee-d1c6-48b2-a821-629ffc2dc3f3","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[],"url":"{{Production}}/payment/64bff12bf63e36669499e97d/","description":"<p>This is the callback URL that is in the response object ofthe Server-to-Server Call</p>\n<p>When this URL is called from the end user's browser, the user would be redirected to the <code>success_redirect</code> or <code>failure_redirect</code> URL given by the merchant at the time of create purchase</p>\n<p>When this URL is called from the end user's browser, if card is 3DS enrolled, the user user will be redirect to a verification screen or challenge by the issuing bank and upon successful user verification, the user would be redictected to the success URL given in <code>/purchases API</code> .</p>\n<p>If for some reason the transactions is unsuccessful, the user will be redirect to failure URL given in <code>/purchases API</code> API .</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"b20ed466-3953-4fdc-88ca-adb9afe12944","id":"b20ed466-3953-4fdc-88ca-adb9afe12944","name":"APIs","type":"folder"}},"urlObject":{"path":["payment","64bff12bf63e36669499e97d",""],"host":["{{Production}}"],"query":[],"variable":[]}},"response":[{"id":"6727f06a-a05b-4ae8-bad1-c306592d4222","name":"Payment-error","originalRequest":{"method":"GET","header":[],"url":"{{StagingBaseURL}}/payment/64bfd7c9f63e36669499e779/"},"status":"Bad Request","code":400,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 14:12:18 GMT"},{"key":"Connection","value":"close"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Only purchases that can be paid for can be initiated for payment.\",\n    \"code\": \"transaction_error\"\n}"}],"_postman_id":"d658d8ee-d1c6-48b2-a821-629ffc2dc3f3"},{"name":"Get Status","id":"48bac3b4-766e-4090-8873-836c32c6f33e","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/64bff12bf63e36669499e97d/","description":"<p>This API tells you about all the details of a purchase, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>created</td>\n<td>When Purchase order is created.</td>\n</tr>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>chargeback</td>\n<td>Payment is chargeback state</td>\n</tr>\n<tr>\n<td>refund_in_process</td>\n<td>Refund is under Processing.</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>overdue</td>\n<td>Purchase is Overdued.</td>\n</tr>\n<tr>\n<td>cancelled</td>\n<td>Purchase is cancelled.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n<tr>\n<td>refunded</td>\n<td>Payment is refunded</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"b20ed466-3953-4fdc-88ca-adb9afe12944","id":"b20ed466-3953-4fdc-88ca-adb9afe12944","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","64bff12bf63e36669499e97d",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"54d811fe-79e1-4eb3-ab7f-acd161cfc9c2","name":"Purchases-error","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"}],"url":"http://18.214.100.20/api/v1/purchases/64bfd7c9f63e36669499e779/"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 15:44:06 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfd7c9f63e36669499e779\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690294251,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690294220,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 100,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 100,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 100,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": false,\n                \"country\": \"US\",\n                \"processing_time\": 1690294279,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 100,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                },\n                \"error\": {\n                    \"message\": \"Transaction Failed\",\n                    \"code\": \"transaction_error\"\n                }\n            }\n        ]\n    },\n    \"status\": \"ERROR\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1690294220\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1690294251\n        },\n        {\n            \"status\": \"error\",\n            \"timestamp\": 1690294299\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1690294382\n        }\n    ],\n    \"viewedOn\": 1690299845,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS188\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690294220,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfd7c9f63e36669499e779/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfd7c9f63e36669499e779/\"\n}"},{"id":"d8f81910-d8af-493c-8d49-e54419301af3","name":"Purchases - success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"}],"url":"http://18.214.100.20/api/v1/purchases/64bfdb7df63e36669499e82f/"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 15:45:29 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfdb7df63e36669499e82f\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690296521,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690295168,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 9,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 9,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 9,\n        \"currency\": \"USD\",\n        \"net_amount\": 9,\n        \"fee_amount\": 10.2591,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1690295205,\n        \"remote_paid_on\": 1690295205\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 9,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"US\",\n                \"processing_time\": 1690295205,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 9,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1690295168\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1690295193\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1690295205\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1690296521\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1690299929\n        }\n    ],\n    \"viewedOn\": 1690299929,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"merchantRef\":\"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS192\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690295168,\n    \"refund_upto\": 1705843623,\n    \"cc_descriptor\": \"test-cardeye\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 9,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfdb7df63e36669499e82f/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfdb7df63e36669499e82f/\"\n}"}],"_postman_id":"48bac3b4-766e-4090-8873-836c32c6f33e"},{"name":"Refund","id":"9ee22f65-a8d6-490c-841f-ba7051d0aef0","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund","description":"<p>This API is used to initate refund of the purchases that have status as <code>PAID</code> can be initiated for refund</p>\n<p>Once the refund has been initiated, the status of the purchase would become <code>REFUND_IN_PROCESS</code> and once the refund has been approved by the bank, the status woud become <code>REFUNDED</code></p>\n<p>Purchase ID is <strong>mandatory</strong> for this API.</p>\n<p>Currently we don't support partial refunds.</p>\n<h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>successful</code> and <code>unsuccessful</code> in refund of purchases.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"b20ed466-3953-4fdc-88ca-adb9afe12944","id":"b20ed466-3953-4fdc-88ca-adb9afe12944","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","657af976c3fceb7beb30eeb4","refund"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"c313ee79-4b7a-4f98-8de5-1729060d7cba","name":"Refund - Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 16:33:43 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfdb7df63e36669499e82f\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690302819,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690295168,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 9,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 9,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 9,\n        \"currency\": \"USD\",\n        \"net_amount\": 9,\n        \"fee_amount\": 10.2591,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1690295205,\n        \"remote_paid_on\": 1690295205\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 9,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"US\",\n                \"processing_time\": 1690295205,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 9,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                }\n            },\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"refund\",\n                \"successful\": true,\n                \"processing_time\": 1690302819,\n                \"extra\": {\n                    \"amount\": 9\n                }\n            }\n        ]\n    },\n    \"status\": \"REFUNDED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1765294731\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1765294744\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1765294754\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1765297331\n        },\n        {\n            \"status\": \"refunded\",\n            \"timestamp\": 1765624009\n        }\n    ],\n    \"viewedOn\": 1690299929,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS192\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690295168,\n    \"refund_upto\": 1705843623,\n    \"cc_descriptor\": \"test-cardeye\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfdb7df63e36669499e82f/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfdb7df63e36669499e82f/\"\n}"},{"id":"1959d625-2c78-422b-ac24-c9fcb259f201","name":"Refund - Pending","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 16:33:43 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfdb7df63e36669499e82f\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690302819,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690295168,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 9,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 9,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 9,\n        \"currency\": \"USD\",\n        \"net_amount\": 9,\n        \"fee_amount\": 10.2591,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1690295205,\n        \"remote_paid_on\": 1690295205\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 9,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"US\",\n                \"processing_time\": 1690295205,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 9,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                }\n            },\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"refund\",\n                \"successful\": true,\n                \"processing_time\": 1690302819,\n                \"extra\": {\n                    \"amount\": 9\n                }\n            }\n        ]\n    },\n    \"status\": \"REFUND_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1690295168\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1690295193\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1690295205\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1690296521\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1690299929\n        },\n        {\n            \"status\": \"refund_in_process\",\n            \"timestamp\": 1690302819\n        }\n    ],\n    \"viewedOn\": 1690299929,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS192\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690295168,\n    \"refund_upto\": 1705843623,\n    \"cc_descriptor\": \"test-cardeye\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfdb7df63e36669499e82f/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfdb7df63e36669499e82f/\"\n}"},{"id":"4e09fa00-6522-4691-ac58-443149f05c6d","name":"Refund - Error","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund"},"status":"Bad Request","code":400,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Thu, 13 Jul 2023 17:49:58 GMT"},{"key":"Connection","value":"close"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Only Purchases with `status == (paid)` can be refunded.\",\n    \"code\": \"transaction_error\"\n}"}],"_postman_id":"9ee22f65-a8d6-490c-841f-ba7051d0aef0"},{"name":"Payment Methods","id":"f40af532-1504-4e24-9e5d-1f28a5a72a38","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/payment_methods?brand_id=aff0471b-e37d-4e76-9dee-d235063bf276","description":"<p>This API gives back the list of Payment methods available for a brand.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"b20ed466-3953-4fdc-88ca-adb9afe12944","id":"b20ed466-3953-4fdc-88ca-adb9afe12944","name":"APIs","type":"folder"}},"urlObject":{"path":["payment_methods"],"host":["https://api.paysecure.net/api/v1"],"query":[{"key":"brand_id","value":"aff0471b-e37d-4e76-9dee-d235063bf276"}],"variable":[]}},"response":[{"id":"d3f30024-040d-4aff-acc5-ed69055ead86","name":"Payment Methods - Error","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":{"raw":"https://api.paysecure.net/api/v1/payment_methods?brand_id=aff0471b-e37d-4e76-9dee-d235063bf276","host":["https://api.paysecure.net/api/v1"],"path":["payment_methods"],"query":[{"key":"brand_id","value":"aff0471b-e37d-4e76-9dee-d235063bf276"}]}},"status":"Unauthorized","code":401,"_postman_previewlanguage":null,"header":[{"key":"Date","value":"Thu, 07 Aug 2025 10:48:58 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-Xss-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 1e5d213252e38a8aa2e2a927fd3c3754.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD55-P8"},{"key":"X-Amz-Cf-Id","value":"Uv3p02pbXBomVNE_FH3o2ezRXrqvTAr9etg7HAKsVUuUi_8Gvf-ecg=="},{"key":"Cf-Cache-Status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=%2BlRerjanFZR0Fh4fFP1DM51iCxavbwesIYz%2FiBfbqbOF5YopeuJBxoMy5kdhHS3%2B%2FyNAacKQzKUv%2FzyXT4gfSV78ugg1iMBiIlmatHtRFg%3D%3D\"}]}"},{"key":"CF-RAY","value":"96b63463da73093a-IAD"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"_all_\": [\n        {\n            \"message\": \"Authorization header missing\",\n            \"code\": \"authentication_failed\"\n        }\n    ]\n}"},{"id":"d4a36142-e88d-4c1c-97b3-4a451681b304","name":"Payment Method- Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":{"raw":"https://api.paysecure.net/api/v1/payment_methods?brand_id=555c458b-e737-4905-adb2-2451d37cbb","host":["https://api.paysecure.net/api/v1"],"path":["payment_methods"],"query":[{"key":"brand_id","value":"555c458b-e737-4905-adb2-2451d37cbb"}]}},"status":"Accepted","code":202,"_postman_previewlanguage":null,"header":[{"key":"Date","value":"Tue, 09 Sep 2025 08:04:28 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=PoGnHzy1YxgyVIthM1PXA54R6F7GXZydfD3kEWXJ%2BfS8vqK1BSV2kQ7%2FcLQCX%2FyIPxxfOymqmqTum2vAWfB9UeDg9tjww39Rt9OJVyQrrwNtZZaWMA%3D%3D\"}]}"},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"CF-RAY","value":"97c52ccb09290668-IAD"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"available_payment_methods\": [\n        \"MASTER\",\n        \"visa\",\n        \"jcb\",\n        \"amex\",\n        \"CRYPTO-BRIDGE\",\n        \"FawryPay\",\n        \"INTERAC-E-TRANSFER\",\n        \"INTERAC-REQUEST-MONEY\",\n        \"MOBILEMONEY\",\n        \"NEOSURF\",\n        \"PAYID\",\n        \"PIX\",\n        \"SPEI\",\n        \"THIRDPARTY-UPI\",\n        \"discover\",\n        \"BANKTRANSFER\",\n        \"VIRTUAL-IBAN\",\n        \"UPI-COLLECT\",\n        \"UPI-QR\",\n        \"VIRTUAL-ACCOUNT\",\n        \"DINERS\",\n        \"NETBANKING\"\n    ],\n    \"by_country\": {\n        \"any\": [\n            \"MASTER\",\n            \"VISA\",\n            \"JCB\",\n            \"AMEX\",\n            \"CRYPTO-BRIDGE\",\n            \"FawryPay\",\n            \"INTERAC-E-TRANSFER\",\n            \"INTERAC-REQUEST-MONEY\",\n            \"MOBILEMONEY\",\n            \"NEOSURF\",\n            \"PAYID\",\n            \"PIX\",\n            \"SPEI\",\n            \"THIRDPARTY-UPI\",\n            \"DISCOVER\",\n            \"BANKTRANSFER\",\n            \"VIRTUAL-IBAN\",\n            \"UPI-COLLECT\",\n            \"UPI-QR\",\n            \"VIRTUAL-ACCOUNT\",\n            \"DINERS\",\n            \"NETBANKING\"\n        ]\n    },\n    \"country_names\": {\n        \"any\": \"Other\"\n    },\n    \"names\": {\n        \"NETBANKING\": \"NETBANKING\",\n        \"AMEX\": \"AMEX\",\n        \"MASTER\": \"Mastercard\",\n        \"CRYPTO-BRIDGE\": \"CRYPTO-BRIDGE\",\n        \"PAYID\": \"PAYID\",\n        \"SPEI\": \"SPEI\",\n        \"DISCOVER\": \"DISCOVER\",\n        \"JCB\": \"JCB\",\n        \"VISA\": \"Visa\",\n        \"NEOSURF\": \"NEOSURF\",\n        \"INTERAC-E-TRANSFER\": \"INTERAC-E-TRANSFER\",\n        \"THIRDPARTY-UPI\": \"THIRDPARTY-UPI\",\n        \"VIRTUAL-IBAN\": \"VIRTUAL-IBAN\",\n        \"BANKTRANSFER\": \"BANKTRANSFER\",\n        \"DINERS\": \"DINERS\",\n        \"INTERAC-REQUEST-MONEY\": \"INTERAC-REQUEST-MONEY\",\n        \"UPI-COLLECT\": \"UPI-COLLECT\",\n        \"UPI-QR\": \"UPI-QR\",\n        \"MOBILEMONEY\": \"MOBILEMONEY\",\n        \"FawryPay\": \"FawryPay\",\n        \"VIRTUAL-ACCOUNT\": \"VIRTUAL-ACCOUNT\",\n        \"PIX\": \"PIX\"\n    },\n    \"card_methods\": [\n        \"MASTER\",\n        \"VISA\",\n        \"JCB\",\n        \"AMEX\",\n        \"DISCOVER\"\n    ]\n}"}],"_postman_id":"f40af532-1504-4e24-9e5d-1f28a5a72a38"},{"name":"Cancel","id":"9e48f345-0405-45b3-bf07-578aeea9d6d5","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/64bff556f63e36669499e9d3/cancel","description":"<p>Cancels an in-progress or completed purchase transaction, preventing further processing or reversing the authorization hold. Use this endpoint to void a transaction that has not yet been settled to the merchant's account.</p>\n<p><strong>When to use:</strong></p>\n<ul>\n<li><p><strong>Post-creation cancellation:</strong> Cancel a purchase immediately after it has been created via the Purchase API, before the customer completes the payment flow.</p>\n</li>\n<li><p><strong>Pre-redirect cancellation:</strong> Cancel a transaction after completing the server-to-server (S2S) call but before redirecting the cardholder to the <code>callbackURL</code>. This is useful when your backend validation logic determines the transaction should not proceed (e.g., inventory check failure, fraud flag, duplicate order detection).</p>\n</li>\n</ul>\n<p>Purchase ID is <strong>mandatory</strong> for this API.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"b20ed466-3953-4fdc-88ca-adb9afe12944","id":"b20ed466-3953-4fdc-88ca-adb9afe12944","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","64bff556f63e36669499e9d3","cancel"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"7cc84969-d533-4f2d-9834-03740525a050","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"}],"url":"http://18.214.100.20/api/v1/purchases/64bff4fff63e36669499e9c8/cancel"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 16:15:35 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bff4fff63e36669499e9c8\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690301735,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690301698,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 9,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 9,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CANCELLED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1690301698\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1690301723\n        },\n        {\n            \"status\": \"cancelled\",\n            \"timestamp\": 1690301735\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS194\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690301698,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bff4fff63e36669499e9c8/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bff4fff63e36669499e9c8/\"\n}"},{"id":"a5dc9e6f-f79f-468c-a966-4a8b930e1d6d","name":"Error","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"}],"url":"http://18.214.100.20/api/v1/purchases/64b034ecc6dccf7d329d9eb3/cancel"},"status":"Bad Request","code":400,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Thu, 13 Jul 2023 17:45:30 GMT"},{"key":"Connection","value":"close"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Only purchases that can be paid for can be canceled.\",\n    \"code\": \"transaction_error\"\n}"}],"_postman_id":"9e48f345-0405-45b3-bf07-578aeea9d6d5"},{"name":"checkWhiteList","id":"3661bb05-88f3-4973-b894-1aafacab72b5","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n    \"email\": \"dev@paysecure.net\",\r\n    \"card_num\": \"5178006985381351\"\r\n  //  \"signup_date\": \"16-05-2023\",  not requered\r\n  //  \"deposit_date\": \"16-05-2023\",\r\n   // \"number_of_deposits\": 6,\r\n   \r\n        \r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/checkWhiteList","description":"<h3 id=\"overview\">Overview</h3>\n<p>Paysecure supports the concept of whitelisted cards. The merchant can send PaySecure a list of cards that are to be whitelisted. Once whitelisted, only whitelisted cards are allowed to be transacted for that merchant.</p>\n<p>The merchant can check the individual card status with this API by giving the email and card numbers of the customers.</p>\n<h3 id=\"mandatory-parameters-in-body\">Mandatory Parameters (in body)</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameters</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>email</td>\n</tr>\n<tr>\n<td>card_num</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"other-parameters\">Other parameters:</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameters</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>signup_date</td>\n</tr>\n<tr>\n<td>deposit_date</td>\n</tr>\n<tr>\n<td>number_of_deposits</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples, you can observe both instances of verifying whether a card exists in a merchant's whitelist, one for an existing card and another for a non-existing card.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"b20ed466-3953-4fdc-88ca-adb9afe12944","id":"b20ed466-3953-4fdc-88ca-adb9afe12944","name":"APIs","type":"folder"}},"urlObject":{"path":["checkWhiteList"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"69d10589-7699-4772-9e5b-c3f5fb3f1540","name":"checkWhiteList - Doesn't exists","originalRequest":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n      \"email\": \"dk6@dk.com\",\r\n  //  \"signup_date\": \"16-05-2023\",\r\n  //  \"deposit_date\": \"16-05-2023\",\r\n   // \"number_of_deposits\": 6,\r\n       \"card_num\": \"5555555555554444\"\r\n}","options":{"raw":{"language":"json"}}},"url":"http://18.214.100.20/api/v1/checkWhiteList"},"status":"OK","code":200,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Content-Length","value":"23"},{"key":"Date","value":"Thu, 13 Jul 2023 17:56:25 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"NOTEXIST\"\n}"},{"id":"f537eb10-75f2-4e44-beee-95e5aa5284c1","name":"checkWhiteList - Exists","originalRequest":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n    \"email\": \"dev@paysecure.net\",\r\n    \"card_num\": \"5178006985381351\"\r\n  //  \"signup_date\": \"16-05-2023\",  not requered\r\n  //  \"deposit_date\": \"16-05-2023\",\r\n   // \"number_of_deposits\": 6,\r\n   \r\n        \r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/checkWhiteList"},"status":"OK","code":200,"_postman_previewlanguage":"json","header":[{"key":"Date","value":"Tue, 25 Jul 2023 13:19:38 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Content-Length","value":"20"},{"key":"Connection","value":"keep-alive"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"X-Cache","value":"Miss from cloudfront"},{"key":"Via","value":"1.1 fe4c2207fc59dd7aa34d5b9c9e7bef06.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"LHR62-C4"},{"key":"X-Amz-Cf-Id","value":"jlhkO3uk9ZosIKb3n8d5UGa0s_yk0g6ZgyZwca4NrvzFfMpnXkSwnA=="},{"key":"CF-Cache-Status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"endpoints\":[{\"url\":\"https:\\/\\/a.nel.cloudflare.com\\/report\\/v3?s=19ICPHCEH52J%2B2gKwR6R65hkypRr9yFP63OeSZ7qaZZOzI7pQC0g67Hgv9iDno43u0razeIYgP0%2FJL8kYiAUCElFZeVnd94rYn%2BYqHXKtJDt5yItEDTYHOmHjNCc2Qbs7fyu5w%3D%3D\"}],\"group\":\"cf-nel\",\"max_age\":604800}"},{"key":"NEL","value":"{\"success_fraction\":0,\"report_to\":\"cf-nel\",\"max_age\":604800}"},{"key":"Server","value":"cloudflare"},{"key":"CF-RAY","value":"7ec4b216b9a606f1-LHR"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"EXIST\"\n}"}],"_postman_id":"3661bb05-88f3-4973-b894-1aafacab72b5"},{"name":"Whitelist Upload","id":"7d62055b-b9f6-47ac-92bc-f56ffda0be7d","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"POST","header":[],"body":{"mode":"formdata","formdata":[{"key":"csvFile","type":"file","fileNotInWorkingDirectoryWarning":"This file isn't in your working directory. Teammates you share this request with won't be able to use this file. To make collaboration easier you can setup your working directory in Settings.","filesNotInWorkingDirectory":["/C:/Users/HP/Desktop/Important/upladingfile/merchantwhitlist.csv"],"value":null}]},"url":"https://api.paysecure.net/api/v1/whitelist/upload/","description":"<h3 id=\"overview\">Overview</h3>\n<p>The merchant can upload a list of whitelist cards and email ids through this API. All cards successfully uploaded will be considered whitelisted and allowed for that merchant.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\">Mandatory parameters in the request body:</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Notes</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>csvFile</td>\n<td>Upload a CSV file</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Please note:</strong></p>\n<ol>\n<li><p>CSV file should contain the following headers (both mandatory)</p>\n<ol>\n<li><p>card_number</p>\n</li>\n<li><p>email_id</p>\n</li>\n</ol>\n</li>\n<li><p>CSV file should not be empty</p>\n</li>\n</ol>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-java\">public class FileUploader {\n    public static void uploadFile(String apiUrl, String filePath, String authorizationHeader) {\n        try {\n            File file = new File(filePath);\n            OkHttpClient client = new OkHttpClient();\n            RequestBody requestBody = new MultipartBody.Builder().setType(MultipartBody.FORM)\n                    .addFormDataPart(\"csvFile\", file.getName(), RequestBody.create(MediaType.parse(\"text/csv\"), file))\n                    .build();\n            Request request = new Request.Builder().url(apiUrl).post(requestBody)\n                    .addHeader(\"Authorization\", authorizationHeader).build();\n            Response response = client.newCall(request).execute();\n            if (response.code() == 202) {\n                System.out.println(\"File uploaded successfully!\");\n                System.out.println(\"Response: \" + response.body().string());\n            } else {\n                System.out.println(\"File upload failed.\");\n                System.out.println(\"Status: \" + response.code());\n                System.out.println(\"Error: \" + response.body().string());\n            }\n        } catch (IOException e) {\n            e.printStackTrace();\n        }\n    }\n    public static void main(String[] args) {\n        String apiUrl = \"https://{{base_url}}/api/v1/whitelist/upload\";\n        String filePath = \"whitelist.csv.file.path\";\n        String authorizationHeader = \"Bearer YOUR API KEY\";\n        uploadFile(apiUrl, filePath, authorizationHeader);\n    }\n}\n\n</code></pre>\n","urlObject":{"protocol":"https","path":["api","v1","whitelist","upload",""],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"0a871ada-3452-4205-8e72-64e65751a6bd","name":"Whitelist Upload success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"multipart/form-data; boundary=<calculated when request is sent>","disabled":true}],"body":{"mode":"formdata","formdata":[{"key":"csvFile","type":"file","fileNotInWorkingDirectoryWarning":"This file isn't in your working directory. Teammates you share this request with won't be able to use this file. To make collaboration easier you can setup your working directory in Settings.","filesNotInWorkingDirectory":["/C:/Users/HP/Desktop/Important/upladingfile/merchantwhitlist.csv"],"value":null}]},"url":"https://api.paysecure.net/api/v1/whitelist/upload/"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"Date","value":"Fri, 14 Jun 2024 09:10:47 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Frame-Options","value":"SAMEORIGIN"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"CF-Cache-Status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"endpoints\":[{\"url\":\"https:\\/\\/a.nel.cloudflare.com\\/report\\/v4?s=bIgUFhs3TU2505qZe4IpSLiaJtI2gsplNDvsVWdKl76AWQdcisezEHOW6t%2BxTCj%2Bxs%2B23gnSeMCWrqwG0CYQONFHXhXb9ZHNtIYMuHWzvjLhVEChIX%2BYpODoLqzs9OP4r5q%2F9ABSXBs%3D\"}],\"group\":\"cf-nel\",\"max_age\":604800}"},{"key":"NEL","value":"{\"success_fraction\":0,\"report_to\":\"cf-nel\",\"max_age\":604800}"},{"key":"Server","value":"cloudflare"},{"key":"CF-RAY","value":"893930730b8b0c3f-MRS"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"totalRecords\": 3,\n    \"totalApproved\": 3,\n    \"status\": \"success\"\n}"},{"id":"7114a62d-95dd-4dec-8d63-62b885ff1bb7","name":"Whitelist Upload failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"multipart/form-data; boundary=<calculated when request is sent>","disabled":true}],"body":{"mode":"formdata","formdata":[{"key":"csvFile","type":"file","fileNotInWorkingDirectoryWarning":"This file isn't in your working directory. Teammates you share this request with won't be able to use this file. To make collaboration easier you can setup your working directory in Settings.","filesNotInWorkingDirectory":["/C:/Users/HP/Desktop/Important/upladingfile/merchantwhitlist.csv"],"value":null}]},"url":"https://api.paysecure.net/api/v1/whitelist/upload/"},"status":"Unauthorized","code":401,"_postman_previewlanguage":"json","header":[{"key":"Date","value":"Fri, 14 Jun 2024 09:11:50 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Frame-Options","value":"SAMEORIGIN"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"CF-Cache-Status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"endpoints\":[{\"url\":\"https:\\/\\/a.nel.cloudflare.com\\/report\\/v4?s=9tel4sXa6ymyhRDTyNC%2B%2Bg2Msz1MivhgHbawlLF7JvTAgfonvRaas8MQeMtVVK95cziZLoZUKaThXJOAAeZW6iZ6fqlK5flpZjGxKwInEyKzZJr9JLDSQbNt5Um%2BK4zdbMZfkHV2seg%3D\"}],\"group\":\"cf-nel\",\"max_age\":604800}"},{"key":"NEL","value":"{\"success_fraction\":0,\"report_to\":\"cf-nel\",\"max_age\":604800}"},{"key":"Server","value":"cloudflare"},{"key":"CF-RAY","value":"893931f998280c3f-MRS"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Authorization header missing\",\n    \"code\": \"authentication_failed\",\n    \"status\": \"fail\"\n}"}],"_postman_id":"7d62055b-b9f6-47ac-92bc-f56ffda0be7d"},{"name":"PayOut","id":"3065075c-9f4e-401e-ba84-180bc403b02e","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"rahul@gmail.com\",\n        \"country\": \"GB\",\n        \"city\": \"London\",\n        \"stateCode\": \"QLD\",\n        \"full_name\": \"Rahul Jain\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"zip_code\": \"W1S 3BE\",\n        \"phone\": \"+44 9876543210\",\n        \"gender\": \"M\",\n        \"date_of_birth\": \"1970-07-10\"\n    },\n    \"purpose\": \"Testing cards payout\",\n    \"currency\": \"GBP\",\n    \"merchantRef\": \"YOUR ORDER ID\", // optional\n    \"payoutMethod\": \"PAYOUT-CARDS\",\n    \"amount\": 100.0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"extraParam\": {\n        \"cardNumber\": \"5431240006334004\",\n        \"cardHolderName\": \"Rahul Agarwal\",\n        \"expiryYear\": \"2030\",\n        \"expiryMonth\": \"11\"\n    }\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<h2 id=\"overview\">Overview</h2>\n<p>The <strong>Original Credit Transaction (OCT)</strong>, commonly referred to as <strong>Push to Card</strong>, enables merchants to facilitate near-instantaneous fund transfers directly to a customer’s eligible Visa or Mastercard debit or credit card. Unlike traditional refund processes that can only return funds from a previous purchase, OCT allows for independent disbursements of funds to a cardholder's account.</p>\n<p>This feature is designed for high-velocity industries that require frictionless, real-time payouts, such as:</p>\n<ul>\n<li><p><strong>Gaming &amp; Betting:</strong> Real-time withdrawal of player winnings.</p>\n</li>\n<li><p><strong>Marketplaces:</strong> Payouts to sellers or service providers.</p>\n</li>\n<li><p><strong>Corporate Disbursements:</strong> Instant insurance claims, rebates, or compensation payments.</p>\n</li>\n<li><p><strong>Merchant Settlements:</strong> Faster access to processed funds for sub-merchants.</p>\n</li>\n</ul>\n<p>By utilizing the Paysecure <code>/payout</code> API with the <code>PAYOUT-CARDS</code> method, you benefit from a unified orchestration layer that handles the complexities of card network routing, ensuring high success rates and global reach while maintaining the same security standards as your standard payment integrations.</p>\n<hr />\n<h2 id=\"integration-steps\">Integration Steps</h2>\n<ol>\n<li><p><strong>Enable OCT:</strong> Ensure \"Push to Card\" permissions are enabled for your merchant account in the Paysecure Merchant Portal.</p>\n</li>\n<li><p><strong>Collect Card Details:</strong> Use a secure method to collect the recipient's card number and expiry date or can you Paysecure's cashier to do that.</p>\n</li>\n<li><p><strong>Execute Payout:</strong> Call the <code>/payout</code> endpoint with the OCT-specific payout method.</p>\n</li>\n<li><p><strong>Handle Webhooks:</strong> Listen for the <code>paid</code> or <code>failure</code> events to update your internal records.</p>\n</li>\n</ol>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Required</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>Yes</td>\n<td>The customer's email.</td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td>Yes</td>\n<td>The customer's phone number along with the country code.  <br />Example: +91 9634088651</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>Yes</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>Yes</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Optional</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>Optional</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>Optional</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>currency</td>\n<td>Yes</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>amount</td>\n<td>Yes</td>\n<td>amount in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>Optional</td>\n<td>example: PAYOUT-CARDS</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>Yes</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Yes</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Yes</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>Optional</td>\n<td>The purpose of doing a payout.</td>\n</tr>\n<tr>\n<td>extraParam.cardNumber</td>\n<td>Yes</td>\n<td>The recipient's 16-digit card number.</td>\n</tr>\n<tr>\n<td>extraParam.expiryYear</td>\n<td>Yes</td>\n<td>YYYY format (e.g., 2028).</td>\n</tr>\n<tr>\n<td>extraParam.expiryMonth</td>\n<td>Yes</td>\n<td>MM format (e.g., 05).</td>\n</tr>\n<tr>\n<td>extraParam.cardHolderName</td>\n<td>Yes</td>\n<td>The receiver's Full Name. Preferred a 2 word name with each word atleast 3 characters long.</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong></p>\n<p>If the merchant is not PCI DSS compliant then they will need to use our <strong>cashier</strong> and asking the user to enter the card details there. Check the cashier section for more details. If the merchant is PCI DSS compliant then they can use the payout API and send the card details as shown above.</p>\n<p>If the merchant wants to use <strong>token_reference</strong> for doing a payout, then please have a look at the Network Tokenisation Section.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"b20ed466-3953-4fdc-88ca-adb9afe12944","id":"b20ed466-3953-4fdc-88ca-adb9afe12944","name":"APIs","type":"folder"}},"urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"0e0833e0-f2d7-457d-97ed-a715dbb2b75d","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahul@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"QLD\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"phone\": \"+44 9876543210\",\r\n        \"gender\": \"M\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"purpose\": \"Testing cards payout\",\r\n    \"currency\": \"GBP\",\r\n    \"merchantRef\": \"YOUR ORDER ID\", // optional\r\n    \"payoutMethod\": \"PAYOUT-CARDS\",\r\n    \"amount\": 100.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"cardNumber\": \"5431240006334004\",\r\n        \"cardHolderName\": \"Rahul Agarwal\",\r\n        \"expiryYear\": \"2030\",\r\n        \"expiryMonth\": \"11\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"status":"Accepted","code":202,"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"6977137755e0628e3600c562\",\r\n    \"client\": {\r\n        \"email\": \"rahul@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"QLD\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"phone\": \"+44 9876543210\",\r\n        \"gender\": \"M\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"updated_on\": 1769411447,\r\n    \"extraParam\": {\r\n        \"cardNumber\": \"5431240006334004\",\r\n        \"cardHolderName\": \"Rahul Agarwal\",\r\n        \"expiryYear\": \"2030\",\r\n        \"expiryMonth\": \"11\"\r\n    },\r\n    \"payoutMethod\": \"PAYOUT-CARDS\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 100.0,\r\n    \"errorMsg\": \"\",\r\n    \"purpose\": \"Testing cards payout\",\r\n    \"created_on\": 1769411447,\r\n    \"merchantRef\": \"YOUR ORDER ID\",\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n        {\r\n            \"status\": \"payout_in_process\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n\r\n    ],\r\n    \"currency\": \"GBP\",\r\n    \"extraFee\": \"0\",\r\n    \"paymentOn\": 0,\r\n    \"checkout_url\": \"https://test4.paymentsclub.net/payout/092e59f94279a3742fa3715fe9a2112a/\",\r\n    \"taxAmount\": 0.0,\r\n    \"taxPercent\": 0.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n    \"redirectType\": \"POST\",\r\n    \"sessionId\": \"\",\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"trxMethod\": \"CARDS\",\r\n    \"success_callback\": \"\",\r\n    \"failure_callback\": \"\"\r\n}"},{"id":"43446118-b6b3-4995-952c-3a7676d5192f","name":"Error","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahul@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"QLD\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"phone\": \"+44 9876543210\",\r\n        \"gender\": \"M\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"purpose\": \"Testing cards payout\",\r\n    \"currency\": \"GBP\",\r\n    \"merchantRef\": \"YOUR ORDER ID\", // optional\r\n    \"payoutMethod\": \"PAYOUT-CARDS\",\r\n    \"amount\": 100.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"cardNumber\": \"5431240006334004\",\r\n        \"cardHolderName\": \"Rahul Agarwal\",\r\n        \"expiryYear\": \"2030\",\r\n        \"expiryMonth\": \"11\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"6977137755e0628e3600c562\",\r\n    \"client\": {\r\n        \"email\": \"rahul@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"QLD\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"phone\": \"+44 9876543210\",\r\n        \"gender\": \"M\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"updated_on\": 1769411447,\r\n    \"extraParam\": {\r\n        \"cardNumber\": \"5431240006334004\",\r\n        \"cardHolderName\": \"Rahul Agarwal\",\r\n        \"expiryYear\": \"2030\",\r\n        \"expiryMonth\": \"11\"\r\n    },\r\n    \"payoutMethod\": \"PAYOUT-CARDS\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 100.0,\r\n    \"errorMsg\": \"\",\r\n    \"purpose\": \"Testing cards payout\",\r\n    \"created_on\": 1769411447,\r\n    \"merchantRef\": \"YOUR ORDER ID\",\r\n    \"status\": \"error\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n        {\r\n            \"status\": \"error\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n\r\n    ],\r\n    \"currency\": \"GBP\",\r\n    \"extraFee\": \"0\",\r\n    \"paymentOn\": 0,\r\n    \"checkout_url\": \"https://test4.paymentsclub.net/payout/092e59f94279a3742fa3715fe9a2112a/\",\r\n    \"taxAmount\": 0.0,\r\n    \"taxPercent\": 0.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n    \"redirectType\": \"POST\",\r\n    \"sessionId\": \"\",\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"trxMethod\": \"BANKTRANSFER\",\r\n    \"success_callback\": \"\",\r\n    \"failure_callback\": \"\"\r\n}"}],"_postman_id":"3065075c-9f4e-401e-ba84-180bc403b02e"}],"id":"b20ed466-3953-4fdc-88ca-adb9afe12944","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"fa45e560-c706-4b4a-90d2-e91f643ba232","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"f731e712-cbad-4975-9d01-47b92adf6ec7","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"b20ed466-3953-4fdc-88ca-adb9afe12944","description":""}],"id":"965ae360-2693-47d8-b889-50a0c401343f","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"type":"text/javascript","packages":{},"exec":[""],"id":"e8a74862-a410-4357-bcf9-5b53a60615f9"}},{"listen":"test","script":{"type":"text/javascript","packages":{},"exec":[""],"id":"69a2cb71-17fd-494c-a773-449c5d656c88"}}],"_postman_id":"965ae360-2693-47d8-b889-50a0c401343f","description":""},{"name":"💰 APMs (Alternative Payment Methods)","item":[{"name":"🇨🇦 Interac e-Transfer","item":[{"name":"Concepts","item":[],"id":"65cfe3ae-be17-4405-9c3b-7f178f4b881b","description":"<h2 id=\"interac-overview\">Interac Overview</h2>\n<p>Interac is a leading Canadian payment network that facilitates secure, real-time transactions between bank accounts. It offers multiple payment options, including Interac e-Transfers.</p>\n<p>Interac e-Transfer allows users to send and receive money directly between bank accounts using email or SMS. It provides a fast, secure, and convenient alternative to traditional payment methods, accessible through most Canadian banks' online and mobile banking platforms.</p>\n<h3 id=\"paysecures-interac-product-suite-enables-merchants-to-initiate\"><strong>Paysecure’s Interac product suite enables merchants to initiate:</strong></h3>\n<ul>\n<li><p><strong>PayIns:</strong> Consumers can utilise Interac e-Transfer to transfer funds from their bank account, through their bank’s app or website.</p>\n</li>\n<li><p><strong>Payouts:</strong> Facilitate real-time disbursements directly to consumers' accounts.</p>\n</li>\n</ul>\n<h2 id=\"payin-flows\">PayIn Flows</h2>\n<p><strong>How it works</strong></p>\n<p>Interac e-Transfer enables merchants with capability to support easy collection from customers. Merchants can initiate payment requests to provide secure, efficient, and flexible options for collecting payments from customers.</p>\n<p><strong>Key Steps</strong></p>\n<img src=\"https://content.pstmn.io/93d3d350-d8c5-4470-960b-4eaa8d8a0d70/SW50ZXJhYyBQYXlJbiBGbG93LnBuZw==\" />\n\n<p><strong>Flow</strong></p>\n<ul>\n<li><p><strong>Initiate Payment Request:</strong> The merchant initiates a PayIn (deposit/collection) transaction by sending a request to the Paysecure <code>/purchases</code> API. The payload must specify <code>INTERAC-ETRANSFER</code> as the payment method and include the customer’s email address or mobile number, the amount to be collected, and an optional message.</p>\n</li>\n<li><p><strong>Generate Security Question &amp; Answer:</strong> The API responds with a security question and answer that the customer must use to complete the transfer, adding an additional layer of security. By default, the request remains valid for 30 days. The merchant can configure a longer expiry period, but not shorter than 30 days.</p>\n</li>\n<li><p><strong>Customer Completes the Transfer:</strong> The customer logs into their online banking platform, inputs the amount, enter the deposit email and security question and answer, and authorizes the transfer to the merchant’s account.</p>\n</li>\n<li><p><strong>Confirm Transfer Completion:</strong> Once the funds are successfully transferred, Paysecure sends a webhook to the merchant containing the transaction details and confirmation of payment status.</p>\n</li>\n<li><p><strong>Update Merchant’s Account:</strong> The merchant’s system updates the customer’s account balance to reflect the successful receipt of funds.</p>\n</li>\n</ul>\n<h2 id=\"payout-flows\"><strong>PayOut flows</strong></h2>\n<p><strong>How it works</strong><br />Paysecure offers the ability to make payouts to customers', individuals', or businesses' bank accounts using Interac e-Transfers. Whether for refunds, rewards, or other types of disbursements, the Payouts API ensures efficient and reliable transactions, supporting real-time fund transfers and comprehensive transaction tracking over Interac e-transfers.</p>\n<p><strong>Key Steps</strong></p>\n<img src=\"https://content.pstmn.io/e51c224c-855b-49b3-b3a0-e38730ba20d4/SW50ZXJhYyBQYXlPdXQgRmxvdy5wbmc=\" />\n\n<p><strong>Flow</strong></p>\n<ul>\n<li><p><strong>Initiate Payout Request:</strong> The merchant calls the Paysecure <code>/Payout</code> API. This request includes the customer’s email address or mobile number, the amount to be transferred, and an optional message.</p>\n</li>\n<li><p><strong>Security Question &amp; Answers (Optional):</strong> For the customers that have their auto-deposit turned off , the merchant can share the security question and answer at their cashier or via email. The customer must use these Security question and answer to receive the funds, adding an extra layer of security. For customers with auto-deposit turned on, the funds will be received instanteneously.</p>\n</li>\n<li><p><strong>Customer Deposits Funds (Optional):</strong> The customer with auto-deposit turned off, will have to follows the link received on their email from Interac and follow the instructions to receive the funds into their acount. For customers with auto-deposit turned on, the funds will be received instanteneously.</p>\n</li>\n<li><p><strong>Confirm Payout Completion:</strong> Upon successful deposit, the merchant will receive the webhook with transaction info and the status.</p>\n</li>\n<li><p><strong>Update Merchant’s Account:</strong> The merchant’s system updates the customer’s account balance to reflect the withdrawn funds.</p>\n</li>\n</ul>\n<h2 id=\"transaction-limits\">Transaction Limits:</h2>\n<p>The limits outlined below are generally for personal accounts and can vary by financial institution and account type. For business accounts, higher limits may apply. It’s advisable to check with your bank for the most accurate limits pertaining to your account</p>\n<h2 id=\"pay-ins\">Pay Ins:</h2>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Criteria</strong></th>\n<th><strong>Min Amount</strong></th>\n<th><strong>Max Amount</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Per Transaction</td>\n<td>0.01 CAD</td>\n<td>3,000 CAD</td>\n</tr>\n<tr>\n<td>Per Day</td>\n<td>0.01 CAD</td>\n<td>3,000 CAD</td>\n</tr>\n<tr>\n<td>Per User (over a 7 day rolling period)</td>\n<td>0.01 CAD</td>\n<td>10,000 CAD</td>\n</tr>\n<tr>\n<td>Per Month (over a 30 day rolling period)</td>\n<td>0.01 CAD</td>\n<td>20,000 CAD</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"pay-outs\">Pay Outs:</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Criteria</strong></th>\n<th><strong>Min Amount</strong></th>\n<th><strong>Max Amount</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Per Transaction</td>\n<td>10 CAD</td>\n<td>3,000 CAD</td>\n</tr>\n<tr>\n<td>Per Day</td>\n<td>10 CAD</td>\n<td>10,000 CAD</td>\n</tr>\n<tr>\n<td>Per User (over a 7 day rolling period)</td>\n<td>10 CAD</td>\n<td>70,000 CAD</td>\n</tr>\n<tr>\n<td>Per Month (over a 30 day rolling period)</td>\n<td>10 CAD</td>\n<td>100,000 CAD</td>\n</tr>\n</tbody>\n</table>\n</div>","_postman_id":"65cfe3ae-be17-4405-9c3b-7f178f4b881b"},{"name":"PayIn API","item":[{"name":"Purchases","id":"49808215-864c-45c9-bc89-45f46818bfc2","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"seo2009@test.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"CA\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"CAD\",\r\n        \"expireInMin\": \"80\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 100\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"INTERAC-ETRANSFER\",\r\n    \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\r\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://your.redirect.url/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://your.success.callback.url\",\r\n    \"failure_callback\": \"https://your.success.failure.url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) which can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. It must be upper case.  <br />This should be \"CA\" for Interac</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”.. Must be in upper case.</td>\n</tr>\n<tr>\n<td>client.street_address</td>\n<td></td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td></td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td></td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />This should be 'CAD' for Interac</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>name of the product or service</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in progress</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is UNSUCCESSFUL</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>The <code>purchase.expireInMin</code>, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td></td>\n</tr>\n<tr>\n<td>Enter Valid Email</td>\n<td></td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td></td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect/failure_redirect/brand_id is missing</td>\n<td></td>\n</tr>\n<tr>\n<td>brand_id cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>failure_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid failure_redirect: minimum 10 characters</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products[0].name/purchase.products[0].price are missing</td>\n<td></td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td></td>\n</tr>\n<tr>\n<td>Currency \"{curr_name}\" is Not Allowed</td>\n<td></td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong> For certain use cases, in addition to long format purchase Id, Paysecure also provides a 7 digit unique code for each purchase starting with digit 4, eg 4000001</p>\n<p><em>“purchaseIdShortCode”: “4000013\"</em></p>\n","urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"5bc04cd3-2e36-4ed9-8228-7d37db8c9f8a","name":"Purchase- success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"seo2009@test.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"CA\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"CAD\",\r\n        \"expireInMin\": \"80\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 100\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"INTERAC-ETRANSFER\",\r\n    \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\r\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://your.redirect.url/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://your.success.callback.url\",\r\n    \"failure_callback\": \"https://your.success.failure.url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\"purchaseId\":\"67efd0ff97be603f97a3a697\",\"client\":{\"customerId\":\"NA\",\"email\":\"ashishm.21190@gmail.com\",\"phone\":\"+447755564318\",\"full_name\":\"Test test\",\"date_of_birth\":\"1970-07-10\",\"street_address\":\"10 New Burlington Street Apt. 214\",\"country\":\"CA\",\"city\":\"London\",\"zip_code\":\"W1S 3BE\",\"cc\":[],\"bcc\":[],\"gender\":\"MALE\",\"avatarUrl\":\"https://res.cloudinary.com/w22/image/upload/v1663783641/photos/currencies/ngn.png\",\"stateCode\":\"QLD\"},\"updated_on\":1743769856,\"type\":\"purchase\",\"paymentMethod\":\"INTERAC-ETRANSFER\",\"amountUnit\":\"MAJOR\",\"errorMsg\":\"\",\"redirectType\":\"GET\",\"force_recurring\":false,\"created_on\":1743769855,\"merchantRef\":\"67efd0ff97be603f97a3a697\",\"merchantName\":\"arunsinghal\",\"purchase\":{\"currency\":\"CAD\",\"products\":[{\"name\":\"test\",\"quantity\":1.0,\"price\":1.0,\"discount\":0,\"tax_percent\":\"0.00\"}],\"total\":1.0,\"language\":\"en\",\"notes\":\"\",\"debt\":0,\"total_formatted\":1.0,\"expireInMin\":\"43200\",\"taxAmount\":0.0,\"taxPercent\":0.0,\"request_client_details\":[],\"email_message\":\"\"},\"payment\":{\"is_outgoing\":false,\"payment_type\":\"PURCHASE\",\"amount\":1.0,\"currency\":\"CAD\",\"net_amount\":1.0,\"fee_amount\":0.0,\"pending_amount\":0.0,\"pending_unfreeze_on\":null,\"description\":\"\",\"paid_on\":1743769855,\"remote_paid_on\":1743769855},\"issuer_details\":{\"website\":\"\",\"legal_street_address\":\"\",\"legal_country\":\"\",\"legal_city\":\"\",\"legal_zip_code\":\"\",\"bank_accounts\":[{}],\"legal_name\":\"test6\",\"brand_name\":\"test6\",\"registration_number\":\"\",\"tax_number\":\"\"},\"transaction_data\":{\"payment_method\":\"\",\"flow\":\"payform\",\"extra\":{\"amount\":1.0,\"masked_pan\":\"INTERAC-ETRANSFER\"},\"country\":\"\",\"attempts\":[{\"client_ip\":\"103.59.75.41, 162.158.88.44, 130.176.93.146\",\"type\":\"execute\",\"payment_method\":\"INTERAC-ETRANSFER\",\"flow\":\"payform\",\"successful\":true,\"country\":\"INTERAC-ETRANSFER\",\"processing_time\":1743769855,\"extra\":{\"amount\":1.0,\"masked_pan\":\"INTERAC-ETRANSFER\"}}]},\"status\":\"PAYMENT_IN_PROCESS\",\"status_history\":[{\"status\":\"created\",\"timestamp\":1743769855},{\"status\":\"pending_execute\",\"timestamp\":1743769855},{\"status\":\"payment_in_process\",\"timestamp\":1743769856},{\"status\":\"viewed\",\"timestamp\":1744026697}],\"viewedOn\":1744026697,\"is_test\":false,\"brand_id\":\"30f7ce6e-3b7e-46a2-9b50-484fc55be689\",\"send_receipt\":false,\"is_recurring_token\":false,\"skip_capture\":false,\"reference_generated\":\"PS620\",\"issued\":\"2025-04-04\",\"due\":1743769855,\"refund_upto\":0,\"cc_descriptor\":\"Africhange Technologies\",\"fraudScore\":\"NA\",\"trustScore\":\"NA\",\"payInDetails\":{\"name\":\"INTERAC\",\"emailAddress\":\"transfer@ieft.ca\",\"secretQA\":\"66a8c78af1fc2f768304bce4\",\"secretAnswer\":\"ps8766a8af\"},\"paidOn\":0,\"receivedAmt\":0.0,\"refund_availability\":\"NONE\",\"refundable_amount\":0.0,\"success_redirect\":\"https://your.redirect.url/getResponse.jsp?success=true\",\"failure_redirect\":\"https://your.redirect.url/getResponse.jsp?success=false\",\"cancel_redirect\":\"\",\"success_callback\":\"https://your.success.callback.url\",\"failure_callback\":\"https://your.success.failure.url\",\"platform\":\"API\",\"created_from_ip\":\"103.59.75.41, 162.158.88.44, 130.176.93.146\",\"checkout_url\":\"https://api.choicepay.ca/payments/67efd0ff97be603f97a3a697/\",\"payoutProcess\":false}"}],"_postman_id":"49808215-864c-45c9-bc89-45f46818bfc2"},{"name":"Get Status","id":"62b97f74-2b7a-4ea1-8a58-79b22b210eb7","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<p><strong>Note:</strong> With respect to bank transfers, the purchase request is synonymous with the PayIn request.</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"0f235715-3da2-42cd-83ac-5c351c67a624","name":"Purchases-success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"6790e75fa46a5a5bb0b00e55\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"phone\": \"+14377717874\",\n        \"full_name\": \"Test test\",\n        \"date_of_birth\": \"1970-07-10\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"country\": \"CA\",\n        \"city\": \"London\",\n        \"zip_code\": \"W1S 3BE\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"gender\": \"MALE\",\n        \"stateCode\": \"QLD\"\n    },\n    \"updated_on\": 1737549752,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"INTERAC-ETRANSFER\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"Transaction succeeded-APPROVED\",\n    \"redirectType\": \"GET\",\n    \"force_recurring\": false,\n    \"created_on\": 1737549663,\n    \"merchantRef\": \"6790e75fa46a5a5bb0b00e55\",\n    \"merchantName\": \"arunsinghal\",\n    \"purchase\": {\n        \"currency\": \"CAD\",\n        \"products\": [\n            {\n                \"name\": \"test\",\n                \"quantity\": 1,\n                \"price\": 1,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 2,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"expireInMin\": \"43200\",\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 1,\n        \"currency\": \"CAD\",\n        \"net_amount\": 1,\n        \"fee_amount\": 0,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1737549663,\n        \"remote_paid_on\": 1737549663\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"test6\",\n        \"brand_name\": \"test6\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"amount\": 1,\n            \"masked_pan\": \"INTERAC-ETRANSFER\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"103.59.75.42, 172.71.186.102, 130.176.183.14\",\n                \"type\": \"execute\",\n                \"payment_method\": \"INTERAC-ETRANSFER\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"INTERAC\",\n                \"processing_time\": 1737549663,\n                \"extra\": {\n                    \"amount\": 1,\n                    \"masked_pan\": \"INTERAC-ETRANSFER\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1737549663\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1737549663\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1737549664\n        },\n        {\n            \"status\": \"paid 2.0\",\n            \"timestamp\": 1737549752\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1737549750\n        }\n    ],\n    \"viewedOn\": 1738749942,\n    \"is_test\": false,\n    \"brand_id\": \"30f7ce6e-3b7e-46a2-9b50-484fc55be689\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS376\",\n    \"issued\": \"2025-01-22\",\n    \"due\": 1737549663,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"Africhange Technologies\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"payInDetails\": {\n        \"name\": \"INTERAC\",\n        \"emailAddress\": \"deposit@ieft.ca\",\n        \"secretQA\": \"66a8c78af1fc2f768304bce4\",\n        \"secretAnswer\": \"ps8766a8af\"\n    },\n    \"paidOn\": 1737549752,\n    \"receivedAmt\": 2,\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://webhook.site/83df9776-3590-4e25-9222-870e931ac868\",\n    \"failure_callback\": \"https://webhook.site/83df9776-3590-4e25-9222-870e931ac868\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"103.59.75.42, 172.71.186.102, 130.176.183.14\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6790e75fa46a5a5bb0b00e55/\",\n    \"payoutProcess\": false\n}"},{"id":"439ccb42-f2d9-45e4-acf6-5f8994821433","name":"Purchases Error","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"code":400,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Error Message\",\n    \"code\": \"error_code\"\n}"}],"_postman_id":"62b97f74-2b7a-4ea1-8a58-79b22b210eb7"}],"id":"58d6007f-79ab-44f7-a87c-e00432a030ab","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/cfWw_RYZ9eZVEKzKjeRW4I_VwbBTyqH78LUrJG6ulp7FkE1pXVD6DZr9MnQXB9KH_oLFasJDb156naCsBc2bgotPaVY7LtGOJNifpTOb5uks3fjAKpgVhU4dsXQmQ7hFKNFIVhZEl2p8fCN1YufsRaA\" />\n\n<ol>\n<li><p>The merchant initiates the purchase via the create purchase API. If successful, they receive PayIn details along with a checkout URL in the response JSON</p>\n</li>\n<li><p>The merchant then has 2 options</p>\n<ol>\n<li><p>Redirect the end-user to the checkoutURL present in the response, where the customer is shown the following details required to make Interac payments:</p>\n<ol>\n<li><p>Payment Amount</p>\n</li>\n<li><p>Deposit email address</p>\n</li>\n<li><p>Secret Question</p>\n</li>\n<li><p>Secret Answer</p>\n</li>\n</ol>\n</li>\n<li><p>Retrieve the PayIn details in the response JSON (as shown below) to create a webpage within the merchant’s IT estate, and show to user the PayIn instruction</p>\n</li>\n</ol>\n</li>\n<li><p>After a successful or failed payment by the end user, an appropriate webhook would be sent to the merchant. If option 2a was employed, the user would be redirected to the appropriate success or failure redirect URL.</p>\n</li>\n</ol>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\"> \"payInDetails\": {\n        \"name\": \"INTERAC-ETRANSFER\",\n        \"emailAddress\": \"deposit@ieft.ca\",\n        \"secretQA\": \"6789df35bbefe612e3cb4641\",\n        \"secretAnswer\": \"PS7466835\"\n   }\n\n</code></pre>\n","_postman_id":"58d6007f-79ab-44f7-a87c-e00432a030ab"},{"name":"PayOut API","item":[{"name":"Create PayOut","id":"6285014e-7757-494e-a52a-3f674e461af7","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"},{"key":"brandId","value":"your-brand-id","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"phone\": \"1111111111\",\r\n        \"email\": \"gouridausa+2@gmail.com\",\r\n        \"full_name\": \"Pay secure\",\r\n        \"stateCode\": \"CT\",\r\n        \"country\": \"CA\",\r\n        \"city\": \"123\",\r\n        \"street_address\": \"test test\",\r\n        \"zip_code\": \"234567\"\r\n    },\r\n    \"payoutMethod\": \"PAYOUT-INTERAC-ETRANSFER\",\r\n    \"purpose\": \"entertainment\",\r\n    \"currency\": \"CAD\",\r\n    \"amount\": 18.00,\r\n    \"success_redirect\": \"https://success.com\",\r\n    \"failure_redirect\": \"https://failure.com\",\r\n    \"pending_redirect\": \"https://pending.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payment, the very first call to make is /payout/</p>\n<p>with the required data in the request body.</p>\n<p>To generate a Payout, you are required to provide the <code>API key</code> (in the header) can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a Payout request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>CA</td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>PAYOUT-INTERAC-ETRANSFER</td>\n</tr>\n<tr>\n<td>Currency</td>\n<td>CAD</td>\n</tr>\n<tr>\n<td>Amount</td>\n<td>Payout Amount</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>Transfer Reversed</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"57f6b692-d141-4483-b883-ca2ef9ef9dc2","id":"57f6b692-d141-4483-b883-ca2ef9ef9dc2","name":"PayOut API","type":"folder"}},"urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"6e9144ee-11ae-47c7-9a79-e45d5c2a9c63","name":"create payout-success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"brandId","value":"your-brand-id","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"phone\": \"+14378817874\",\r\n        \"email\": \"gouridausa+2@gmail.com\",\r\n        \"full_name\": \"Pay secure\",\r\n        \"stateCode\": \"CT\",\r\n        \"country\": \"CA\",\r\n        \"city\": \"Torronto\",\r\n        \"street_address\": \"test test\",\r\n        \"zip_code\": \"234567\"\r\n    },\r\n    \"payoutMethod\": \"PAYOUT-INTERAC-ETRANSFER\",\r\n    \"purpose\": \"entertainment\",\r\n    \"currency\": \"CAD\",\r\n    \"amount\": 5.00,\r\n    \"success_redirect\": \"https://success.com\",\r\n    \"failure_redirect\": \"https://failure.com\",\r\n    \"pending_redirect\": \"https://pending.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"_type\": \"Payout\",\n    \"payoutId\": \"69cd1236e36738557e988399\",\n    \"client\": {\n        \"_type\": \"PClientDetails\",\n        \"customerId\": \"NA\",\n        \"email\": \"gouridausa+2@gmail.com\",\n        \"phone\": \"+14378817874\",\n        \"full_name\": \"Ashish Mistry\",\n        \"date_of_birth\": null,\n        \"street_address\": \"test test\",\n        \"country\": \"CA\",\n        \"city\": \"Torronto\",\n        \"zip_code\": \"234567\",\n        \"documentId\": null,\n        \"documentType\": null,\n        \"spei_clabe\": null,\n        \"spei_debitCard\": null,\n        \"spei_mobileNo\": null,\n        \"stateCode\": \"CT\"\n    },\n    \"updated_on\": 1775047222,\n    \"payoutMethod\": \"PAYOUT-INTERAC-ETRANSFER\",\n    \"beneficiaryDetail\": null,\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 5,\n    \"errorMsg\": \"paid\",\n    \"issued\": \"2026-04-01\",\n    \"responseMsg\": null,\n    \"purpose\": \"Transfer Interac\",\n    \"created_on\": 1775047222,\n    \"custUniqueId\": \"ashishm.21190@gmail.com\",\n    \"amount_in_usd\": 3.6,\n    \"merchantRef\": \"69cd1236e36738557e988399\",\n    \"instruction\": null,\n    \"merchant_id\": null,\n    \"usePrivateKey\": null,\n    \"merchantName\": null,\n    \"agentId\": 0,\n    \"parentId\": 0,\n    \"whiteId\": 0,\n    \"year\": null,\n    \"month\": null,\n    \"day\": null,\n    \"hour\": 12,\n    \"bankid\": null,\n    \"setCurr\": \"CAD\",\n    \"pspReference\": null,\n    \"bankmid\": null,\n    \"bankname\": null,\n    \"status\": \"paid\",\n    \"status_history\": [\n        {\n            \"_type\": \"Status\",\n            \"status\": \"created\",\n            \"timestamp\": 1775047222,\n            \"updatedBy\": null,\n            \"paidReason\": null\n        },\n        {\n            \"_type\": \"Status\",\n            \"status\": \"paid\",\n            \"timestamp\": 1775047239,\n            \"updatedBy\": null,\n            \"paidReason\": null\n        }\n    ],\n    \"viewedOn\": null,\n    \"currency\": \"CAD\",\n    \"actionStatus\": {\n        \"_type\": \"ApiError\",\n        \"message\": null,\n        \"actualMessage\": null,\n        \"merchantName\": null,\n        \"code\": \"success\",\n        \"status\": \"paid\",\n        \"callback_url\": null,\n        \"method\": null,\n        \"beneficiaryId\": null,\n        \"profileId\": null,\n        \"payInBankDetail\": null,\n        \"pix_payload\": null,\n        \"payInDetails\": {\n            \"_type\": \"PayInDetail\",\n            \"name\": \"INTERAC E-TRANSFER\",\n            \"emailAddress\": \"ashishm.21190@gmail.com\",\n            \"secretQA\": \"q691236367385579883992851\",\n            \"secretAnswer\": \"a691236367385579883992851\",\n            \"reference_number\": null,\n            \"payment_method\": null,\n            \"transaction_expiry\": null,\n            \"qrCode\": null,\n            \"gpayUri\": null,\n            \"phonepeUri\": null,\n            \"paytmUri\": null,\n            \"intentUri\": null,\n            \"generatedLink\": null,\n            \"instruction\": null,\n            \"paymentUrl\": null,\n            \"script\": null,\n            \"clabe\": null,\n            \"beneficiary\": null,\n            \"amount\": null,\n            \"linkExpiresOn\": null,\n            \"cardExpiresOn\": null,\n            \"subStatus\": null\n        },\n        \"balance\": null,\n        \"vab\": null,\n        \"authKey\": null,\n        \"methodExecutionTime\": null,\n        \"password\": null,\n        \"salt\": null,\n        \"nextCall\": null,\n        \"nextURL\": null,\n        \"descriptor\": null,\n        \"currentTime\": 1775047239,\n        \"custVerificationString\": null,\n        \"instructions\": null,\n        \"trustScore\": null,\n        \"trustLevel\": null,\n        \"no_Of_Cust_Hits\": null,\n        \"no_Of_Hits\": null,\n        \"referer\": null,\n        \"clientIp\": null,\n        \"merchantIp\": null,\n        \"isS2s\": null,\n        \"otp\": null,\n        \"userDeviceId\": null,\n        \"isAllowed\": null,\n        \"logo_url\": null,\n        \"transactionExpireInMin\": null,\n        \"mandateReferenceId\": null\n    },\n    \"fx_Currency\": null,\n    \"fx_Amount\": null,\n    \"referer\": null,\n    \"clientIp\": \"95.217.22.130\",\n    \"merchantIp\": \"95.217.22.130\",\n    \"transFees\": null,\n    \"MDR\": null,\n    \"ruleName\": \"Rule_Not_Applied\",\n    \"cascade_Num\": null,\n    \"conversionRiskFactorApplied\": null,\n    \"feesDeducted\": 0,\n    \"signature\": null,\n    \"puId\": \"\",\n    \"uId\": 0,\n    \"authKey\": \"\",\n    \"currency_conversion\": null,\n    \"success_callback\": \"\",\n    \"failure_callback\": \"\",\n    \"success_redirect\": \"https://success.com\",\n    \"failure_redirect\": \"https://failure.com\",\n    \"pending_redirect\": \"https://pending.com\"\n}"},{"id":"b68c4d75-64a9-4719-b0b7-27a5ce673484","name":"create payout-error","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"brandId","value":"your-brand-id","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"phone\": \"+14378817874\",\n        \"email\": \"gouridausa+2@gmail.com\",\n        \"full_name\": \"Pay secure\",\n        \"stateCode\": \"CT\",\n        \"country\": \"CA\",\n        \"city\": \"Torronto\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\"\n    },\n    \"payoutMethod\": \"PAYOUT-INTERAC-ETRANSFER\",\n    \"purpose\": \"entertainment\",\n    \"currency\": \"CAD\",\n    \"amount\": 5.00,\n    \"success_redirect\": \"https://success.com\",\n    \"failure_redirect\": \"https://failure.com\",\n    \"pending_redirect\": \"https://pending.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"code":400,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Insufficient Balance [5.23]\",\n    \"code\": \"transaction_error\"\n}"}],"_postman_id":"6285014e-7757-494e-a52a-3f674e461af7"},{"name":"Get Status","id":"1febcfd0-2d97-4054-bf4b-d5ff9796b0af","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/","description":"<p>This API tells you about all the details of a Payout, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the payoutId in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payout_in_process</td>\n<td>payout is under Processing.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><p>The webhook will only be triggered for paid transactions or errors.</p>\n<p>Paid: \"success_callback\": \"<a href=\"https://success.com\">https://success.com</a>\",</p>\n<p>Error: \"failure_callback\": “<a href=\"https://failure.com%E2%80%9D\">https://failure.com”</a></p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"57f6b692-d141-4483-b883-ca2ef9ef9dc2","id":"57f6b692-d141-4483-b883-ca2ef9ef9dc2","name":"PayOut API","type":"folder"}},"urlObject":{"path":["getpayout","{payoutId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"8cecfe91-70cb-4a1f-9b8b-666513720be3","name":"Get success Status","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"payoutId\": \"66bf2e76e3defc36cd575481\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"phone\": \"+14377717874\",\n        \"full_name\": \"Ashish Mistry\",\n        \"country\": \"CA\"\n    },\n    \"updated_on\": 1723805728,\n    \"payoutMethod\": \"PAYOUT-INTERAC-ETRANSFER\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 12,\n    \"errorMsg\": \"\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1723805302,\n    \"merchantRef\": \"66bf2e76e3defc36cd575481\",\n    \"merchantName\": \"arunsinghal\",\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1723805302\n        },\n        {\n            \"status\": \"payout_in_process\",\n            \"timestamp\": 1723805310\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1723805728\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1738750221\n        }\n    ],\n    \"viewedOn\": 1738750221,\n    \"currency\": \"USD\",\n    \"paymentOn\": 1723805728,\n    \"payOutDetails\": {\n        \"name\": \"INTERAC E-TRANSFER\",\n        \"emailAddress\": \"ashishm.21190@gmail.com\",\n        \"secretQA\": \"q66276336575481202\",\n        \"secretAnswer\": \"a66276336575481202\"\n    },\n    \"success_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\",\n    \"failure_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\"\n}"},{"id":"f97b9603-1fdc-4361-ae1a-49cf689c397c","name":"Get Error Status","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Error Message\",\n    \"code\": \"error_code\"\n}"}],"_postman_id":"1febcfd0-2d97-4054-bf4b-d5ff9796b0af"}],"id":"57f6b692-d141-4483-b883-ca2ef9ef9dc2","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/Uxy8jmp5RP-c360-oIMAZy2As8naqJdARgKsWU0x_BtszfJlwdRVM6-obffbtjTABfI9V0hxH4Ad-Ns96We42lIMdL434tTzLJ6aEQBt0dzX_ZXeM4RtG_kmEeem7WIsN520Zh5PS3xTFYNzOmks0ak\" />\n\n<ul>\n<li><p>The merchant initiates a PayOut via the payout API.</p>\n</li>\n<li><p>After a successful or failed payment attempt, the status is reflected on the response, and the details on the status history. You can also get the status through getStatus (purchases/{payID}) API.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"7644380a-8f4b-4e42-b202-7f5a61abd2a8","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"c09a9c3e-ffa0-413b-a6b5-f7e9c1de2f23","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"57f6b692-d141-4483-b883-ca2ef9ef9dc2"},{"name":"Get Balance API","item":[{"name":"Checking Balance","id":"9b940b63-d3ae-46e5-88e0-914e274f7036","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"INTERAC-ETRANSFER\"\r\n\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance","description":"<h2 id=\"api-for-checking-available-balance\"><strong>API for checking available balance</strong></h2>\n<ol>\n<li><p>URL :- /getBalance/</p>\n</li>\n<li><p>RequestType: POST</p>\n</li>\n<li><p>Request Body</p>\n</li>\n</ol>\n<p>Note: Currency is not a mandatory parameter. If no parameter is specified then all respective currency balances would be provided, if any specific currency parameter is provided then only that currency balance would be provided.</p>\n","urlObject":{"path":["getBalance"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"15cdf23d-0f5c-4fa2-a6ca-3bed86c7fcda","name":"Checking Balance payout-success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"INTERAC-ETRANSFER\"\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"paymentMethod\": \"INTERAC-ETRANSFER\",\n    \"status\": \"success\",\n    \"data\": [\n        {\n            \"currency\": \"AUD\",\n            \"balance\": \"0.00\"\n        },\n        {\n            \"currency\": \"BRL\",\n            \"balance\": \"0.00\"\n        },\n        {\n            \"currency\": \"EUR\",\n            \"balance\": \"0.00\"\n        },\n        {\n            \"currency\": \"INR\",\n            \"balance\": \"0.00\"\n        },\n        {\n            \"currency\": \"JPY\",\n            \"balance\": \"0.00\"\n        },\n        {\n            \"currency\": \"USD\",\n            \"balance\": \"0.00\"\n        }\n    ]\n}"},{"id":"b4503189-c378-4109-b803-dbc9ff982712","name":"Checking Balance payout-error","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"INTERAC-ETRANSFER\"\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Error Message\",\n    \"code\": \"No currency account found\"\n}"}],"_postman_id":"9b940b63-d3ae-46e5-88e0-914e274f7036"}],"id":"331fc9ae-44b2-4f2b-9f7b-e27a9c5ed1a2","_postman_id":"331fc9ae-44b2-4f2b-9f7b-e27a9c5ed1a2","description":""}],"id":"0157d363-ae87-4aa5-9197-f05993504b91","_postman_id":"0157d363-ae87-4aa5-9197-f05993504b91","description":""},{"name":"🇨🇦 Interac Request Money","item":[{"name":"Concepts","item":[],"id":"8b8ad1e2-9b08-4cea-993e-3f8426b85c95","description":"<h2 id=\"payin-flows\"><strong>PayIn Flows</strong></h2>\n<h3 id=\"how-it-works\"><strong>How It Works</strong></h3>\n<p>With <strong>Interac Request Money</strong>, payments are made seamless and secure. Customers are provided with a deposit link upon initiating a transaction on the merchant's website. They are redirected to a secure payment page, where their bank is selected, and the payment is completed effortlessly. Payments are processed instantly, ensuring real-time confirmation and updates. This method enhances the checkout experience, builds customer trust, and increases conversions, making it an ideal choice for businesses seeking a reliable payment solution.</p>\n<h3 id=\"key-steps\"><strong>Key Steps</strong></h3>\n<img src=\"https://content.pstmn.io/746e51e2-8ff6-47bc-8a3b-ab3e7b6167c0/aW1hZ2UucG5n\" width=\"508\" height=\"266\" />\n\n<h3 id=\"flow\">Flow</h3>\n<ol>\n<li><p><strong>Initiate Transfer Request</strong>: Upon the custeomer's intent to pay, the merchant calls the <code>/purchases</code> API with <code>INTERAC-REQUEST-MONEY</code> in the Payment Method Param, to initiate a PayIn (deposit/collections) transaction. This request includes the customerʼs email address, mobile number, the amount to be collected, and an optional message. With this method, the customer do not need any security question and answer to proceed with the payment.</p>\n</li>\n<li><p><strong>Deposit Link</strong>:</p>\n<ol>\n<li>A unique deposit link is generated and presented to the customer. This link will be valid for 24 hrs. This time cannot be changed.</li>\n</ol>\n</li>\n<li><p><strong>Redirection to Payment Page</strong>:</p>\n<ol>\n<li><p>The customer is redirected to the deposit link and shown payment details:</p>\n<ol>\n<li><p>Amount due.</p>\n</li>\n<li><p>A list of supported banks.</p>\n</li>\n</ol>\n</li>\n</ol>\n</li>\n<li><p><strong>Bank Selection</strong>:</p>\n<ol>\n<li><p>The customer selects their bank from a dropdown menu.</p>\n</li>\n<li><p>They are redirected to their banking portal.</p>\n</li>\n</ol>\n</li>\n<li><p><strong>Payment Confirmation</strong>:</p>\n<ol>\n<li><p>The customer logs into their banking portal</p>\n</li>\n<li><p>Completes the payment on their banking app/website.</p>\n</li>\n<li><p>Instant payment confirmation is displayed on the merchant’s website.</p>\n</li>\n<li><p>The customer’s balance is updated.</p>\n</li>\n</ol>\n</li>\n</ol>\n<h2 id=\"payout-flows\"><strong>PayOut flows</strong></h2>\n<h3 id=\"how-it-works-1\"><strong>How it works</strong></h3>\n<p>Paysecure offers the ability to make payouts to customers', individuals', or<br />businesses' bank accounts using Interac e-Transfers. Whether for refunds,<br />rewards, or other types of disbursements, the Interac Payouts API ensures<br />efficient and reliable transactions, supporting real-time fund transfers and<br />comprehensive transaction tracking.</p>\n<h3 id=\"key-steps-1\"><strong>Key Steps</strong></h3>\n<img src=\"https://content.pstmn.io/d2d79ec3-f371-4ec3-87a3-2477a28c7a7b/aW1hZ2UucG5n\" width=\"500\" height=\"228\" />\n\n<h3 id=\"flow-1\"><strong>Flow</strong></h3>\n<ol>\n<li><p><strong>Initiate Payout Request</strong>: The merchant calls <code>/payout</code> API. This request includes the customerʼs email address or mobile number, the amount to be transferred, and an optional message. the Payout Method is <code>PAYOUT-INTERAC-REQUEST-MONEY.</code></p>\n</li>\n<li><p><strong>Generate Security Question &amp; Answer (Optional)</strong>: If necessary, the merchant can show the security question and answer (received in the response) that the customer may need to provide to receive the funds, adding an extra layer of security.</p>\n</li>\n<li><p><strong>Send Notification</strong>: The customer receives an email notification with payout instructions. If the customerʼs Interac auto deposit is turned on, the funds will automatically be deposited to the customerʼs designated account, without needing to enter the security question and answer.</p>\n<ol>\n<li><strong>If customer's auto-deposit is turned off,</strong> The customer logs into their banking portal, follow the payment instructions and completes the payment.</li>\n</ol>\n</li>\n<li><p><strong>Confirm Payout Completion</strong>: Upon successful payout, a success webhook will be received, with information about the transaction along with the status.</p>\n</li>\n<li><p><strong>Update Merchantʼs Account</strong>: The merchantʼs system updates the customerʼs account balance to reflect the withdrawn funds.</p>\n</li>\n</ol>\n<h2 id=\"transaction-limits\">Transaction Limits:</h2>\n<p>The limits outlined below are generally for personal accounts and can vary by financial institution and account type. For business accounts, higher limits may apply. It’s advisable to check with your bank for the most accurate limits pertaining to your account</p>\n<h2 id=\"pay-ins\">Pay Ins:</h2>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Criteria</strong></th>\n<th><strong>Min Amount</strong></th>\n<th><strong>Max Amount</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Per Transaction</td>\n<td>0.01 CAD</td>\n<td>3,000 CAD</td>\n</tr>\n<tr>\n<td>Per Day</td>\n<td>0.01 CAD</td>\n<td>3,000 CAD</td>\n</tr>\n<tr>\n<td>Per User (over a 7 day rolling period)</td>\n<td>0.01 CAD</td>\n<td>10,000 CAD</td>\n</tr>\n<tr>\n<td>Per Month (over a 30 day rolling period)</td>\n<td>0.01 CAD</td>\n<td>20,000 CAD</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"pay-outs\">Pay Outs:</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Criteria</strong></th>\n<th><strong>Min Amount</strong></th>\n<th><strong>Max Amount</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Per Transaction</td>\n<td>10 CAD</td>\n<td>3,000 CAD</td>\n</tr>\n<tr>\n<td>Per Day</td>\n<td>10 CAD</td>\n<td>10,000 CAD</td>\n</tr>\n<tr>\n<td>Per User (over a 7 day rolling period)</td>\n<td>10 CAD</td>\n<td>70,000 CAD</td>\n</tr>\n<tr>\n<td>Per Month (over a 30 day rolling period)</td>\n<td>10 CAD</td>\n<td>100,000 CAD</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"38a3f7a8-dd06-4bed-8e0f-22be9f67291f","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"ecbce1f9-ff11-4b3b-bdf5-249005e9e032","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"8b8ad1e2-9b08-4cea-993e-3f8426b85c95"},{"name":"PayIn API","item":[{"name":"Create Purchase","id":"58a3f40d-37aa-4949-96dc-1bd772ee1e77","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"ashishm.21190@gmail.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"CA\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\",\r\n        \"gender\": \"MALE\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"CAD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 1\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"INTERAC-REQUEST-MONEY\",\r\n    \"brand_id\": \"0cea7af3-23b2-4278-ab94-acf4076cbee4\",\r\n    \"success_redirect\": \"https://your.redirect.url/getResponse\",\r\n    \"failure_redirect\": \"https://your.redirect.url/getResponse\",\r\n    \"success_callback\": \"https://your.success.callback.url\",\r\n    \"failure_callback\": \"https://your.success.failure.url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td></td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. It must be upper case.  <br />This should be \"CA\" for Interac</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”.. Must be in upper case.</td>\n</tr>\n<tr>\n<td>client.street_address</td>\n<td></td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td></td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td></td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />This should be 'CAD' for Interac</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is UNSUCCESSFUL</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td></td>\n</tr>\n<tr>\n<td>Enter Valid Email</td>\n<td></td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td></td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect/failure_redirect/brand_id is missing</td>\n<td></td>\n</tr>\n<tr>\n<td>brand_id cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>failure_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid failure_redirect: minimum 10 characters</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products[0].name/purchase.products[0].price are missing</td>\n<td></td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td></td>\n</tr>\n<tr>\n<td>Currency \"{curr_name}\" is Not Allowed</td>\n<td></td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong> For certain use cases, in addition to long format purchase Id, Paysecure also provides a 7 digit unique code for each purchase starting with digit 4, eg 4000001</p>\n<p><em>“purchaseIdShortCode”: “4000013\"</em></p>\n","urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"a2db96ff-e627-435f-8640-a67f863f9ab9","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"ashishm.21190@gmail.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"CA\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\",\r\n        \"gender\": \"MALE\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"CAD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 1\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"INTERAC-REQUEST-MONEY\",\r\n    \"brand_id\": \"0cea7af3-23b2-4278-ab94-acf4076cbee4\",\r\n    \"success_redirect\": \"https://your.redirect.url/getResponse\",\r\n    \"failure_redirect\": \"https://your.redirect.url/getResponse\",\r\n    \"success_callback\": \"https://your.success.callback.url\",\r\n    \"failure_callback\": \"https://your.success.failure.url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"670cb0affcc7f4706acb65e0\",\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"phone\": \"+447755564318\",\n        \"full_name\": \"Test test\",\n        \"date_of_birth\": \"1970-07-10\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"country\": \"CA\",\n        \"city\": \"London\",\n        \"zip_code\": \"W1S 3BE\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"gender\": \"MALE\",\n        \"avatarUrl\": \"https://res.cloudinary.com/w22/image/upload/v1663783641/photos/currencies/ngn.png\",\n        \"stateCode\": \"QLD\"\n    },\n    \"updated_on\": 1728884911,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"INTERAC-REQUEST-MONEY\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"POST\",\n    \"force_recurring\": false,\n    \"created_on\": 1728884911,\n    \"merchantRef\": \"670cb0affcc7f4706acb65e0\",\n    \"merchantName\": \"ajay03\",\n    \"purchase\": {\n        \"currency\": \"CAD\",\n        \"products\": [\n            {\n                \"name\": \"test\",\n                \"quantity\": 1,\n                \"price\": 1,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 1,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"expireInMin\": \"1440\",\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 1,\n        \"currency\": \"CAD\",\n        \"net_amount\": 1,\n        \"fee_amount\": 0,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1728884911,\n        \"remote_paid_on\": 1728884911\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"r4\",\n        \"brand_name\": \"r4\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"amount\": 1,\n            \"masked_pan\": \"INTERAC-DEBIT\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"110.235.229.9\",\n                \"type\": \"execute\",\n                \"payment_method\": \"INTERAC-DEBIT\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"INTERAC-DEBIT\",\n                \"processing_time\": 1728884911,\n                \"extra\": {\n                    \"amount\": 1,\n                    \"masked_pan\": \"INTERAC-DEBIT\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAYMENT_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1728884911\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1728884911\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1728884911\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"0cea7af3-23b2-4278-ab94-acf4076cbee4\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS3\",\n    \"issued\": \"2024-10-14\",\n    \"due\": 1728884911,\n    \"refund_upto\": 1744433315,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 1,\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://your.success.callback.url\",\n    \"failure_callback\": \"https://your.success.failure.url\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"110.235.229.9\",\n    \"checkout_url\": \"https://api.paysecure.net/payments/670cb0affcc7f4706acb65e0/\",\n    \"payoutProcess\": false\n}"},{"id":"4739c817-68d9-4f7f-abed-9312cd589383","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"city\": \"London\",\n        \"full_name\": \"Test test\",\n        \"zip_code\": \"W1S 3BE\",\n        \"country\": \"CA\",\n        \"stateCode\": \"QLD\",\n        \"phone\": \"+447755564318\",\n        \"gender\": \"MALE\",\n        \"date_of_birth\": \"1970-07-10\"\n    },\n    \"purchase\": {\n        \"currency\": \"CAD\",\n        \"products\": [\n            {\n                \"name\": \"test \",\n                \"price\": 1\n            }\n        ]\n    },\n    \"paymentMethod\": \"INTERAC-REQUEST-MONEY\",\n    \"brand_id\": \"0cea7af3-23b2-4278-ab94-acf4076cbee4\",\n    \"success_redirect\": \"https://your.redirect.url/getResponse\",\n    \"failure_redirect\": \"https://your.redirect.url/getResponse\",\n    \"success_callback\": \"https://your.success.callback.url\",\n    \"failure_callback\": \"https://your.success.failure.url\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Error Message\",\n    \"code\": \"error_code\"\n}"}],"_postman_id":"58a3f40d-37aa-4949-96dc-1bd772ee1e77"},{"name":"Get Status","id":"a2460696-94a9-4ab8-919e-223be957f99b","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<p><strong>Note:</strong> With respect to bank transfers, the purchase request is synonymous with the PayIn request.</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"a488dd65-61ba-4a55-8f86-38dcbeb75d91","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"670cb0affcc7f4706acb65e0\",\r\n    \"client\": {\r\n        \"email\": \"ashishm.21190@gmail.com\",\r\n        \"phone\": \"+447755564318\",\r\n        \"full_name\": \"Test test\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"country\": \"CA\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"gender\": \"MALE\",\r\n        \"avatarUrl\": \"https://res.cloudinary.com/w22/image/upload/v1663783641/photos/currencies/ngn.png\",\r\n        \"stateCode\": \"QLD\"\r\n    },\r\n    \"updated_on\": 1728884911,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"INTERAC-REQUEST-MONEY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"redirectType\": \"POST\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1728884911,\r\n    \"merchantRef\": \"670cb0affcc7f4706acb65e0\",\r\n    \"merchantName\": \"ajay03\",\r\n    \"purchase\": {\r\n        \"currency\": \"CAD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"quantity\": 1,\r\n                \"price\": 1,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 1,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1,\r\n        \"expireInMin\": \"1440\",\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 1,\r\n        \"currency\": \"CAD\",\r\n        \"net_amount\": 1,\r\n        \"fee_amount\": 0,\r\n        \"pending_amount\": 0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1728884911,\r\n        \"remote_paid_on\": 1728884911\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"r4\",\r\n        \"brand_name\": \"r4\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 1,\r\n            \"masked_pan\": \"INTERAC-DEBIT\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"110.235.229.9\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"INTERAC-DEBIT\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"INTERAC-DEBIT\",\r\n                \"processing_time\": 1728884911,\r\n                \"extra\": {\r\n                    \"amount\": 1,\r\n                    \"masked_pan\": \"INTERAC-DEBIT\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1728884911\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1728884911\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1728884911\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1728884911\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"0cea7af3-23b2-4278-ab94-acf4076cbee4\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS3\",\r\n    \"issued\": \"2024-10-14\",\r\n    \"due\": 1728884911,\r\n    \"refund_upto\": 1744433315,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 1,\r\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://your.success.callback.url\",\r\n    \"failure_callback\": \"https://your.success.failure.url\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"110.235.229.9\",\r\n    \"checkout_url\": \"https://api.paysecure.net/payments/670cb0affcc7f4706acb65e0/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"0ea8a8ff-e534-4530-a89c-1eeb2ba886e0","name":"Failure","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Error Message\",\n    \"code\": \"error_code\"\n}"}],"_postman_id":"a2460696-94a9-4ab8-919e-223be957f99b"}],"id":"e4bb36f6-8725-47e4-b399-41d327597bcb","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://content.pstmn.io/f3b53540-b97f-49ee-b71d-377315760fba/V2hhdHNBcHAgSW1hZ2UgMjAyNC0xMi0wOSBhdCAxMS4wNi4yMi5qcGVn\" />\n\n<ol>\n<li><p>The merchant calls the INTERAC-REQUEST-MONEY /purchases API to initiate a Payin (deposit/collections) transaction.</p>\n</li>\n<li><p>Payment link is generated, and customer is redirected to follow the payment instructions.</p>\n</li>\n<li><p>After successful or failed payment by the end user, an appropriate webhook would be sent back to the merchant.</p>\n</li>\n</ol>\n","_postman_id":"e4bb36f6-8725-47e4-b399-41d327597bcb","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"91ea0bd8-d11f-4d1c-b213-c7eb984b59ec","id":"91ea0bd8-d11f-4d1c-b213-c7eb984b59ec","name":"🇨🇦 Interac Request Money","type":"folder"}}},{"name":"PayOut API","item":[{"name":"Create PayOut","id":"1c2a5432-07a0-45a6-b634-f46e9118db66","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"},{"key":"brandId","value":"your-brand-id","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"ashishm.21190@gmail.com\",\r\n        \"country\": \"CA\",\r\n        \"phone\": \"+14377717874\",\r\n        \"full_name\": \"Ashish Mistry\"\r\n    },\r\n    \"purpose\": \"Transfer Reversed\",\r\n    \"currency\": \"CAD\",\r\n    \"payoutMethod\": \"PAYOUT-INTERAC-REQUEST-MONEY\",\r\n    \"amount\": 1,\r\n    \"success_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\",\r\n    \"failure_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payment, the very first call to make is /payout/</p>\n<p>with the required data in the request body.</p>\n<p>To generate a Payout, you are required to provide the <code>API key</code> (in the header) can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a Payout request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email or client.phone</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td>Full Name of the user</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>CA</td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>PAYOUT-INTERAC-REQUEST-MONEY</td>\n</tr>\n<tr>\n<td>Currency</td>\n<td>Note this is currency account for which you have balance</td>\n</tr>\n<tr>\n<td>Amount</td>\n<td>amount in CAD</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>eg. \"Transfer Reversed\"</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"3004222a-d09c-4a2c-861d-7f22f4262854","id":"3004222a-d09c-4a2c-861d-7f22f4262854","name":"PayOut API","type":"folder"}},"urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"547d7cc6-5794-4558-a04c-1bb0f0c6b7bb","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"brandId","value":"your-brand-id","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"ashishm.21190@gmail.com\",\r\n        \"country\": \"CA\",\r\n        \"phone\": \"+14377717874\",\r\n        \"full_name\": \"Test Person-uk\"\r\n    },\r\n    \"purpose\": \"test payout\",\r\n    \"currency\": \"CAD\",\r\n    \"payoutMethod\": \"PAYOUT-INTERAC-REQUEST-MONEY\",\r\n    \"amount\": 10,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"payoutId\": \"670cb200fcc7f4706acb6759\",\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"phone\": \"+14377717874\",\n        \"full_name\": \"Ashish Mistry\",\n        \"country\": \"CA\"\n    },\n    \"updated_on\": 1728885248,\n    \"payoutMethod\": \"PAYOUT-INTERAC-REQUEST-MONEY\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 1,\n    \"errorMsg\": \"\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1728885248,\n    \"merchantRef\": \"670cb200fcc7f4706acb6759\",\n    \"status\": \"PAYOUT_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1728885248\n        },\n        {\n            \"status\": \"payout_in_process\",\n            \"timestamp\": 1728885253\n        }\n    ],\n    \"currency\": \"CAD\",\n    \"paymentOn\": 0,\n    \"payOutDetails\": {\n        \"emailAddress\": \"ashishm.21190@gmail.com\",\n        \"secretQA\": \"q670200747066759362\",\n        \"secretAnswer\": \"a670200747066759362\"\n    },\n    \"success_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\",\n    \"failure_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\"\n}"},{"id":"e42327f5-0a2f-4503-bb4f-7350b72cd6f1","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"brandId","value":"your-brand-id","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"ashishm.21190@gmail.com\",\r\n        \"country\": \"CA\",\r\n        \"phone\": \"+14377717874\",\r\n        \"full_name\": \"Test Person-uk\"\r\n    },\r\n    \"purpose\": \"test payout\",\r\n    \"currency\": \"CAD\",\r\n    \"payoutMethod\": \"PAYOUT-INTERAC-REQUEST-MONEY\",\r\n    \"amount\": 10,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Error Message\",\n    \"code\": \"error_code\"\n}"}],"_postman_id":"1c2a5432-07a0-45a6-b634-f46e9118db66"},{"name":"Get Status","id":"180253bc-2864-4037-a867-0b3f6fd87922","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/","description":"<p>This API tells you about all the details of a Payout, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the payoutId in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payout_in_process</td>\n<td>payout is under Processing.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><p>The webhook will only be triggered for paid transactions or errors.</p>\n<p>Paid: \"success_callback\": \"<a href=\"https://success.com\">https://success.com</a>\",</p>\n<p>Error: \"failure_callback\": “<a href=\"https://failure.com%E2%80%9D\">https://failure.com”</a></p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"3004222a-d09c-4a2c-861d-7f22f4262854","id":"3004222a-d09c-4a2c-861d-7f22f4262854","name":"PayOut API","type":"folder"}},"urlObject":{"path":["getpayout","{payoutId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"86aacfea-f125-4218-a781-b9498b170f62","name":"Get success Status","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"payoutId\": \"670926784600a76f8d8a1b43\",\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"phone\": \"+14377717874\",\n        \"full_name\": \"Ashish Mistry\",\n        \"country\": \"CA\"\n    },\n    \"updated_on\": 1728653103,\n    \"payoutMethod\": \"PAYOUT-INTERAC-DEBIT\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 1,\n    \"errorMsg\": \"\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1728652920,\n    \"merchantRef\": \"670926784600a76f8d8a1b43\",\n    \"merchantName\": \"Ajay002\",\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1728652920\n        },\n        {\n            \"status\": \"payout_in_process\",\n            \"timestamp\": 1728652924\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1728653103\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1729154507\n        }\n    ],\n    \"viewedOn\": 1729154507,\n    \"currency\": \"CAD\",\n    \"paymentOn\": 1728653103,\n    \"payOutDetails\": {\n        \"emailAddress\": \"ashishm.21190@gmail.com\",\n        \"secretQA\": \"q6709267846007688143362\",\n        \"secretAnswer\": \"a6709267846007688143362\"\n    },\n    \"success_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\",\n    \"failure_callback\": \"https://webhook.site/d7660184-d724-480c-bad0-cf0480f5518e\"\n}"},{"id":"3e28a6ed-1375-43d2-bbb2-a5afa6aea8e5","name":"Get Error Status","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Error Message\",\n    \"code\": \"error_code\"\n}"}],"_postman_id":"180253bc-2864-4037-a867-0b3f6fd87922"}],"id":"3004222a-d09c-4a2c-861d-7f22f4262854","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/Uxy8jmp5RP-c360-oIMAZy2As8naqJdARgKsWU0x_BtszfJlwdRVM6-obffbtjTABfI9V0hxH4Ad-Ns96We42lIMdL434tTzLJ6aEQBt0dzX_ZXeM4RtG_kmEeem7WIsN520Zh5PS3xTFYNzOmks0ak\" />\n\n<ul>\n<li><p>The merchant initiates a PayOut via the payout API.</p>\n</li>\n<li><p>Retrieve the PayOut details in the response JSON, where the customer is shown the following details required to make Interac payout: Security Question, Security Answer</p>\n</li>\n<li><p>After a successful or failed payment attempt, the status is reflected on the response, and the details of the status history. You can also get the status through getStatus (purchases/{payID}) API.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"3bb138bf-b84f-4439-9dca-a3db39a68b44","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"020e1872-249a-4340-bacf-ce3ac75f158b","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"3004222a-d09c-4a2c-861d-7f22f4262854"},{"name":"Get Balance API","item":[{"name":"Checking Balance","id":"1b34e9b6-d640-4a22-8c74-c5f68601b8c2","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"paymentMethod\": \"INTERAC-REQUEST-MONEY\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance","description":"<h2 id=\"api-for-checking-balance-payout\"><strong>API for Checking Balance payout</strong></h2>\n<ol>\n<li><p>URL :- /getBalance/</p>\n</li>\n<li><p>RequestType: POST</p>\n</li>\n<li><p>Request Body</p>\n</li>\n</ol>\n<p>Note: Currency is not a mandatory parameter. If no parameter is specified then all respective currency balances would be provided, if any specific currency parameter is provided then only that currency balance would be provided.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"e58689d5-c4b5-49fe-bd14-20b977cd01cc","id":"e58689d5-c4b5-49fe-bd14-20b977cd01cc","name":"Get Balance API","type":"folder"}},"urlObject":{"path":["getBalance"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"840b686b-dd98-48e2-9796-d5761a07ca15","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{\r\n    \"paymentMethod\": \"INTERAC-REQUEST-MONEY\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"currency\": \"CAD\",\r\n    \"balance\": \"2.22\",\r\n    \"paymentMethod\": \"INTERAC-REQUEST-MONEY\",\r\n    \"status\": \"success\"\r\n}"},{"id":"2081ceb2-9cc5-42b4-ae70-9157ef11c3c1","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{\r\n    \"paymentMethod\": \"INTERAC-REQUEST-MONEY\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"No currency account found\"\r\n}"}],"_postman_id":"1b34e9b6-d640-4a22-8c74-c5f68601b8c2"}],"id":"e58689d5-c4b5-49fe-bd14-20b977cd01cc","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"17932c18-6a06-463b-ad8d-e527e11d9592","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"61223523-081b-4263-bf8f-f900174a1c5d","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"e58689d5-c4b5-49fe-bd14-20b977cd01cc","description":""}],"id":"91ea0bd8-d11f-4d1c-b213-c7eb984b59ec","description":"<h2 id=\"interac-request-money-overview\">Interac Request Money Overview</h2>\n<p>Interac is a leading Canadian payment network that facilitates secure, real-time transactions between bank accounts. It offers multiple payment methods, including Request Money.</p>\n<p>Interac Request Money method allows users to send and receive money directly between bank accounts using payment link. It provides a fast, secure, and convenient alternative to traditional payment methods, accessible through most Canadian banks' online and mobile banking platforms.</p>\n<h3 id=\"interac-request-money-payment-suite-enables-merchants-to-initiate\"><strong>Interac Request Money payment suite enables merchants to initiate:</strong></h3>\n<ul>\n<li><p><strong>PayIns:</strong> Consumers can utilise Interac e-Transfer to transfer funds from their bank account, through their bank’s app or website.</p>\n</li>\n<li><p><strong>Payouts:</strong> Facilitate real-time disbursements directly to consumers' accounts.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"f3606355-103d-42e6-9304-f2b09d4d1018","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"ddf6f683-82ae-4722-aa64-d2ded859536c","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"91ea0bd8-d11f-4d1c-b213-c7eb984b59ec"},{"name":"🇨🇦 Interac Express","item":[{"name":"Concepts","item":[],"id":"1c4a4e2d-f1ed-4689-8620-449a3a06ff81","description":"<h2 id=\"customer-payment-journey\">Customer Payment Journey</h2>\n<ol>\n<li><p><strong>Merchant creates a payment request</strong> via Paysecure API and receives a Reference ID.</p>\n</li>\n<li><p><strong>Customer is shown the Reference ID</strong>, the recipient email/mobile, and the exact amount.</p>\n</li>\n<li><p><strong>Customer logs into their bank</strong> and initiates a transfer using these details.</p>\n</li>\n<li><p><strong>Customer must input the Reference ID</strong> in the message/memo field of the transfer.</p>\n</li>\n<li><p><strong>Paysecure matches the Reference ID</strong> and the payment amount to validate the transaction.</p>\n</li>\n</ol>\n<h3 id=\"edge-cases\">Edge Cases</h3>\n<ul>\n<li><p><strong>Incorrect or Missing Reference ID</strong>: Payment cannot be matched. The transaction will not be marked as successful and the amount will be auto-refunded after the transaction expires.</p>\n</li>\n<li><p><strong>Overpayment</strong>: The transaction will be marked as <strong>Paid</strong> and the excess amount will be <strong>auto-refunded</strong> to the customer.</p>\n</li>\n<li><p><strong>Underpayment</strong>: The transaction remains in <strong>In Progress</strong> status. The customer can:</p>\n<ul>\n<li><p>Pay the remaining amount using the same Reference ID, which will update the status to <strong>Paid</strong>, OR</p>\n</li>\n<li><p>Wait for expiry, after which the initial payment is <strong>auto-refunded</strong>.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Expired Transactions</strong>: All transactions are valid for <strong>24 hours</strong>. Any payment made after expiry is <strong>auto-refunded</strong>.</p>\n</li>\n</ul>\n","_postman_id":"1c4a4e2d-f1ed-4689-8620-449a3a06ff81"},{"name":"Payin API","item":[{"name":"Purchases","id":"f306faf8-2432-4c74-bfc0-859a63632697","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"seo2009@test.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test Customer\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"CA\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"CAD\",\r\n        \"expireInMin\": \"80\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 100\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"INTERAC-EXPRESS\",\r\n    \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\r\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://tyour.redirect.url/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://your.success.callback.url\",\r\n    \"failure_callback\": \"https://your.success.failure.url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. It must be upper case.  <br />This should be \"CA\" for Interac</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”.. Must be in upper case.</td>\n</tr>\n<tr>\n<td>client.street_address</td>\n<td></td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td></td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td></td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />This should be 'CAD' for Interac</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>name of the product or service</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in progress</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is UNSUCCESSFUL</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>The <code>purchase.expireInMin</code>, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td></td>\n</tr>\n<tr>\n<td>Enter Valid Email</td>\n<td></td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td></td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect/failure_redirect/brand_id is missing</td>\n<td></td>\n</tr>\n<tr>\n<td>brand_id cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>failure_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid failure_redirect: minimum 10 characters</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products[0].name/purchase.products[0].price are missing</td>\n<td></td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td></td>\n</tr>\n<tr>\n<td>Currency \"{curr_name}\" is Not Allowed</td>\n<td></td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong> For certain use cases, in addition to long format purchase Id, Paysecure also provides a 7 digit unique code for each purchase starting with digit 4, eg 4000001</p>\n<p><em>“purchaseIdShortCode”: “4000013\"</em></p>\n","urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"2a2b3ac4-b498-46c0-9ea3-ed254bd28938","name":"Purchase- success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"seo2009@test.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"CA\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"CAD\",\r\n        \"expireInMin\": \"80\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 100\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"INTERAC-EXPRESS\",\r\n    \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\r\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://your.redirect.url/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://your.success.callback.url\",\r\n    \"failure_callback\": \"https://your.success.failure.url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"6890aba7faa4173bbbbb76c6\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"seo2009@test.com\",\n        \"phone\": \"+447755564318\",\n        \"full_name\": \"Test test\",\n        \"date_of_birth\": \"1970-07-10\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"country\": \"CA\",\n        \"city\": \"London\",\n        \"zip_code\": \"W1S 3BE\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"QLD\"\n    },\n    \"updated_on\": 1754311599,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"INTERAC-EXPRESS\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"GET\",\n    \"force_recurring\": false,\n    \"created_on\": 1754311591,\n    \"extraParam\": {\n        \"reference\": \"wkdjabf43\"\n    },\n    \"merchantRef\": \"6890aba7faa4173bbbbb76c6\",\n    \"merchantName\": \"arunsinghal\",\n    \"purchase\": {\n        \"currency\": \"CAD\",\n        \"products\": [\n            {\n                \"name\": \"test\",\n                \"quantity\": 1.0,\n                \"price\": 100.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 100.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"expireInMin\": \"1440\",\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 100.0,\n        \"currency\": \"CAD\",\n        \"net_amount\": 100.0,\n        \"fee_amount\": 0.0,\n        \"pending_amount\": 0.0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1754311592,\n        \"remote_paid_on\": 1754311592\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"test6\",\n        \"brand_name\": \"test6\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"amount\": 100.0,\n            \"masked_pan\": \"INTERAC-EXPRESS\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"103.59.75.176, 104.23.216.90, 18.68.12.74\",\n                \"type\": \"execute\",\n                \"payment_method\": \"INTERAC-EXPRESS\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"INTERAC-EXPRESS\",\n                \"processing_time\": 1754311592,\n                \"extra\": {\n                    \"amount\": 100.0,\n                    \"masked_pan\": \"INTERAC-EXPRESS\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAYMENT_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1754311591\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1754311592\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1754311599\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"30f7ce6e-3b7e-46a2-9b50-484fc55be689\",\n    \"is_recurring_token\": false,\n    \"reference_generated\": \"PS1060\",\n    \"issued\": \"2025-08-04\",\n    \"due\": 1754311591,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"0\",\n    \"trustScore\": \"0\",\n    \"payInDetails\": {\n        \"name\": \"INTERAC E-TRANSFER\",\n        \"emailAddress\": \"fund@ieft.ca\",\n        \"reference_number\": \"8g1lya\"\n    },\n    \"paidOn\": 0,\n    \"receivedAmt\": 0.0,\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0.0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"103.59.75.176, 104.23.216.90, 18.68.12.74\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6890aba7faa4173bbbbb76c6/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"f306faf8-2432-4c74-bfc0-859a63632697"}],"id":"df3c815e-af7b-42e0-903c-cccb8a5f8502","description":"<h3 id=\"how-it-works\">How It Works</h3>\n<p>Interac-Express uses a <strong>Reference ID-based flow</strong> to streamline collections. Merchants generate a transaction-specific ID which customers must include when transferring funds from their bank account. This ensures precise, secure, and automated payment reconciliation.</p>\n<h4 id=\"key-steps\">Key Steps</h4>\n<p><strong>Flow:</strong></p>\n<ol>\n<li><p><strong>Initiate Payment Request</strong><br /> Merchant initiates a PayIn by calling the <code>/purchases</code> API. The request must include:</p>\n<ul>\n<li><p><code>paymentMethod</code>: <code>INTERAC-EXPRESS</code></p>\n</li>\n<li><p>Customer email or mobile</p>\n</li>\n<li><p>Amount</p>\n</li>\n<li><p>Optional message</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Reference ID Generation</strong><br /> Paysecure returns a unique <code>Reference ID</code> associated with the transaction. This ID is valid for 24 hours and must be included by the customer in the message/memo field during their bank transfer.</p>\n</li>\n<li><p><strong>Customer Transfer</strong><br /> The customer logs into their online or mobile banking, inputs the transfer amount, adds the Paysecure-provided email or mobile, and includes the Reference ID exactly as provided.</p>\n</li>\n<li><p><strong>Validation &amp; Matching</strong><br /> Paysecure validates the incoming transfer by matching the Reference ID and amount.</p>\n<ul>\n<li><p>If matched correctly, the transaction is marked as successful.</p>\n</li>\n<li><p>See edge cases above for incorrect, underpaid, overpaid, or expired scenarios.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Webhook Notification</strong><br /> Once the transfer is matched and verified, Paysecure sends a webhook to the merchant with full transaction details and status.</p>\n</li>\n<li><p><strong>Merchant Reconciliation</strong><br /> Merchant updates the customer account or order status based on the received webhook data.</p>\n</li>\n</ol>\n","_postman_id":"df3c815e-af7b-42e0-903c-cccb8a5f8502"},{"name":"Payout API","item":[{"name":"Create Payout","id":"beb5ce5e-de69-4e81-8d7d-b469399e388a","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"},{"key":"brandId","value":"your-brand-id","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"ashishm.21190@gmail.com\",\r\n        \"country\": \"CA\",\r\n        \"phone\": \"+14377717874\",\r\n        \"full_name\": \"Test Person-uk\"\r\n    },\r\n    \"purpose\": \"Transfer Reversed\",\r\n    \"currency\": \"CAD\",\r\n    \"payoutMethod\": \"PAYOUT-INTERAC-ETRANSFER\",\r\n    \"amount\": 10,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payment, the very first call to make is /payout/</p>\n<p>with the required data in the request body.</p>\n<p>To generate a Payout, you are required to provide the <code>API key</code> (in the header) can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a Payout request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email client.phone</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>CA</td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>PAYOUT-INTERAC-EXPRESS</td>\n</tr>\n<tr>\n<td>Currency</td>\n<td>CAD</td>\n</tr>\n<tr>\n<td>Amount</td>\n<td>Payout Amount</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>Transfer Reversed</td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"249cde06-9ec3-435d-ae65-0d72ca36e9e4","name":"create payout-success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"brandId","value":"your-brand-id","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"ashishm.21190@gmail.com\",\r\n        \"country\": \"CA\",\r\n        \"phone\": \"+14377717874\",\r\n        \"full_name\": \"Test Person-uk\"\r\n    },\r\n    \"purpose\": \"test payout\",\r\n    \"currency\": \"CAD\",\r\n    \"payoutMethod\": \"PAYOUT-INTERAC-EXPRESS\",\r\n    \"amount\": 10,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"payoutId\": \"67efc0586720dd3a164fe8b3\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"country\": \"CA\",\n        \"phone\": \"+14377717874\",\n        \"full_name\": \"Test Person-uk\"\n    },\n    \"updated_on\": 1743765592,\n    \"payoutMethod\": \"PAYOUT-INTERAC-EXPRESS\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 10,\n    \"errorMsg\": \"\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1743765592,\n    \"merchantRef\": \"67efc0586720dd3a164fe8b3\",\n    \"merchantName\": \"arunsinghal\",\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1743765592\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1743765610\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1744025266\n        }\n    ],\n    \"viewedOn\": 1744026844,\n    \"currency\": \"CAD\",\n    \"paymentOn\": 1743765610,\n    \"success_callback\": \"https://success.com\",\n    \"failure_callback\": \"https://failure.com\"\n}"}],"_postman_id":"beb5ce5e-de69-4e81-8d7d-b469399e388a"}],"id":"970c9e16-f400-410a-8fc7-9c8a34e1e6e3","description":"<h3 id=\"how-it-works\">How It Works</h3>\n<p>Merchants can send funds to customers using Interac-Express by specifying the recipient’s email or mobile. Funds are typically delivered in real-time, depending on the recipient’s bank setup.</p>\n<h4 id=\"key-steps\">Key Steps</h4>\n<p><strong>Flow:</strong></p>\n<ol>\n<li><p><strong>Initiate Payout Request</strong><br /> Merchant initiates a payout using the <code>/payout</code> API, passing:</p>\n<ul>\n<li><p><code>paymentMethod</code>: <code>INTERAC-EXPRESS</code></p>\n</li>\n<li><p>Recipient email or mobile number</p>\n</li>\n<li><p>Amount</p>\n</li>\n<li><p>Optional message</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Recipient Notification</strong><br /> The customer receives a notification from their bank to accept the incoming funds. If the recipient has <strong>Auto-Deposit</strong> enabled, funds are deposited instantly. Otherwise, the customer must manually claim the payment via the bank’s standard process.</p>\n</li>\n<li><p><strong>Webhook Confirmation</strong><br /> Paysecure notifies the merchant via webhook once the payout has been successfully claimed or credited.</p>\n</li>\n<li><p><strong>Update Records</strong><br /> Merchant updates the customer's profile or balance based on payout status.</p>\n</li>\n</ol>\n<hr />\n","_postman_id":"970c9e16-f400-410a-8fc7-9c8a34e1e6e3"}],"id":"a9bd276c-9cf0-4c98-bb80-95ca796ec3f2","description":"<h3 id=\"overview\">Overview</h3>\n<p>Interac-Express is a real-time Canadian payment method that enables secure bank-to-bank transfers through customer-initiated actions via their banking apps or websites. It’s designed for fast, reference-based validation—no security questions, no delays.</p>\n<p>Paysecure enables merchants to use Interac-Express for:</p>\n<ul>\n<li><p><strong>PayIns</strong>: Customers initiate bank transfers referencing a unique ID tied to their transaction.</p>\n</li>\n<li><p><strong>Payouts</strong>: Businesses can send funds directly to customer accounts in near real-time.</p>\n</li>\n</ul>\n","_postman_id":"a9bd276c-9cf0-4c98-bb80-95ca796ec3f2"},{"name":"🇧🇷 PIX","item":[{"name":"Concepts","item":[],"id":"b8aabd8a-f19c-48b7-85b9-cc9f2cb7761e","description":"<h2 id=\"payin-flows\">PayIn Flows</h2>\n<p><strong>How it works</strong><br />To initiate a PIX payment, a payer can scan the code using their PIX payment app (such as Itau, NuBank, etc).<br />These codes comply with BCB’s infrastructure requirements to ensure that the merchant's details are stored securely and there are no errors during the payment journey.  </p>\n<p><strong>Key Steps</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/UcxDawvzgu9zw6gCa8i_KrzNRn2baEIsJOJfAkuyBWu9yl3Hky5JyA0xQnNrT18ovLe4Lwl2sdD0kjKMFQUrYUMvnKimvRbxLio0pd5xjNy63PlYeV4phxMspF6sYGLug0OHaw__oWW8UE8m2Nt-3XA\" />\n\n<p><strong>Flow</strong></p>\n<ul>\n<li><p>Merchant platforms can create a dynamic QR code by passing the relevant parameter using Paysecure’s API.</p>\n</li>\n<li><p>The platform can display the dynamic QR code on its app or any website at checkout or on a third-party app.</p>\n</li>\n<li><p>The payer scans the QR code from the PIX app of their choice on their mobile.</p>\n</li>\n<li><p>The payer authorizes the transaction on the app by entering a valid PIN.</p>\n</li>\n<li><p>Once the payment is done, the merchant platform receives a transaction status callback from Paysecure to a pre-configured endpoint.</p>\n</li>\n<li><p>The platform can also check the request status using the reference ID generated from the collection request using the Check Payment Status API.</p>\n</li>\n</ul>\n<h2 id=\"payout-flows\"><strong>PayOut flows</strong></h2>\n<p><strong>How it works</strong></p>\n<p>To initiate a payout, the merchant has to give Paysecure the PIX details such as the recipient's PIX key (e.g., CPF/CNPJ, phone number, or email), amount, and any additional information.</p>\n<p>If the merchant has enough balance, then the transaction amount will be deducted from the merchant balance and sent to the user.</p>\n<p><strong>Key Steps</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/ezT3e0yYTc3TGWJ87RKK6sQpMhbgfr5Q-NfSMxnjz4WTxMJs5tr9-mUME-a2PpvYtA8QOrrKGw29dQFHdGcLsBiNW-jF-xiFxbuJZa0a7jd-zI3aIe6mO-JVSj6NIwiTyvBU_VVGGLdtOrjmX8Usf1k\" />\n\n<p><strong>Flow</strong></p>\n<ul>\n<li><p><strong>Initiation:</strong></p>\n<ul>\n<li><p><strong>User initiates:</strong> The process starts with a user requesting payout from the merchant.</p>\n</li>\n<li><p><strong>Merchant approval:</strong> if everything is OK, the merchant approves payout request</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Processing:</strong></p>\n<ul>\n<li><p><strong>Payment details:</strong> Using Paysecure’s API, the merchant provides the recipient's Pix key (which can be a phone number, email, CPF/CNPJ, or random key) and the transfer amount.</p>\n</li>\n<li><p><strong>Funds check:</strong> Paysecure verifies if sufficient funds are available in the merchant account to cover the transfer.</p>\n</li>\n<li><p><strong>Processing &amp; Key mapping:</strong> the recipient's Pix key is validated using the DICT (Transactional Identifier Directory). This central database links Pix keys with users' bank accounts.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Payout:</strong></p>\n<ul>\n<li><strong>Instant transfer:</strong> If everything checks out, the payer's bank instantly transfers the funds to the recipient's bank account. The recipient typically receives confirmation messages from their respective bank about the successful transaction.</li>\n</ul>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"bcecd6d1-8344-4c93-848b-e616da7a9852","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"b2c39a39-4cf6-483a-a4cc-641449d9cb55","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"b8aabd8a-f19c-48b7-85b9-cc9f2cb7761e"},{"name":"PayIn API","item":[{"name":"Purchases","id":"9dc2c43e-b2c8-4eae-bdb4-2da4b2e1e1bb","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"test@gmail.com\",\n        \"full_name\": \"test test\",\n        \"country\": \"BR\",\n        \"city\": \"Brasília\",\n        \"stateCode\": \"SP\",\n        \"street_address\": \"Praça da Bíblia 1308\",\n        \"zip_code\": \"57312-140\",\n        \"date_of_birth\": \"1994-31-04\",\n        \"phone\": \"+558262362732\",\n        \"tax_number\": \"39933551809\"\n    },\n    \"purchase\": {\n        \"currency\": \"BRL\",\n        \"products\": [\n            {\n                \"name\": \"test \",\n                \"price\": 10\n            }\n        ]\n    },\n    \"paymentMethod\": \"PIX\",\n    \"merchantRef\": \"test12\",\n    \"brand_id\": \"90ed108b-6753-465d-8a21-e2cc604ff814\",\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\n    \"success_callback\": \"https://test1.com\",\n    \"failure_callback\": \"https://test2.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"request-body-parameters\"><strong>Request Body Parameters:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.full_name</td>\n<td>Conditional.  <br />But Recommended to pass the complete name of the client. Atleast 2 words recommended.</td>\n</tr>\n<tr>\n<td>client.email</td>\n<td>Conditional.  <br />But Recommended to pass a correct email id.</td>\n</tr>\n<tr>\n<td>client.tax_number</td>\n<td>Mandatory.  <br />Pass the CPF (Brazilian tax identification number of customer), must contain 11 digits.</td>\n</tr>\n<tr>\n<td>paymentMethod</td>\n<td>Conditional.  <br />Mandatory if you are not using Paysecure Cashier. Else Non Mandatory.  <br />Value: PIX</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>Mandatory.  <br />ISO 4217 code for currency you want to send the transaction in. This should be 'BRL' for PIX.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>Mandatory.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Mandatory.  <br />Price in decimal format upto 2 decimals.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Mandatory.  <br />Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is in progress state.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Mandatory  <br />URL to send the user if the transactions has failed.</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong> the object “pix_payload.payload” contains all the necessary fields to create a page containing a QR code and other information on the merchant portal. The field “pix_payload.qr_code” value is in Base64. This can be used to show the QR code image. The field \"pix_payload.expiration_date\" is in UTC time.</p>\n<h2 id=\"essential-optional-parameters\">Essential Optional Parameters</h2>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td></td>\n</tr>\n<tr>\n<td>some Mandatory Parameter are missing</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid Email Format</td>\n<td></td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td></td>\n</tr>\n<tr>\n<td>Merchant Limit is not set</td>\n<td></td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td></td>\n</tr>\n<tr>\n<td>Brand not found!</td>\n<td></td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td></td>\n</tr>\n<tr>\n<td>Only <code>“{curr_name}\"</code> currency is allowed</td>\n<td></td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid_Parameter</td>\n<td>You'd usually get it when one or more mandatory parameters are not present in the request.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"61e7905f-af6e-41a3-910a-22b56594ed9c","id":"61e7905f-af6e-41a3-910a-22b56594ed9c","name":"PayIn API","type":"folder"}},"urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"16d67c87-cf25-4407-a4a6-ddb409f890b5","name":"Purchase- success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"Brasília\",\r\n        \"stateCode\": \"SP\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"57312-140\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+558262362732\",\r\n        \"tax_number\": \"39933551809\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"BRL\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"PIX\",\r\n    \"merchantRef\": \"test12\",\r\n    \"brand_id\": \"90ed108b-6753-465d-8a21-e2cc604ff814\",\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"65f9368cb905381ba207b3c4\",\n    \"client\": {\n        \"email\": \"test@gmail.com\",\n        \"full_name\": \"test test\",\n        \"country\": \"BR\",\n        \"city\": \"Brasília\",\n        \"stateCode\": \"SP\",\n        \"street_address\": \"Praça da Bíblia 1308\",\n        \"zip_code\": \"57312-140\",\n        \"date_of_birth\": \"1994-31-04\",\n        \"phone\": \"+558262362732\",\n        \"tax_number\": \"39933551809\"\n    },\n    \"updated_on\": 1710831244,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"PIX\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"POST\",\n    \"force_recurring\": false,\n    \"created_on\": 1710831244,\n    \"merchantRef\": \"65f9368cb905381ba207b3c4\",\n    \"merchantName\": \"test\",\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"price\": 10\n            }\n        ],\n        \"total\": 10,\n        \"language\": \"en\",\n        \"total_formatted\": 1,\n        \"timezone\": \"MIT\"\n    },\n    \"issuer_details\": {\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"newbrand\",\n        \"brand_name\": \"newbrand\"\n    },\n    \"transaction_data\": {},\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1764922723\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1764922723\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1764922727\n        }\n    ],\n    \"pix_payload\": {\n        \"payload\": \"00020101021226800014br.gov.bcb.pix2558pix.asaas.com/qr/cobv/e3eb36eb-7e9b-404d-9bd3-b486a42da3445204000053039865802BR5925A55 CONSULTORIA EM CREDIT6009Sao Paulo61080455202062070503***630451CA\",\n        \"qr_code\": \"iVBORw0KGgoAAAANSUhEUgAAAZ8AAAGfCAIAAAAPgEjDAAAP4UlEQVR42u3bUY7cSA4EUN … ..\",\n        \"expiration_date\": \"2025-03-27 23:59:59\"\n    },\n    \"is_test\": false,\n    \"brand_id\": \"90ed108b-6753-465d-8a21-e2cc604ff814\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS2696\",\n    \"issued\": \"2024-03-19\",\n    \"due\": 1710831244,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\n    \"success_callback\": \"https://test1.com\",\n    \"failure_callback\": \"https://test2.com\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"183.83.53.0\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/33ddc21c6073a7ac722288f0b2ec35be/\",\n    \"payoutProcess\": false\n}"},{"id":"6bd612b1-cdba-4f33-a8f6-9f6c40ff6733","name":"Purchase-error","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"Brasília\",\r\n        \"stateCode\": \"SP\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"57312-140\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+558262362732\",\r\n        \"tax_number\": \"39933551809\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"BRL\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"PIX\",\r\n    \"merchantRef\": \"test12\",\r\n    \"brand_id\": \"90ed1084-6753-465d-8a21-e2cc604ff814\",\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Brand not found!\",\n    \"code\": \"transaction_error\"\n}"}],"_postman_id":"9dc2c43e-b2c8-4eae-bdb4-2da4b2e1e1bb"},{"name":"Get Status","id":"3ebf2e9a-a957-4cd1-bf33-0e71471e6f06","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>The purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"f768d1ee-4c4b-4e5c-9a88-d3aab292a316","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n   \"purchaseId\": \"65f9368cb905381ba207b3c4\",\r\n   \"client\": {\r\n       \"email\": \"test@gmail.com\",\r\n       \"full_name\": \"Test test\",\r\n       \"tax_number\": \"39933551809\"\r\n   },\r\n   \"updated_on\": 1710831244,\r\n   \"type\": \"purchase\",\r\n   \"paymentMethod\": \"PIX\",\r\n   \"amountUnit\": \"MAJOR\",\r\n   \"errorMsg\": \"\",\r\n   \"redirectType\": \"POST\",\r\n   \"force_recurring\": false,\r\n   \"created_on\": 1710831244,\r\n   \"merchantRef\": \"65f9368cb905381ba207b3c4\",\r\n   \"merchantName\": \"test\",\r\n   \"purchase\": {\r\n       \"currency\": \"USD\",\r\n       \"products\": [\r\n           {\r\n               \"price\": 10.0\r\n           }\r\n       ],\r\n       \"total\": 10.0,\r\n       \"language\": \"en\",\r\n       \"total_formatted\": 1.0,\r\n       \"timezone\": \"MIT\"\r\n   },\r\n   \"issuer_details\": {\r\n       \"bank_accounts\": [\r\n           {\r\n               \"bank_account\": \"\",\r\n               \"bank_code\": \"\"\r\n           }\r\n       ],\r\n       \"legal_name\": \"newbrand\",\r\n       \"brand_name\": \"newbrand\"\r\n   },\r\n   \"transaction_data\": {},\r\n   \"status\": \"CREATED\",\r\n   \"status_history\": [\r\n       {\r\n           \"status\": \"created\",\r\n           \"timestamp\": 1710831244\r\n       }\r\n   ],\r\n   \"is_test\": false,\r\n   \"brand_id\": \"90ed108b-6753-465d-8a21-e2cc604ff814\",\r\n   \"send_receipt\": false,\r\n   \"is_recurring_token\": false,\r\n   \"skip_capture\": false,\r\n   \"reference_generated\": \"PS2696\",\r\n   \"issued\": \"2024-03-19\",\r\n   \"due\": 1710831244,\r\n   \"refund_upto\": 0,\r\n   \"cc_descriptor\": \"\",\r\n   \"fraudScore\": \"NA\",\r\n   \"trustScore\": \"NA\",\r\n   \"refund_availability\": \"NONE\",\r\n   \"refundable_amount\": 0.0,\r\n   \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n   \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\r\n   \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n   \"cancel_redirect\": \"\",\r\n   \"success_callback\": \"https://test1.com\",\r\n   \"failure_callback\": \"https://test2.com\",\r\n   \"platform\": \"API\",\r\n   \"created_from_ip\": \"223.182.100.34\",\r\n   \"checkout_url\": \"https://api.paysecure.net/payments/65f9368cb905381ba207b3c4/\"\r\n}\r\n"},{"id":"7e8adca0-f65d-44b8-8146-4a49aeb24664","name":"Failure","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}\r\n"}],"_postman_id":"3ebf2e9a-a957-4cd1-bf33-0e71471e6f06"}],"id":"61e7905f-af6e-41a3-910a-22b56594ed9c","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/QiIrZmMWISniXvk4h0Wpq5y4QDrWlUNK8cVUra7HhfDL9B12sdZv7kwGJ24R8Hs6AKPLRKZJafk1p5S3jCikw0V1lIBTVUy67hEgNRNNjH5Q2HysOP-3HlHZAjZiVvPsohyopIwZA48ejeFF0Ul1PX4\" />\n\n<ol>\n<li><p><strong>Initiate Purchase:</strong> The merchant calls the create purchase API to start the purchase process.</p>\n</li>\n<li><p><strong>Get Checkout URL:</strong> If the API call is successful, the response body contains a checkout URL.</p>\n</li>\n<li><p><strong>Redirect Client:</strong> The merchant redirects the client to the checkout URL received.</p>\n</li>\n<li><p><strong>Client Payment:</strong> The client is presented with a QR code to complete the payment.</p>\n<ol>\n<li>Please note that instead of redirecting to the checkout URL, the information to create a page on the merchant’s digital estate itself containing the QR code and other information can be achieved by utilizing the data on the “pix_payload“ object in the response.</li>\n</ol>\n</li>\n<li><p><strong>Payment Outcome:</strong> After the payment attempt, the client is redirected to a URL indicating success or failure, which was specified in the create purchase API.</p>\n</li>\n<li><p><strong>Callback Posting:</strong> Upon successful or failed payment, the entire payload of the transaction is posted to designated success or failure callback URLs.</p>\n</li>\n</ol>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"b3ab9718-4b76-4e6d-86fd-754a15d4bfac","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"9912eb92-0639-44af-bd37-4450b7179336","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"61e7905f-af6e-41a3-910a-22b56594ed9c"},{"name":"Refund API","item":[{"name":"Refund","id":"7648dd62-168d-4e02-8352-1d8f469ecca7","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund","description":"<p>This API is used to initate refund of the purchases that have status as <code>PAID</code></p>\n<p>Once the refund has been initiated, the status of the purchase would become <code>REFUND_IN_PROCESS</code> and once the refund has been approved by the bank, the status woud become <code>REFUNDED</code></p>\n<p>Purchase ID is <strong>mandatory</strong> for this API.</p>\n<p>If due to some reason, the refund has failed, the status would again become <code>PAID</code></p>\n<h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>successful</code> and <code>unsuccessful</code> in refund of purchases.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"cc776e6d-8c05-4a73-afed-808f7f574e51","id":"cc776e6d-8c05-4a73-afed-808f7f574e51","name":"🇧🇷 PIX","type":"folder"}},"urlObject":{"path":["purchases","657af976c3fceb7beb30eeb4","refund"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"5602864a-c565-413b-af90-2a291bc83efd","name":"Refund - Pending","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 16:33:43 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfdb7df63e36669499e82f\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690302819,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690295168,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 9,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 9,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 9,\n        \"currency\": \"USD\",\n        \"net_amount\": 9,\n        \"fee_amount\": 10.2591,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1690295205,\n        \"remote_paid_on\": 1690295205\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 9,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"US\",\n                \"processing_time\": 1690295205,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 9,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                }\n            },\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"refund\",\n                \"successful\": true,\n                \"processing_time\": 1690302819,\n                \"extra\": {\n                    \"amount\": 9\n                }\n            }\n        ]\n    },\n    \"status\": \"REFUND_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1690295168\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1690295193\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1690295205\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1690296521\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1690299929\n        },\n        {\n            \"status\": \"refund_in_process\",\n            \"timestamp\": 1690302819\n        }\n    ],\n    \"viewedOn\": 1690299929,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS192\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690295168,\n    \"refund_upto\": 1705843623,\n    \"cc_descriptor\": \"test-cardeye\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfdb7df63e36669499e82f/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfdb7df63e36669499e82f/\"\n}"},{"id":"9f6698d8-cf36-48c3-822f-69268927af4d","name":"Refund - Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 16:33:43 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfdb7df63e36669499e82f\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690302819,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690295168,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 9,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 9,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 9,\n        \"currency\": \"USD\",\n        \"net_amount\": 9,\n        \"fee_amount\": 10.2591,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1690295205,\n        \"remote_paid_on\": 1690295205\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 9,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"US\",\n                \"processing_time\": 1690295205,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 9,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                }\n            },\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"refund\",\n                \"successful\": true,\n                \"processing_time\": 1690302819,\n                \"extra\": {\n                    \"amount\": 9\n                }\n            }\n        ]\n    },\n    \"status\": \"REFUNDED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1690295168\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1690295193\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1690295205\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1690296521\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1690299929\n        },\n        {\n            \"status\": \"refunded\",\n            \"timestamp\": 1690302819\n        }\n    ],\n    \"viewedOn\": 1690299929,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS192\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690295168,\n    \"refund_upto\": 1705843623,\n    \"cc_descriptor\": \"test-cardeye\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfdb7df63e36669499e82f/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfdb7df63e36669499e82f/\"\n}"},{"id":"d40c230c-9377-4383-bf7d-fb27bcdb4ed2","name":"Refund - Error","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund"},"status":"Bad Request","code":400,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Thu, 13 Jul 2023 17:49:58 GMT"},{"key":"Connection","value":"close"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Only Purchases with `status == (paid)` can be refunded.\",\n    \"code\": \"transaction_error\"\n}"}],"_postman_id":"7648dd62-168d-4e02-8352-1d8f469ecca7"}],"id":"941e6f8c-1351-4306-af47-b231b1403db6","_postman_id":"941e6f8c-1351-4306-af47-b231b1403db6","description":"","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"cc776e6d-8c05-4a73-afed-808f7f574e51","id":"cc776e6d-8c05-4a73-afed-808f7f574e51","name":"🇧🇷 PIX","type":"folder"}}},{"name":"PayOut API","item":[{"name":"Create PayOut","id":"6544159d-64d5-45ca-a3e2-51a02d86d2d5","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"Brasília\",\r\n        \"stateCode\": \"SP\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"57312-140\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+558262362732\",\r\n        \"documentId\": \" 97c1c590-554b-4449-a0f1-8da9f9756937\",  \r\n        \"documentType\": \"evp\"\r\n    },\r\n    \"purpose\": \"payout to test\",\r\n    \"payoutMethod\": \"Payout-PIX\",\r\n    \"amount\": 10,\r\n    \"currency\": \"BRL\",\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payout, the very first call to make is /payout/ API with the required data in the request body.</p>\n<p>To generate a PayOut, you are required to provide the <code>API key</code> (in the header), which can be located in the Dashboard section of your merchant account login.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a payout request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>The customer's email.</td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td>The customer's phone number along with the country code.  <br />Example: +91 9634088651</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>amount</td>\n<td>amount in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>example: PAYOUT-PIX</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>The purpose of doing a payout.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"additional-parameters-for-this-usecase\">Additional <strong>parameters for this usecase:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.documentType</td>\n<td>Mandatory.  <br />Document Type Supported : cpf, cnpj, evp, email, phone  <br />  <br />cpf is Brazil's tax_id  <br />cnpj is Business tax_id  <br />evp is random key generated by the bank  <br />email is the email which supports pix  <br />phone is the phone number which supports pix</td>\n</tr>\n<tr>\n<td>client.documentId</td>\n<td>Mandatory.  <br />Document value of the type above.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"30eff71f-84de-4f87-bb03-f17c4693f217","id":"30eff71f-84de-4f87-bb03-f17c4693f217","name":"PayOut API","type":"folder"}},"urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"e90d4e0d-43ff-45be-bca1-cb7057e096a7","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"Brasília\",\r\n        \"stateCode\": \"SP\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"57312-140\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+558262362732\",\r\n        \"documentId\": \" 97c1c590-554b-4449-a0f1-8da9f9756937\",  \r\n        \"documentType\": \"evp\"\r\n    },\r\n    \"purpose\": \"payout to test\",\r\n    \"payoutMethod\": \"Payout-PIX\",\r\n    \"amount\": 10,\r\n    \"currency\": \"BRL\",\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"65f93895c96bae142f7b1765\",\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"Brasília\",\r\n        \"stateCode\": \"SP\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"57312-140\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+558262362732\",\r\n        \"documentId\": \" 97c1c590-554b-4449-a0f1-8da9f9756937\",\r\n        \"documentType\": \"evp\"\r\n    },\r\n    \"updated_on\": 1710831765,\r\n    \"payoutMethod\": \"Payout-PIX\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 10.0,\r\n    \"errorMsg\": \"\",\r\n    \"created_on\": 1710831768,\r\n    \"merchantName\": \"test\",\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1710831765\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1710831768\r\n        }\r\n    ],\r\n    \"currency\": \"BRL\",\r\n    \"purpose\": \"payout to test\",\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\"\r\n}"},{"id":"51d5f12c-bb41-4f51-b876-c7c0294fec06","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"Brasília\",\r\n        \"stateCode\": \"SP\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"57312-140\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+558262362732\",\r\n        \"documentId\": \" 97c1c590-554b-4449-a0f1-8da9f9756937\",  \r\n        \"documentType\": \"evp\"\r\n    },\r\n    \"purpose\": \"payout to test\",\r\n    \"payoutMethod\": \"Payout-PIX\",\r\n    \"amount\": 20,\r\n    \"currency\": \"BRL\",\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n   \"payoutId\": \"65f93895c96bae142f7b1765\",\r\n   \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"Brasília\",\r\n        \"stateCode\": \"SP\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"57312-140\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+558262362732\",\r\n        \"documentId\": \" 97c1c590-554b-4449-a0f1-8da9f9756937\",  \r\n        \"documentType\": \"evp\"\r\n   },\r\n   \"updated_on\": 1710831765,\r\n   \"payoutMethod\": \"Payout-PIX\",\r\n   \"amountUnit\": \"MAJOR\",\r\n   \"amount\": 20.0,\r\n   \"errorMsg\": \"errors.wallet.transfer_balance_insufficient\",\r\n   \"created_on\": 1710831768,\r\n   \"merchantRef\": \"65f93895c96bae142f7b1765\",\r\n   \"merchantName\": \"test\",\r\n   \"status\": \"ERROR\",\r\n   \"status_history\": [\r\n       {\r\n           \"status\": \"created\",\r\n           \"timestamp\": 1710831765\r\n       },\r\n       {\r\n           \"status\": \"error\",\r\n           \"timestamp\": 1710831768\r\n       }\r\n   ],\r\n   \"currency\": \"BRL\",\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\"\r\n}\r\n"}],"_postman_id":"6544159d-64d5-45ca-a3e2-51a02d86d2d5"},{"name":"Get Status","id":"c3d3a40b-7a8b-44d6-b763-568d521af133","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/","description":"<p>This API tells you about all the details of a Payout, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the payoutId in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payout_in_process</td>\n<td>payout is under Processing.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><p>The webhook will only be triggered for paid transactions or errors.</p>\n<p>Paid: \"success_callback\": \"<a href=\"https://success.com\">https://success.com</a>\",</p>\n<p>Error: \"failure_callback\": “<a href=\"https://failure.com%E2%80%9D\">https://failure.com”</a></p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"30eff71f-84de-4f87-bb03-f17c4693f217","id":"30eff71f-84de-4f87-bb03-f17c4693f217","name":"PayOut API","type":"folder"}},"urlObject":{"path":["getpayout","{payoutId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"08a3e69a-0314-4f87-8645-bc52b18cce2a","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"65f93895c96bae142f7b1765\",\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"Brasília\",\r\n        \"stateCode\": \"SP\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"57312-140\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+558262362732\",\r\n        \"documentId\": \" 97c1c590-554b-4449-a0f1-8da9f9756937\",\r\n        \"documentType\": \"evp\"\r\n    },\r\n    \"updated_on\": 1710831765,\r\n    \"payoutMethod\": \"Payout-PIX\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 10.0,\r\n    \"errorMsg\": \"\",\r\n    \"created_on\": 1710831768,\r\n    \"merchantName\": \"test\",\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1710831765\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1710831768\r\n        }\r\n    ],\r\n    \"currency\": \"BRL\",\r\n    \"purpose\": \"payout to test\",\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\"\r\n}"},{"id":"ddae3566-a77d-4adf-be78-5d6a901c6b1a","name":"Failure","originalRequest":{"method":"GET","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\n   \"payoutId\": \"65f93895c96bae142f7b1765\",\n   \"client\": {\n        \"email\": \"test@gmail.com\",\n        \"full_name\": \"test test\",\n        \"country\": \"BR\",\n        \"city\": \"Brasília\",\n        \"stateCode\": \"SP\",\n        \"street_address\": \"Praça da Bíblia 1308\",\n        \"zip_code\": \"57312-140\",\n        \"date_of_birth\": \"1994-31-04\",\n        \"phone\": \"+558262362732\",\n        \"documentId\": \" 97c1c590-554b-4449-a0f1-8da9f9756937\",  \n        \"documentType\": \"evp\"\n   },\n   \"updated_on\": 1710831765,\n   \"payoutMethod\": \"Payout-PIX\",\n   \"amountUnit\": \"MAJOR\",\n   \"amount\": 20.0,\n   \"errorMsg\": \"errors.wallet.transfer_balance_insufficient\",\n   \"created_on\": 1710831768,\n   \"merchantRef\": \"65f93895c96bae142f7b1765\",\n   \"merchantName\": \"test\",\n   \"status\": \"ERROR\",\n   \"status_history\": [\n       {\n           \"status\": \"created\",\n           \"timestamp\": 1710831765\n       },\n       {\n           \"status\": \"error\",\n           \"timestamp\": 1710831768\n       }\n   ],\n   \"currency\": \"BRL\",\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\n    \"pending_redirect\": \"https://test.com/getResponse.jsp?success=pending\",\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\n    \"success_callback\": \"https://test1.com\",\n    \"failure_callback\": \"https://test2.com\"\n}"}],"_postman_id":"c3d3a40b-7a8b-44d6-b763-568d521af133"}],"id":"30eff71f-84de-4f87-bb03-f17c4693f217","description":"<p><strong>Payout API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/C3wVvecNtQw4_DB4-8CRpFabuqko5aLMycrWTkTjyCTHPuK1Of3lNOiyyTV2wKCwT0gLmsFZkfAgJ4sa6NHBp3ea0l6dD9gJAX2FQhOTG4p7pa-YZzQRXY5aHsYOB8uGk76XIcBZ7rLq9G4gHbHnYqU\" />\n\n<p><strong>API Steps</strong></p>\n<ul>\n<li><p>The merchant initiates a PayOut via the payout API.</p>\n</li>\n<li><p>After a successful or failed payment attempt, the status is reflected on the response and the details of the status history.</p>\n</li>\n<li><p>To get the status of the transaction, call “/purchases/{purchaseId}/” API.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"1398aebd-4229-4235-9da4-95581e082ef4","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"77e7de18-1c2e-48c3-8314-cba37d39d053","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"30eff71f-84de-4f87-bb03-f17c4693f217"}],"id":"cc776e6d-8c05-4a73-afed-808f7f574e51","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"c4182687-76fd-4223-b6e8-f9d84c405ebf","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"4d381d55-9183-4d4c-a4de-bb8ac7376755","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"cc776e6d-8c05-4a73-afed-808f7f574e51","description":""},{"name":"🇪🇬 FawryPay","item":[{"name":"Concepts","item":[],"id":"25492c68-43fc-45f3-a849-d90b8f704176","description":"<h2 id=\"fawry-overview\">Fawry Overview</h2>\n<p>Fawry is a leading Egyptian payment network that facilitates secure, online and offline transactions across various financial services. It offers multiple payment options, including Fawry Pay, enabling seamless transactions between businesses and consumers.</p>\n<p>Fawry Pay allows users to make and receive payments directly through various channels, such as retail points, mobile apps, and online platforms. It provides a fast, secure, and convenient alternative to traditional payment methods, accessible through numerous banks and financial institutions in Egypt.</p>\n<h3 id=\"paysecures-fawry-product-suite-enables-merchants-to-initiate\"><strong>Paysecure’s Fawry product suite enables merchants to initiate:</strong></h3>\n<ul>\n<li><p>PayIns: Consumers can use Fawry Pay to transfer funds from their bank account or via Fawry’s extensive network of retail locations and online services.</p>\n</li>\n<li><p>Payouts*: Facilitate real-time disbursements directly to consumers' accounts or through Fawry's network.</p>\n</li>\n</ul>\n<p>*Note: Payouts APIs are under development and will be availabe soon</p>\n<h2 id=\"payin-flows\">PayIn Flows</h2>\n<p><strong>How it works</strong></p>\n<p>Paysecure’s Fawry PayIn leverages Fawry’s payment network to support a wide range of collection scenarios. Merchants can initiate payment requests via various channels such as mobile apps, online platforms, or physical retail points, providing secure, efficient, and flexible options for collecting payments from customers.</p>\n<p><strong>Key Steps</strong></p>\n<img src=\"https://content.pstmn.io/f6db7c5d-71f5-4e5e-aeb8-e238de5cff02/aW1hZ2UucG5n\" width=\"1351\" height=\"472\" />\n\n<p><strong>PayIn Flow</strong></p>\n<ul>\n<li><p>Initiate Payment: The customer initiates a payment by clicking on a ”Pay with FAWRY” button and selecting the deposit amount on the merchant’s website or app.</p>\n</li>\n<li><p>Receive Unique Reference Code: The customer is provided with a unique reference code for the payment.</p>\n</li>\n<li><p>Go to Fawry Agent: The customer visits a Fawry agent, which can be any shop or retail location within Fawry’s extensive network.</p>\n</li>\n<li><p>Provide Reference Code: The customer provides the unique reference code to the Fawry agent.</p>\n</li>\n<li><p>Make Payment: The customer pays the amount due in cash or through available electronic payment methods at the Fawry agent.</p>\n</li>\n<li><p>Receive Confirmation: The customer receives a confirmation message indicating that the payment was successful, either via SMS, email, or app notification.</p>\n</li>\n</ul>\n<h2 id=\"transaction-limits\">Transaction Limits:</h2>\n<h3 id=\"pay-ins\">Pay Ins:</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Criteria</strong></th>\n<th><strong>Min Amount</strong></th>\n<th><strong>Max Amount</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Per Transaction</td>\n<td>10 EGP</td>\n<td>100,000 EGP</td>\n</tr>\n<tr>\n<td>Per Day</td>\n<td></td>\n<td></td>\n</tr>\n<tr>\n<td>Per User</td>\n<td></td>\n<td></td>\n</tr>\n<tr>\n<td>Per Month</td>\n<td></td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"pay-outs\">Pay Outs:</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Criteria</strong></th>\n<th><strong>Min Amount</strong></th>\n<th><strong>Max Amount</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Per Transaction</td>\n<td>100 EGP</td>\n<td>150,000 EGP</td>\n</tr>\n<tr>\n<td>Per Day</td>\n<td></td>\n<td></td>\n</tr>\n<tr>\n<td>Per User</td>\n<td></td>\n<td></td>\n</tr>\n<tr>\n<td>Per Month</td>\n<td></td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div>","_postman_id":"25492c68-43fc-45f3-a849-d90b8f704176"},{"name":"PayIn API","item":[{"name":"Purchases","id":"22e9c043-4797-43d4-90bf-368eb1df18e8","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"DEEPAKDEEPAKSINGHAL@gmail.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"EG\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EGP\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"FawryPay\",\r\n    \"brand_id\": \"{{brand_id}}\",\r\n    \"success_redirect\": \"https://your.success.redirect.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td></td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. It must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”.. Must be in upper case.</td>\n</tr>\n<tr>\n<td>client.street_address</td>\n<td></td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td></td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td></td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />Please note, the currency has to be enbaled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is UNSUCCESSFUL</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td></td>\n</tr>\n<tr>\n<td>Enter Valid Email</td>\n<td></td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td></td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect/failure_redirect/brand_id is missing</td>\n<td></td>\n</tr>\n<tr>\n<td>brand_id cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>failure_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid failure_redirect: minimum 10 characters</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products[0].name/purchase.products[0].price are missing</td>\n<td></td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td></td>\n</tr>\n<tr>\n<td>Currency \"{curr_name}\" is Not Allowed</td>\n<td></td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong> For certain use cases, in addition to long format purchase Id, Paysecure also provides a 7 digit unique code for each purchase starting with digit 4, eg 4000001</p>\n<p><em>“purchaseIdShortCode”: “4000013\"</em></p>\n","urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"e1f3ecda-10d1-4c2d-8fdb-122a04ebdc39","name":"Purchase- success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"DEEPAKDEEPAKSINGHAL@gmail.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"EG\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EGP\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"FawryPay\",\r\n    \"brand_id\": \"{{brand_id}}\",\r\n    \"success_redirect\": \"https://your.success.redirect.com/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"667cfb2cf0bd8d672c8fc562\",\r\n    \"client\": {\r\n        \"email\": \"deepakdeepaksinghal@gmail.com\",\r\n        \"phone\": \"+447755564318\",\r\n        \"full_name\": \"Test test\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"country\": \"EG\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"QLD\"\r\n    },\r\n    \"updated_on\": 1719466796,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"FAWRYPAY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"redirectType\": \"POST\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1719466796,\r\n    \"merchantRef\": \"667cfb2cf0bd8d672c8fc562\",\r\n    \"instruction\": \"Please use the reference number 9350804722 to pay 10 EGP for this order at Fawrypay store. Complete the payment before 6/29/2024 5:39:59 AM +00:00\",\r\n    \"merchantName\": \"merchant002\",\r\n    \"purchase\": {\r\n        \"currency\": \"EGP\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"request_client_details\": [],\r\n        \"timezone\": \"MIT\",\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 10.0,\r\n        \"currency\": \"EGP\",\r\n        \"net_amount\": 10.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1719466796,\r\n        \"remote_paid_on\": 1719466796\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"test6\",\r\n        \"brand_name\": \"test6\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 10.0,\r\n            \"masked_pan\": \"FAWRYPAY\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"110.235.229.106\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"FAWRYPAY\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"FAWRYPAY\",\r\n                \"processing_time\": 1719466796,\r\n                \"extra\": {\r\n                    \"amount\": 10.0,\r\n                    \"masked_pan\": \"FAWRYPAY\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAYMENT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1719466796\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1719466796\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1719466796\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS10252\",\r\n    \"issued\": \"2024-06-27\",\r\n    \"due\": 1719466796,\r\n    \"refund_upto\": 1735015199,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"payInDetails\": {\r\n        \"reference_number\": \"9350804722\",\r\n        \"payment_method\": \"PAYATFAWRY\",\r\n        \"transaction_expiry\": \"29 Jun 2024 05:39:59:054 +0000\"\r\n    },\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 10.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com/getResponse.jsp?success=false\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n  \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"110.235.229.106\",\r\n    \"checkout_url\": \"https://api.paysecure.net/payments/667cfb2cf0bd8d672c8fc562/\"\r\n}"},{"id":"64625cc5-8472-4df2-ba36-1df834eda4fe","name":"Create Purchase","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}\r\n"}],"_postman_id":"22e9c043-4797-43d4-90bf-368eb1df18e8"},{"name":"Get Status","id":"70919d61-e6e2-4ea9-9872-88f2a350eef5","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<p><strong>Note:</strong> With respect to bank transfers, the purchase request is synonymous with the PayIn request.</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"9dfdeeaa-b8a3-453b-a198-4c50aa71cb00","name":"Purchases-success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"667cfc59f0bd8d672c8fc6c8\",\r\n    \"client\": {\r\n        \"email\": \"deepakdeepaksinghal@gmail.com\",\r\n        \"phone\": \"+447755564318\",\r\n        \"full_name\": \"Test test\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"country\": \"EG\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"QLD\"\r\n    },\r\n    \"updated_on\": 1719467097,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"FAWRYPAY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"redirectType\": \"POST\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1719467097,\r\n    \"merchantRef\": \"667cfc59f0bd8d672c8fc6c8\",\r\n    \"instruction\": \"Please use the reference number 9350717665 to pay 10 EGP for this order at Fawrypay store. Complete the payment before 6/29/2024 5:45:00 AM +00:00\",\r\n    \"merchantName\": \"merchant002\",\r\n    \"purchase\": {\r\n        \"currency\": \"EGP\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"request_client_details\": [],\r\n        \"timezone\": \"MIT\",\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 10.0,\r\n        \"currency\": \"EGP\",\r\n        \"net_amount\": 10.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1719467097,\r\n        \"remote_paid_on\": 1719467097\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"test6\",\r\n        \"brand_name\": \"test6\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 10.0,\r\n            \"masked_pan\": \"FAWRYPAY\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"110.235.229.106\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"FAWRYPAY\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"FAWRYPAY\",\r\n                \"processing_time\": 1719467097,\r\n                \"extra\": {\r\n                    \"amount\": 10.0,\r\n                    \"masked_pan\": \"FAWRYPAY\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAYMENT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1719467097\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1719467097\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1719467097\r\n        },\r\n        {\r\n            \"status\": \"viewed\",\r\n            \"timestamp\": 1719467160\r\n        }\r\n    ],\r\n    \"viewedOn\": 1719467160,\r\n    \"is_test\": false,\r\n    \"brand_id\": \"c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS10253\",\r\n    \"issued\": \"2024-06-27\",\r\n    \"due\": 1719467097,\r\n    \"refund_upto\": 1735015500,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"payInDetails\": {\r\n        \"reference_number\": \"9350717665\",\r\n        \"payment_method\": \"PAYATFAWRY\",\r\n        \"transaction_expiry\": \"29 Jun 2024 05:45:00:245 +0000\"\r\n    },\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 10.0,\r\n     \"success_redirect\": \"https://your.success.redirect.com/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com/getResponse.jsp?success=false\",\r\n    \"cancel_redirect\": \"\",\r\n     \"success_callback\": \"https://your.success.callback.com\",\r\n  \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"110.235.229.106\",\r\n     \"checkout_url\": \"https://api.paysecure.net/payments/667cfb2cf0bd8d672c8fc562/\"\r\n}"},{"id":"2a337056-e9ed-4dbb-b908-3062d98a8200","name":"Purchases","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}\r\n"}],"_postman_id":"70919d61-e6e2-4ea9-9872-88f2a350eef5"}],"id":"c8829e83-c0dc-463b-afce-0fa4195e3040","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/cfWw_RYZ9eZVEKzKjeRW4I_VwbBTyqH78LUrJG6ulp7FkE1pXVD6DZr9MnQXB9KH_oLFasJDb156naCsBc2bgotPaVY7LtGOJNifpTOb5uks3fjAKpgVhU4dsXQmQ7hFKNFIVhZEl2p8fCN1YufsRaA\" />\n\n<ol>\n<li><p>The merchant initiates the purchase via the create purchase API. If successful, they receive PayIn details (Unique Ref Code) along with a checkout URL in the response JSON</p>\n</li>\n<li><p>The merchant then has 2 options</p>\n<ol>\n<li><p>Use the PayIn details in the JSON to create a webpage within the merchant’s IT estate, and show to user the PayIn instruction</p>\n</li>\n<li><p>Or direct the end-user to our checkout URL, where the client sees bank details for payment.</p>\n</li>\n</ol>\n</li>\n<li><p>After a successful or failed payment by the end user, an appropriate webhook would be sent to the merchant. If option 2b was the method employed, the user would be redirected to the appropriate redirect URL.</p>\n</li>\n</ol>\n","_postman_id":"c8829e83-c0dc-463b-afce-0fa4195e3040"},{"name":"PayOut API","item":[{"name":"Create PayOut","id":"fc2ca64a-217b-43dd-a24f-3f115e5e07fc","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n    \"email\": \"test@gmail.com\",\r\n       \"country\" : \"EG\",\r\n \"phone\" : \"9586445444\",\r\n\"full_name\": \"Test Person-uk\",\r\n\"documentId\":\"29206260104051\"\r\n    },\r\n    \"purpose\" : \"test payout\",\r\n    \"currency\" : \"EGP\",\r\n    \"payoutMethod\" : \"Payout-fawrypay\",\r\n    \"amount\" : 20,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n    \r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payment, the very first call to make is/payout/</p>\n<p>with the required data in the request body.</p>\n<p>To generate a Payout, you are required to provide the <code>API key</code> (in the header) can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a Payout request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email or client.phone</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td></td>\n</tr>\n<tr>\n<td>client.country</td>\n<td></td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td></td>\n</tr>\n<tr>\n<td>Currency</td>\n<td>Note this is currency account for which you have balance</td>\n</tr>\n<tr>\n<td>Amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[{"disabled":true,"key":"","value":null},{"disabled":true,"key":null,"value":""}],"variable":[]}},"response":[{"id":"2db4e2be-2ffc-44f1-af6b-115876831499","name":"create payout-success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n    \"email\": \"test@gmail.com\",\r\n       \"country\" : \"EG\",\r\n \"phone\" : \"9586445444\",\r\n\"full_name\": \"Test Person-uk\",\r\n\"documentId\":\"29206260104051\"\r\n    },\r\n    \"purpose\" : \"test payout\",\r\n    \"currency\" : \"EGP\",\r\n    \"payoutMethod\" : \"Payout-fawrypay\",\r\n    \"amount\" : 20,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n    \r\n}","options":{"raw":{"language":"json"}}},"url":{"raw":"https://api.paysecure.net/api/v1/payout/","host":["https://api.paysecure.net/api/v1"],"path":["payout",""],"query":[{"key":"","value":null,"disabled":true},{"key":null,"value":"","disabled":true}]}},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"6687d86dde5d5c0feecf7621\",\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"phone\": \"9586445444\",\r\n        \"full_name\": \"Test Person-uk\",\r\n        \"country\": \"EG\",\r\n        \"documentId\": \"29206260104051\"\r\n    },\r\n    \"updated_on\": 1720178797,\r\n    \"payoutMethod\": \"PAYOUT-FAWRYPAY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 20.0,\r\n    \"errorMsg\": \"\",\r\n    \"purpose\": \"test payout\",\r\n    \"created_on\": 1720178797,\r\n    \"merchantRef\": \"6687d86dde5d5c0feecf7621\",\r\n    \"status\": \"PAYOUT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1720178797\r\n        },\r\n        {\r\n            \"status\": \"payout_in_process\",\r\n            \"timestamp\": 1720178799\r\n        }\r\n    ],\r\n    \"currency\": \"EGP\",\r\n    \"paymentOn\": 0,\r\n    \"payOutDetails\": {\r\n        \"instruction\": \"Please use transaction reference 20514294 with the BTC 77361 at any Fawry store to get cashout within 72 hrs\"\r\n    },\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}"},{"id":"40ce6702-3769-418d-9747-0f223e9015d0","name":"create payout-error","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n    \"email\": \"test@gmail.com\",\r\n       \"country\" : \"EG\",\r\n \"phone\" : \"9586445444\",\r\n\"full_name\": \"Test Person-uk\",\r\n\"documentId\":\"29206260104051\"\r\n    },\r\n    \"purpose\" : \"test payout\",\r\n    \"currency\" : \"EGP\",\r\n    \"payoutMethod\" : \"Payout-fawrypay\",\r\n    \"amount\" : 20,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n    \r\n}","options":{"raw":{"language":"json"}}},"url":{"raw":"https://api.paysecure.net/api/v1/payout/","host":["https://api.paysecure.net/api/v1"],"path":["payout",""],"query":[{"key":"","value":null,"disabled":true},{"key":null,"value":"","disabled":true}]}},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":" {\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}\r\n"}],"_postman_id":"fc2ca64a-217b-43dd-a24f-3f115e5e07fc"},{"name":"Get Status","id":"45ea3d2c-5629-4518-9244-ab3d597623e0","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/","description":"<p>This API tells you about all the details of a Payout, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the payoutId in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payout_in_process</td>\n<td>payout is under Processing.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><p>The webhook will only be triggered for paid transactions or errors.</p>\n<p>Paid: \"success_callback\": \"<a href=\"https://success.com\">https://success.com</a>\",</p>\n<p>Error: \"failure_callback\": “<a href=\"https://failure.com%E2%80%9D\">https://failure.com”</a></p>\n","urlObject":{"path":["getpayout","{payoutId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"542f60a8-a4ea-4393-a167-2ffdb78b4386","name":"Get success Status","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"6685467c0e5b201a73f91256\",\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"phone\": \"9586445444\",\r\n        \"full_name\": \"Test Person-uk\",\r\n        \"country\": \"EG\",\r\n        \"documentId\": \"29206260104051\"\r\n    },\r\n    \"updated_on\": 1720010823,\r\n    \"payoutMethod\": \"PAYOUT-FAWRYPAY\",\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountNumber\": \"123456789011\",\r\n        \"upi\": \"charles.babbage@okhdfc\",\r\n        \"transferType\": \"IMPS\",\r\n        \"ifscCode\": \"SBIN0001077\",\r\n        \"payeeName\": \"deepak singhal\"\r\n    },\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 20.0,\r\n    \"errorMsg\": \"\",\r\n    \"purpose\": \"test payout\",\r\n    \"created_on\": 1720010364,\r\n    \"merchantRef\": \"6685467c0e5b201a73f91256\",\r\n    \"merchantName\": \"test\",\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1720010364\r\n        },\r\n        {\r\n            \"status\": \"payout_in_process\",\r\n            \"timestamp\": 1720010367\r\n        },\r\n        {\r\n            \"status\": \"viewed\",\r\n            \"timestamp\": 1720010582\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1720010823\r\n        }\r\n    ],\r\n    \"viewedOn\": 1720179568,\r\n    \"currency\": \"EGP\",\r\n    \"paymentOn\": 1720010823,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}"},{"id":"9266b19d-2b27-4a8b-ad5a-55a65a43fc0b","name":"Get Error Status","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"45ea3d2c-5629-4518-9244-ab3d597623e0"}],"id":"b2278ff9-c01f-4717-afe6-38dc2eb43ed9","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/Uxy8jmp5RP-c360-oIMAZy2As8naqJdARgKsWU0x_BtszfJlwdRVM6-obffbtjTABfI9V0hxH4Ad-Ns96We42lIMdL434tTzLJ6aEQBt0dzX_ZXeM4RtG_kmEeem7WIsN520Zh5PS3xTFYNzOmks0ak\" />\n\n<ul>\n<li><p>The merchant initiates a PayOut via the payout API.</p>\n</li>\n<li><p>After a successful or failed payment attempt, the status is reflected on the response, and the details on the status history. You can also get the status through getStatus (purchases/{payID}) API.</p>\n</li>\n</ul>\n","_postman_id":"b2278ff9-c01f-4717-afe6-38dc2eb43ed9"},{"name":"Get Balance API","item":[{"name":"Checking Balance","id":"6178d832-c187-4abf-8d5c-a0da6b147ae2","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"INTERAC\"\r\n\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance","description":"<h2 id=\"api-for-checking-balance-payout\"><strong>API for Checking Balance payout</strong></h2>\n<ol>\n<li><p>URL :- /getBalance/</p>\n</li>\n<li><p>RequestType: POST</p>\n</li>\n<li><p>Request Body</p>\n</li>\n</ol>\n<p>Note: Currency is not a mandatory parameter. If no parameter is specified then all respective currency balances would be provided, if any specific currency parameter is provided then only that currency balance would be provided.</p>\n","urlObject":{"path":["getBalance"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"ebd94aa8-e888-4175-8680-2422b9638f9b","name":"Checking Balance payout-success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"INTERAC\"\r\n\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"paymentMethod\": \"FAWRYPAY\",\r\n    \"status\": \"success\",\r\n    \"data\": [\r\n        {\r\n            \"currency\": \"AUD\",\r\n            \"balance\": \"0.00\"\r\n        },\r\n        {\r\n            \"currency\": \"CAD\",\r\n            \"balance\": \"0.00\"\r\n        },\r\n        {\r\n            \"currency\": \"EGP\",\r\n            \"balance\": \"-1.20\"\r\n        },\r\n        {\r\n            \"currency\": \"EUR\",\r\n            \"balance\": \"0.00\"\r\n        },\r\n        {\r\n            \"currency\": \"GBP\",\r\n            \"balance\": \"0.00\"\r\n        },\r\n        {\r\n            \"currency\": \"INR\",\r\n            \"balance\": \"0.00\"\r\n        },\r\n        {\r\n            \"currency\": \"NGN\",\r\n            \"balance\": \"0.00\"\r\n        },\r\n        {\r\n            \"currency\": \"USD\",\r\n            \"balance\": \"0.00\"\r\n        },\r\n        {\r\n            \"currency\": \"ZAR\",\r\n            \"balance\": \"0.00\"\r\n        }\r\n    ]\r\n}\r\n"},{"id":"f8a13b99-1ba4-4601-8a3b-b3a41a82802a","name":"Checking Balance payout-error","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"INTERAC\"\r\n\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"No currency account found\"\r\n}\r\n"}],"_postman_id":"6178d832-c187-4abf-8d5c-a0da6b147ae2"}],"id":"a437ea4f-17a0-4a06-aee7-b5119ae2a403","_postman_id":"a437ea4f-17a0-4a06-aee7-b5119ae2a403","description":""}],"id":"0a21775d-1d55-4268-a968-5cdba811965a","_postman_id":"0a21775d-1d55-4268-a968-5cdba811965a","description":""},{"name":"🇮🇳 UPI Solution","item":[{"name":"Concepts","item":[],"id":"dd980600-8bdc-443d-a067-d18ce0e1f7f7","description":"<h2 id=\"upi-overview\">UPI Overview</h2>\n<p>The Unified Payments Interface (UPI) technology unifies various banking functions, smooth fund routing, and merchant payments under one roof by enabling numerous bank accounts into a single mobile application (of any participating bank).</p>\n<h3 id=\"paysecures-upi-product-suite-enables-merchants-to-initiate\"><strong>Paysecure’s UPI product suite enables merchants to initiate:</strong></h3>\n<ul>\n<li><p><strong>PayIns:</strong> Consumers can utilise UPI to transfer funds from their bank account, through their bank’s app or website.</p>\n</li>\n<li><p><strong>Payouts:</strong> Facilitate real-time disbursements directly to consumers' accounts by UPI ID, IMPS, RTGS,NEFT.</p>\n</li>\n</ul>\n<h2 id=\"payin-flows\">PayIn Flows</h2>\n<p><strong>How it works</strong></p>\n<p>Paysecure’s UPI PayIn API lets the platforms collect funds from payers through intent flow/payment link without entering the payer's VPA. Suitable for app or mobile-based flows.</p>\n<p><strong>Key Steps</strong></p>\n<img src=\"https://content.pstmn.io/3c74812c-5c9f-405b-ad81-8d87f944ddb0/aW1hZ2UucG5n\" width=\"1244\" height=\"560\" />\n\n<p><strong>Flow</strong></p>\n<ul>\n<li><p>Initiate Transfer Request: The merchant sends a request to the UPI PayIn API to initiate a PayIn (deposit/collections) transaction. This request includes the customer’s email address or mobile number, the amount to be collected, and an optional message.</p>\n</li>\n<li><p>UPI payment options: The API generates a Multiple payment option (PayTM, GPay, PhonePe apps as well by scanning QR code) where end user can select any one payment option to complete the transaction.</p>\n</li>\n<li><p>User pays using their App: User will then pay the amount using their desired payment app and method through default UPI apps or by scanning the QR code via any bank app)</p>\n</li>\n<li><p>Confirm Transfer Completion: Once the transfer is completed by the end user, the paysecure would send webhook of payment completion with the status. The balance of merchant would be updated to reflect the new transaction’s outcome.</p>\n</li>\n<li><p>Update Merchant’s Account: The merchant would then update (on the merchant’s system) the customer’s account balance to reflect the received funds.</p>\n</li>\n</ul>\n<h2 id=\"payout-flows\"><strong>PayOut flows</strong></h2>\n<p><strong>How it works</strong></p>\n<p>Our APIs enable payouts through various channels, including IMPS, UPI, RTGS, and NEFT, to user's bank accounts.</p>\n<p>Here are some common use cases, though not limited to these:</p>\n<ol>\n<li><p>Vendor Payouts: Quickly settle payments for goods or services with your vendors or distributors.</p>\n</li>\n<li><p>Payroll &amp; Reimbursements: Disburse salaries, ad-hoc payments, or employee reimbursements to staff or agents.</p>\n</li>\n<li><p>Disbursements: Facilitate loan or credit disbursements to merchants or consumers' bank accounts via your own or a lender's account.</p>\n</li>\n</ol>\n<p>*<em>Key Steps</em><em>*</em></p>\n<img src=\"https://content.pstmn.io/617fb471-49f3-42da-a00e-51059ae89857/aW1hZ2UucG5n\" width=\"1538\" height=\"570\" />\n\n<p><strong>Flow</strong></p>\n<ul>\n<li><p>We recommend that merchan't validate the bank accounts of their customer's bank account before doing payouts.</p>\n</li>\n<li><p>Ensure that enough balance is there in your merchant account do the payout.</p>\n</li>\n<li><p>The merchant platform initiates the creation of a payout by passing beneficiary details, along with payout details.</p>\n</li>\n<li><p>Beneficiary's bank details</p>\n<ul>\n<li><p>Beneficiary's transfer Type (IMPS, RTGS, NEFT, UPI)</p>\n</li>\n<li><p>Beneficiary's ifsc Code (if transferType is either of IMPS, RTGS, or NEFT)</p>\n</li>\n<li><p>Beneficiary's payee Name (if transferType is either of IMPS, RTGS, or NEFT)</p>\n</li>\n<li><p>Beneficiary's bank Account Number (if transferType is either of IMPS, RTGS, or NEFT)</p>\n</li>\n</ul>\n</li>\n<li><p>Upon completion of the payout, reaching either a Success or Failure state, Paysecure notifies the merchant’s platform via webhook, providing the final status of the transaction and additional details.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"08d10093-885c-4575-91f2-cb931ab4373e","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"00cae0a7-812b-4793-9f91-096940e9a56d","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"dd980600-8bdc-443d-a067-d18ce0e1f7f7"},{"name":"PayIn API","item":[{"name":"Purchases","id":"32a80665-c3c7-4885-be73-1019375c755a","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"IN\",\r\n        \"city\": \"Jaipur\",\r\n        \"stateCode\": \"RJ\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"302022\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+91 9634988765\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"INR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"price\": 100\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"UPI-QR\",\r\n    \"merchantRef\": \"test12\", // optional\r\n    \"brand_id\": \"{{merchant_brand_id}}\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>The customer's email.</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>purchase.products</td>\n<td>An object which contains the list of products which the customer is buying.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>The name of the product.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<p>Possible Payment Methods allowed: UPI-QR and UPI-INTENT</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Allowed Limit for this payment method for particular time period has been consumed</td>\n</tr>\n<tr>\n<td>some Mandatory Parameter are missing</td>\n</tr>\n<tr>\n<td>Invalid format of Date_of_Birth [allowed format: yyyy-mm-dd]</td>\n</tr>\n<tr>\n<td>Invalid Email Format</td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n</tr>\n<tr>\n<td>Merchant Limit is not set</td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n</tr>\n<tr>\n<td>Brand not found !</td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n</tr>\n<tr>\n<td>Only {{currencyCode}} currency is allowed.</td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n</tr>\n<tr>\n<td>Invalid_Parameter  <br />You'd usually get it when one or more mandatory parameters are not present in the request.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"f9e660c3-3b6a-4118-82bd-44e0c81c5b79","id":"f9e660c3-3b6a-4118-82bd-44e0c81c5b79","name":"PayIn API","type":"folder"}},"urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"56bbdd7a-b24e-4698-8b7f-1aeabae3033f","name":"UPI-QR","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"IN\",\r\n        \"city\": \"Jaipur\",\r\n        \"stateCode\": \"RJ\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"302022\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+91 9634988765\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"INR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"price\": 100\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"UPI-QR\",\r\n    \"merchantRef\": \"test12\", // optional\r\n    \"brand_id\": \"{{merchant_brand_id}}\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"status":"Success","code":202,"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"6682942d5273633e7b8d30c8\",\r\n    \"client\": {\r\n        \"email\": \"deepakdeepaksinghal@gmail.com\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"country\": \"EG\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"QLD\"\r\n    },\r\n    \"updated_on\": 1719833645,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"UPI-QR\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"redirectType\": \"POST\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1719833645,\r\n    \"merchantRef\": \"6682942d5273633e7b8d30c8\",\r\n    \"merchantName\": \"merchant002\",\r\n    \"purchase\": {\r\n        \"currency\": \"INR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"request_client_details\": [],\r\n        \"timezone\": \"MIT\",\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 10.0,\r\n        \"currency\": \"INR\",\r\n        \"net_amount\": 10.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1719833645,\r\n        \"remote_paid_on\": 1719833645\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"test6\",\r\n        \"brand_name\": \"test6\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 10.0,\r\n            \"masked_pan\": \"UPI\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"110.235.229.42\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"UPI-QR\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"UPI\",\r\n                \"processing_time\": 1719833645,\r\n                \"extra\": {\r\n                    \"amount\": 10.0,\r\n                    \"masked_pan\": \"UPI\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAYMENT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1719833645\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1719833645\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1719833645\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS10421\",\r\n    \"issued\": \"2024-07-01\",\r\n    \"due\": 1719833645,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"payInDetails\": {\r\n        \"expiration_date\": \"2025-03-27 23:59:59\",\r\n        \"qrCode\": \"iVBORw0KGgoAAAANSUhEUgAAAb0AAAG9AQAAAACpVZXpAAAH7UlEQVR4nO1cQY7qSgw0yiJLjpCbJBdDIhIXg5vkCCyzQPi7qtwkM2/zNcsYpIfeQFcvTNtdLtsx/9trtS/wC/wCv8A/AZ9mdnpevb9bt6zj+TWso3Uen17i33nGkgverotN/orP7FoHeHV/AG1nfnoZ+kfYrcdKv8ei/gEMvljxRkQZ4MVi5Ww2nm9LbBF/xnLYd7YVVu3dZ262hPUvA3+CUsCnDesJ39/PHhidtlg5cRFek9+WtSgwPO595ldGI4dTAohX/8ZpG2Hp8MdiQPnjEL7XIWJdEae6BfvgC0SxCGCx2Q2fvf5x5GMDGckRov7X2+8r4NhAvW6O82QrHBBeuGBHHjSHK7rDtDxtv8jD0YERv8PPwAHcRjogbv43/BF/wuZwytgHO9r4serxgbIg7vvzPNALY1GHzXDrwYJji2JgTsvOkY8PxGnDDYeVsPHcYjWoUtx6jF04cjPsa8PmjxWAroMWUbtbdPPHPuGZsOqdX8SfOJXGu26zagVgLILHraTWvOUDjRuuU4jq4a2xj8y9hLd6HaArFcMtD997gVoHJYCRwa8H2HzgWVxBDkoBxR5lraVHxIpgdWXEcjJKHrmw+S2Z071F8gLA+JSGCkwEbISoOFnJHiNtvSAhgc0RpyKmw/BeBqgUFUcJGIPWAZnjY1VXis+bUMdw93McHph0kXedfA/pBfMx5CKLlJCJ9n3+FEkOD1QSiuUyrSWaQfyuc0eS3UElm+m8ZYDNqrCbkQMgMMGWEcCQhdEB6a1Jsps/VgCGybASWTtOFu1Lz8SlD/lsgheepBXFupaUFQEiC4MXzozaRjYQrnhRAksioORDbx8doAAQkfwM3qzrP4MVI3lwRqeEOEgTgc37eyVg5zxFZNAuboR0HlkY5VZdbszbELtk6SpAk/DV44yBB2H5zFSWgR3KPAkSKIHZT3nt6EA4INgPmKJRim/1L1MljKI8zS0NbSwElG5qrX6DwsQkDQh5Kr91prI3V4jfqHUBYKfKH9jPQPbDCpchTkmop/xzgiYi9dULASm2863TQeuxGYuDYVUzmtFOm3tuxaDjA+Fi0AehAZFB0zOpfxikD4Uo7YOw9SFIBYAqkN4UyRnY4ZnNFWnfVlpX7WeTEI8PBGWepDvLZCDPopBZOQVVgj+CCNwaaaoBxP8p/zDloN5jZI/sQABGeYe7ctftyBUAPpmmozqBpAyZ/ArxmXmqfJTqIZVWbLGJJBWAtCXqN8rCqIN1rqh9N0qIs84dGzU2raMAkPEbJjMWt85atJg1fZXZhm7CURyqDvCpWpejnUci4QrxmWSSVQwqRGwT47qdEFQBOPCWpxeCPBulsl55KiyIOM96hiLWw+sAndSQB+1KqQxnjEBmIC+xb2NNjFnJp95RASjimEViKtAiTWoEM1bf1YHK2vKOPR4fiJuLyrIZuk0hNOP6Z9McsxJk8gsJEm44sYEqQHaghvF4fQk9ch+9MXR3aOdRJA9KsJVKDw9k1FbDE1WyiOkUghiwSQlQycmyz5mCRyWgZxAyFU2dJJvxm59RsgerlmS/XXMFgOzfYU3H1OFuSlaRnq288JyuyL5dhLJPB0IBIBa9mbCrOYxaqkqlqPwhlcU1B89Ud/wnklcABjdCmi4dEcoyo1Nrt2yVsDGrGGpqrgNUqY8siQblQXMeOcZv6Ijr1LpYdjWd4wM9h2yYcanE02gRxY3WmSHSxBKP1wFK4NFVz0i0jZUwO2Viz3PHA7nrfD4+8MlRLCRl4NITs42WxPdZxKGQdpXSah/aWQDo5IcJVB2ZhBrHi0UcmjY7eH/8HAWAraaTxMfSAU1ah9E9L8pAVD6tBGQnt/h1bMFGg3fLMdjUwvaMNfMOzCJtR+7wQPWucKBmZjjnV61DjJtxXkJpiO1qOhWAOV/TYhKcUpM2F91rxqGJVrHYdXcXAPIA5dDsIPXwnUZWOxRpgrMjEzORW8GrAnDO4tbE8QnORrCfBeeOMvSk3h/LLR6FgNtIIyui1OglaTAhYXNYamicufGdIx8eqFz9ZTkMYWy8dA1vqRp4Ir/2WcLINlBQAPgkIWQQz0c8OFvlkl8zA5lzGAeHz9+FgO6ii+y9QCRSowHdTtH9xOZTjWBn6asKUK2VvtBaUuFH+R62oAZkObLfKzM71wHCqhyVaFPpIs/emndV+mLfBmtivv85Dg9kAwajE+K3kg8lpq3YA0dlY48GAM+FgDklq7wDoVtUaVT/e/YdJDdiUcPrAHmeFJhemkBKMunZ/y6nZDeYGMKmzB8eCBshHW1T6VhuqdabzmI+P2Tpm1OWAWoei88uSBV+o9G7eimfN4O0f9e/enyg9PgL5Xk9tqDP9OKmKilbCNU0dxL6Wgr4aOlo/yGOagQ7yeZqwYRnXndlxArAnNHfRvbzXlML5ktJmWdij2rgsxAQVlVJMF2xaUCcGuUH6n9SpX3f9XR8IF7qQIiTlUWcznXf5/CRZfflqIGuaxkgDEVqaOyX4+VmnNvic2SyTCi5VRWfdgVUAF5dUVtj6KrpwL545dMX7TNg/LMaeHygnr7YxNM2JcEvVOLJrISKolk9oPpxW7ep+JJodLJqnkpN9Vs1IFxsarqzpLKHsrUXGaW1+vrFfj3w8+BA+iOHA1omrxbCJ9F67IP2oUK04+QFgC2Sq8U7x5CGTyVsaL3LLjIp9ywC/NPrC/wCv8Av8C/A/wCpreUSrYyOqQAAAABJRU5ErkJggg==\",\r\n    },\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"110.235.229.42\",\r\n    \"checkout_url\": \"https://api.paysecure.net/payments/6682942d5273633e7b8d30c8/\"\r\n}\r\n"},{"id":"491031bd-36e8-4fbe-9d1c-4b0768a50188","name":"UPI-INTENT","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"full_name\": \"test test\",\r\n        \"country\": \"IN\",\r\n        \"city\": \"Jaipur\",\r\n        \"stateCode\": \"RJ\",\r\n        \"street_address\": \"Praça da Bíblia 1308\",\r\n        \"zip_code\": \"302022\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+91 9634988765\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"INR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"price\": 100\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"UPI-INTENT\",\r\n    \"merchantRef\": \"test12\", // optional\r\n    \"brand_id\": \"{{merchant_brand_id}}\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"6682942d5273633e7b8d30c8\",\r\n    \"client\": {\r\n        \"email\": \"deepakdeepaksinghal@gmail.com\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"country\": \"EG\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"QLD\"\r\n    },\r\n    \"updated_on\": 1719833645,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"UPI-INTENT\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"redirectType\": \"POST\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1719833645,\r\n    \"merchantRef\": \"6682942d5273633e7b8d30c8\",\r\n    \"merchantName\": \"merchant002\",\r\n    \"purchase\": {\r\n        \"currency\": \"INR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"request_client_details\": [],\r\n        \"timezone\": \"MIT\",\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 10.0,\r\n        \"currency\": \"INR\",\r\n        \"net_amount\": 10.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1719833645,\r\n        \"remote_paid_on\": 1719833645\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"test6\",\r\n        \"brand_name\": \"test6\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 10.0,\r\n            \"masked_pan\": \"UPI\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"110.235.229.42\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"UPI-COLLECT\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"UPI\",\r\n                \"processing_time\": 1719833645,\r\n                \"extra\": {\r\n                    \"amount\": 10.0,\r\n                    \"masked_pan\": \"UPI\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAYMENT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1719833645\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1719833645\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1719833645\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS10421\",\r\n    \"issued\": \"2024-07-01\",\r\n    \"due\": 1719833645,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"payInDetails\": {\r\n        \"transaction_expiry\": \"2026-02-21 07:11:13\",\r\n        \"intentUri\": \"upi://pay?pa=bom260101330774%40mahb&am=101&tn=jamb&tr=jamb&pn=V%20S%20ENTERPRISEScu=\"\r\n    },\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"110.235.229.42\",\r\n    \"checkout_url\": \"https://api.paysecure.net/payments/6682942d5273633e7b8d30c8/\"\r\n}"}],"_postman_id":"32a80665-c3c7-4885-be73-1019375c755a"},{"name":"Get Status","id":"f3be53e4-055b-4f75-b94d-d211abe3b39b","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<p><strong>Note:</strong> With respect to bank transfers, the purchase request is synonymous with the PayIn request.</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"f9e660c3-3b6a-4118-82bd-44e0c81c5b79","id":"f9e660c3-3b6a-4118-82bd-44e0c81c5b79","name":"PayIn API","type":"folder"}},"urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"4f518cf7-b059-472f-86f9-0c8514efd2c2","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"66c4667bb993c970367c288a\",\r\n    \"client\": {\r\n        \"email\": \"deepakdeepaksinghal@gmail.com\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"country\": \"IN\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"QLD\"\r\n    },\r\n    \"updated_on\": 1724147324,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"UPI\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"redirectType\": \"POST\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1724147324,\r\n    \"merchantRef\": \"66c4667bb993c970367c288a\",\r\n    \"merchantName\": \"merchant002\",\r\n    \"purchase\": {\r\n        \"currency\": \"INR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"expireInMin\": \"35\",\r\n        \"request_client_details\": [],\r\n        \"timezone\": \"MIT\",\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 10.0,\r\n        \"currency\": \"INR\",\r\n        \"net_amount\": 10.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1724147324,\r\n        \"remote_paid_on\": 1724147324\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"test6\",\r\n        \"brand_name\": \"test6\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 10.0,\r\n            \"masked_pan\": \"UPI\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"103.59.75.113\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"UPI\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"UPI\",\r\n                \"processing_time\": 1724147324,\r\n                \"extra\": {\r\n                    \"amount\": 10.0,\r\n                    \"masked_pan\": \"UPI\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAYMENT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1724147324\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1724147324\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1724147324\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS10907\",\r\n    \"issued\": \"2024-08-20\",\r\n    \"due\": 1724147324,\r\n    \"refund_upto\": 1725871728,\r\n    \"cc_descriptor\": \"test1\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"payInDetails\": {\r\n        \"expiration_date\": \"2025-03-27 23:59:59\",\r\n        \"qrCode\": \"iVBORw0KGgoAAAANSUhEUgAAAb0AAAG9AQAAAACpVZXpAAAH7UlEQVR4nO1cQY7qSgw0yiJLjpCbJBdDIhIXg5vkCCyzQPi7qtwkM2/zNcsYpIfeQFcvTNtdLtsx/9trtS/wC/wCv8A/AZ9mdnpevb9bt6zj+TWso3Uen17i33nGkgverotN/orP7FoHeHV/AG1nfnoZ+kfYrcdKv8ei/gEMvljxRkQZ4MVi5Ww2nm9LbBF/xnLYd7YVVu3dZ262hPUvA3+CUsCnDesJ39/PHhidtlg5cRFek9+WtSgwPO595ldGI4dTAohX/8ZpG2Hp8MdiQPnjEL7XIWJdEae6BfvgC0SxCGCx2Q2fvf5x5GMDGckRov7X2+8r4NhAvW6O82QrHBBeuGBHHjSHK7rDtDxtv8jD0YERv8PPwAHcRjogbv43/BF/wuZwytgHO9r4serxgbIg7vvzPNALY1GHzXDrwYJji2JgTsvOkY8PxGnDDYeVsPHcYjWoUtx6jF04cjPsa8PmjxWAroMWUbtbdPPHPuGZsOqdX8SfOJXGu26zagVgLILHraTWvOUDjRuuU4jq4a2xj8y9hLd6HaArFcMtD997gVoHJYCRwa8H2HzgWVxBDkoBxR5lraVHxIpgdWXEcjJKHrmw+S2Z071F8gLA+JSGCkwEbISoOFnJHiNtvSAhgc0RpyKmw/BeBqgUFUcJGIPWAZnjY1VXis+bUMdw93McHph0kXedfA/pBfMx5CKLlJCJ9n3+FEkOD1QSiuUyrSWaQfyuc0eS3UElm+m8ZYDNqrCbkQMgMMGWEcCQhdEB6a1Jsps/VgCGybASWTtOFu1Lz8SlD/lsgheepBXFupaUFQEiC4MXzozaRjYQrnhRAksioORDbx8doAAQkfwM3qzrP4MVI3lwRqeEOEgTgc37eyVg5zxFZNAuboR0HlkY5VZdbszbELtk6SpAk/DV44yBB2H5zFSWgR3KPAkSKIHZT3nt6EA4INgPmKJRim/1L1MljKI8zS0NbSwElG5qrX6DwsQkDQh5Kr91prI3V4jfqHUBYKfKH9jPQPbDCpchTkmop/xzgiYi9dULASm2863TQeuxGYuDYVUzmtFOm3tuxaDjA+Fi0AehAZFB0zOpfxikD4Uo7YOw9SFIBYAqkN4UyRnY4ZnNFWnfVlpX7WeTEI8PBGWepDvLZCDPopBZOQVVgj+CCNwaaaoBxP8p/zDloN5jZI/sQABGeYe7ctftyBUAPpmmozqBpAyZ/ArxmXmqfJTqIZVWbLGJJBWAtCXqN8rCqIN1rqh9N0qIs84dGzU2raMAkPEbJjMWt85atJg1fZXZhm7CURyqDvCpWpejnUci4QrxmWSSVQwqRGwT47qdEFQBOPCWpxeCPBulsl55KiyIOM96hiLWw+sAndSQB+1KqQxnjEBmIC+xb2NNjFnJp95RASjimEViKtAiTWoEM1bf1YHK2vKOPR4fiJuLyrIZuk0hNOP6Z9McsxJk8gsJEm44sYEqQHaghvF4fQk9ch+9MXR3aOdRJA9KsJVKDw9k1FbDE1WyiOkUghiwSQlQycmyz5mCRyWgZxAyFU2dJJvxm59RsgerlmS/XXMFgOzfYU3H1OFuSlaRnq288JyuyL5dhLJPB0IBIBa9mbCrOYxaqkqlqPwhlcU1B89Ud/wnklcABjdCmi4dEcoyo1Nrt2yVsDGrGGpqrgNUqY8siQblQXMeOcZv6Ijr1LpYdjWd4wM9h2yYcanE02gRxY3WmSHSxBKP1wFK4NFVz0i0jZUwO2Viz3PHA7nrfD4+8MlRLCRl4NITs42WxPdZxKGQdpXSah/aWQDo5IcJVB2ZhBrHi0UcmjY7eH/8HAWAraaTxMfSAU1ah9E9L8pAVD6tBGQnt/h1bMFGg3fLMdjUwvaMNfMOzCJtR+7wQPWucKBmZjjnV61DjJtxXkJpiO1qOhWAOV/TYhKcUpM2F91rxqGJVrHYdXcXAPIA5dDsIPXwnUZWOxRpgrMjEzORW8GrAnDO4tbE8QnORrCfBeeOMvSk3h/LLR6FgNtIIyui1OglaTAhYXNYamicufGdIx8eqFz9ZTkMYWy8dA1vqRp4Ir/2WcLINlBQAPgkIWQQz0c8OFvlkl8zA5lzGAeHz9+FgO6ii+y9QCRSowHdTtH9xOZTjWBn6asKUK2VvtBaUuFH+R62oAZkObLfKzM71wHCqhyVaFPpIs/emndV+mLfBmtivv85Dg9kAwajE+K3kg8lpq3YA0dlY48GAM+FgDklq7wDoVtUaVT/e/YdJDdiUcPrAHmeFJhemkBKMunZ/y6nZDeYGMKmzB8eCBshHW1T6VhuqdabzmI+P2Tpm1OWAWoei88uSBV+o9G7eimfN4O0f9e/enyg9PgL5Xk9tqDP9OKmKilbCNU0dxL6Wgr4aOlo/yGOagQ7yeZqwYRnXndlxArAnNHfRvbzXlML5ktJmWdij2rgsxAQVlVJMF2xaUCcGuUH6n9SpX3f9XR8IF7qQIiTlUWcznXf5/CRZfflqIGuaxkgDEVqaOyX4+VmnNvic2SyTCi5VRWfdgVUAF5dUVtj6KrpwL545dMX7TNg/LMaeHygnr7YxNM2JcEvVOLJrISKolk9oPpxW7ep+JJodLJqnkpN9Vs1IFxsarqzpLKHsrUXGaW1+vrFfj3w8+BA+iOHA1omrxbCJ9F67IP2oUK04+QFgC2Sq8U7x5CGTyVsaL3LLjIp9ywC/NPrC/wCv8Av8C/A/wCpreUSrYyOqQAAAABJRU5ErkJggg==\"\r\n    },\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 10.0,\r\n    \"success_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=false\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://staging.paysecure.net\",\r\n    \"failure_callback\": \"https://staging.paysecure.net\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"103.59.75.113\",\r\n    \"checkout_url\": \"https://staging.paysecure.net/payments/66c4667bb993c970367c288a/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"fd6179b7-fca3-47c2-8254-211282082c7b","name":"Failure","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"f3be53e4-055b-4f75-b94d-d211abe3b39b"}],"id":"f9e660c3-3b6a-4118-82bd-44e0c81c5b79","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/cfWw_RYZ9eZVEKzKjeRW4I_VwbBTyqH78LUrJG6ulp7FkE1pXVD6DZr9MnQXB9KH_oLFasJDb156naCsBc2bgotPaVY7LtGOJNifpTOb5uks3fjAKpgVhU4dsXQmQ7hFKNFIVhZEl2p8fCN1YufsRaA\" />\n\n<ol>\n<li><p>The merchant initiates the purchase via the create purchase API. If successful, they receive a checkout URL in the response JSON. Sometimes they can also get an object of PayIn Details which they can use to make the payment.</p>\n</li>\n<li><p>The merchant then has 2 options</p>\n<ol>\n<li><p>Upon utilizing the checkout URL, depending on the payment method passed, the user will be presented with several payment choices from which to choose in order to complete the payment:</p>\n<ol>\n<li><p>QR Code</p>\n</li>\n<li><p>PhonePe, Googlepay or Paytm intent flow</p>\n</li>\n</ol>\n</li>\n<li><p>Retrieve the PayIn details in the response JSON (as shown below).</p>\n</li>\n</ol>\n</li>\n<li><p>After a successful or failed payment by the end user, an appropriate webhook would be sent to the merchant. If option 2a was the method employed, the user would be redirected to the appropriate redirect URL.</p>\n</li>\n</ol>\n<p><strong>Available Payment Methods</strong>: UPI-QR and UPI-INTENT</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"42cacc0d-d134-4323-bd90-34cd80aa23cf","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"381327d3-02d0-4fdc-a168-8cc4e061c2e1","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"f9e660c3-3b6a-4118-82bd-44e0c81c5b79"},{"name":"Payout","item":[{"name":"PayOut","id":"a500ebbb-7c93-46d8-837b-00d31c0d158f","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"customer141@gmail.com\",\n        \"phone\": \"+91 9634088651\",\n        \"country\": \"IN\",\n        \"zip_code\": \"302018\",\n        \"city\": \"Jaipur\",\n        \"street_address\": \"Vaishali Nagar\",\n        \"full_name\": \"Rahul Jain\",\n        \"stateCode\": \"RJ\"\n    },\n    \"beneficiaryDetail\": {\n        \"bankAccountName\": \"Rahul Jain\",\n        \"bankAccountNumber\": \"123456789012\",\n        \"ifscCode\": \"HDFC021212\"\n    },\n    \"payoutMethod\": \"Payout-BANKTRANSFER\",\n    \"amount\": 100,\n    \"currency\": \"INR\",\n    \"purpose\": \"payout for testing\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payment, the very first API call to make is <code>/payout/</code> with the required data in the request body.</p>\n<p>To generate a Payout, you are required to provide the <code>API key</code> (in the header) can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a Payout request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>The customer's email.</td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td>The customer's phone number along with the country code.  <br />Example: +91 9634088651</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>amount</td>\n<td>amount in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>example: PAYOUT-BANKTRANSFER</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>The purpose of doing a payout.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"additional-parameters-for-this-usecase\">Additional <strong>parameters for this usecase:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>beneficiaryDetail.bankName</td>\n<td>The Bank Name in which the customer want's to credit the money.  <br />  <br />Optional Field.  <br />If passed, only use the mentioned bank names below. Anything else might lead to payout failures.  <br />If you don't want to pass, then you might need to open our checkout_url in the response and user can select the Bank from the dropdown.</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.bankAccountName</td>\n<td>Mandatory Field.  <br />Account Holder's Full Name.  <br />It is advised to have atleast 2 words in the name.</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.bankAccountCurrency</td>\n<td>Optional Field.  <br />The Currency in which the money will be credited. Generally the same as the <code>currency</code> field mentioned above.</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.bankAccountNumber</td>\n<td>Mandatory Field.  <br />Account Holder's Account Number.  <br />This is the account in which the money will be credited.</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.ifscCode</td>\n<td>Mandatory Field.  <br />IFSC code of the account in which the money will be credited.</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.bankCountryCode</td>\n<td>Optional Field.  <br />The country code in which the account exist. Generally the same as the <code>country</code> field mentioned above.</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Bank Names:</strong></p>\n<img src=\"https://content.pstmn.io/94f46e68-73b7-4a16-bff1-1d4a57dd6e92/aW1hZ2UucG5n\" width=\"676\" height=\"3498\" />","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"87db92b1-5b1f-4118-87c7-b5e97e4de751","id":"87db92b1-5b1f-4118-87c7-b5e97e4de751","name":"Payout","type":"folder"}},"urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"f23c4b1a-7a19-4ebf-a5ed-79163f2dfe9f","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"customer141@gmail.com\",\r\n        \"phone\": \"+91 9634088651\",\r\n        \"country\": \"IN\",\r\n        \"zip_code\": \"302018\",\r\n        \"city\": \"Jaipur\",\r\n        \"street_address\": \"Vaishali Nagar\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountName\": \"Rahul Jain\",\r\n        \"bankAccountNumber\": \"123456789012\",\r\n        \"ifscCode\": \"HDFC021212\"\r\n    },\r\n    \"payoutMethod\": \"Payout-BANKTRANSFER\",\r\n    \"amount\": 100,\r\n    \"currency\": \"INR\",\r\n    \"purpose\": \"payout for testing\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"status":"Accepted","code":202,"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"6977137755e0628e3600c562\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"customer141@gmail.com\",\r\n        \"phone\": \"+91 9634088651\",\r\n        \"country\": \"IN\",\r\n        \"zip_code\": \"302018\",\r\n        \"city\": \"Jaipur\",\r\n        \"street_address\": \"Vaishali Nagar\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"updated_on\": 1769411447,\r\n    \"payoutMethod\": \"PAYOUT-BANKTRANSFER\",\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountName\": \"Rahul Jain\",\r\n        \"bankAccountNumber\": \"123456789012\",\r\n        \"ifscCode\": \"HDFC021212\"\r\n    },\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 100.0,\r\n    \"errorMsg\": \"\",\r\n    \"purpose\": \"payout for testing\",\r\n    \"created_on\": 1769411447,\r\n    \"merchantRef\": \"6977137755e0628e3600c562\",\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n\r\n    ],\r\n    \"currency\": \"INR\",\r\n    \"extraFee\": \"0\",\r\n    \"paymentOn\": 0,\r\n    \"checkout_url\": \"https://test4.paymentsclub.net/payout/092e59f94279a3742fa3715fe9a2112a/\",\r\n    \"taxAmount\": 0.0,\r\n    \"taxPercent\": 0.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n    \"redirectType\": \"POST\",\r\n    \"sessionId\": \"\",\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"trxMethod\": \"BANKTRANSFER\",\r\n    \"success_callback\": \"\",\r\n    \"failure_callback\": \"\"\r\n}"},{"id":"0f74911a-d55f-42dd-9fcb-7448ce145471","name":"Error","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"customer141@gmail.com\",\r\n        \"phone\": \"+91 9634088651\",\r\n        \"country\": \"IN\",\r\n        \"zip_code\": \"302018\",\r\n        \"city\": \"Jaipur\",\r\n        \"street_address\": \"Vaishali Nagar\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountName\": \"Rahul Jain\",\r\n        \"bankAccountNumber\": \"123456789012\",\r\n        \"ifscCode\": \"HDFC021212\"\r\n    },\r\n    \"payoutMethod\": \"Payout-BANKTRANSFER\",\r\n    \"amount\": 100,\r\n    \"currency\": \"INR\",\r\n    \"purpose\": \"payout for testing\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"6977137755e0628e3600c562\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"customer141@gmail.com\",\r\n        \"phone\": \"+91 9634088651\",\r\n        \"country\": \"IN\",\r\n        \"zip_code\": \"302018\",\r\n        \"city\": \"Jaipur\",\r\n        \"street_address\": \"Vaishali Nagar\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"updated_on\": 1769411447,\r\n    \"payoutMethod\": \"PAYOUT-BANKTRANSFER\",\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountName\": \"Rahul Jain\",\r\n        \"bankAccountNumber\": \"123456789012\",\r\n        \"ifscCode\": \"HDFC021212\"\r\n    },\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 100.0,\r\n    \"errorMsg\": \"This customer can not be processed !\",\r\n    \"purpose\": \"payout for testing\",\r\n    \"created_on\": 1769411447,\r\n    \"merchantRef\": \"6977137755e0628e3600c562\",\r\n    \"status\": \"ERROR\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n        {\r\n            \"status\": \"error\",\r\n            \"timestamp\": 1769411447\r\n        }\r\n    ],\r\n    \"currency\": \"INR\",\r\n    \"extraFee\": \"0\",\r\n    \"paymentOn\": 0,\r\n    \"checkout_url\": \"https://test4.paymentsclub.net/payout/092e59f94279a3742fa3715fe9a2112a/\",\r\n    \"taxAmount\": 0.0,\r\n    \"taxPercent\": 0.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n    \"redirectType\": \"POST\",\r\n    \"sessionId\": \"\",\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"trxMethod\": \"BANKTRANSFER\",\r\n    \"success_callback\": \"\",\r\n    \"failure_callback\": \"\"\r\n}"}],"_postman_id":"a500ebbb-7c93-46d8-837b-00d31c0d158f"},{"name":"Get Status","id":"608342b1-dff5-48fb-b73f-3fe3286733aa","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/","description":"<p>This API tells you about all the details of a Payout, including its history.</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the payoutId in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payout_in_process</td>\n<td>payout is under Processing.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"path":["getpayout","{payoutId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"ce38a709-cf1c-4480-8e12-a7c4bb2e2949","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"6977137755e0628e3600c562\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"customer141@gmail.com\",\r\n        \"phone\": \"+91 9634088651\",\r\n        \"country\": \"IN\",\r\n        \"zip_code\": \"302018\",\r\n        \"city\": \"Jaipur\",\r\n        \"street_address\": \"Vaishali Nagar\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"updated_on\": 1769411447,\r\n    \"payoutMethod\": \"PAYOUT-BANKTRANSFER\",\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountName\": \"Rahul Jain\",\r\n        \"bankAccountNumber\": \"123456789012\",\r\n        \"ifscCode\": \"HDFC021212\"\r\n    },\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 100.0,\r\n    \"errorMsg\": \"\",\r\n    \"purpose\": \"payout for testing\",\r\n    \"created_on\": 1769411447,\r\n    \"merchantRef\": \"6977137755e0628e3600c562\",\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n\r\n    ],\r\n    \"currency\": \"INR\",\r\n    \"extraFee\": \"0\",\r\n    \"paymentOn\": 0,\r\n    \"checkout_url\": \"https://test4.paymentsclub.net/payout/092e59f94279a3742fa3715fe9a2112a/\",\r\n    \"taxAmount\": 0.0,\r\n    \"taxPercent\": 0.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n    \"redirectType\": \"POST\",\r\n    \"sessionId\": \"\",\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"trxMethod\": \"BANKTRANSFER\",\r\n    \"success_callback\": \"\",\r\n    \"failure_callback\": \"\"\r\n}"},{"id":"1b78846d-3d7e-4eeb-9ecb-7961396608e4","name":"Error","originalRequest":{"method":"GET","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"6977137755e0628e3600c562\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"customer141@gmail.com\",\r\n        \"phone\": \"+91 9634088651\",\r\n        \"country\": \"IN\",\r\n        \"zip_code\": \"302018\",\r\n        \"city\": \"Jaipur\",\r\n        \"street_address\": \"Vaishali Nagar\",\r\n        \"full_name\": \"Rahul Jain\",\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"updated_on\": 1769411447,\r\n    \"payoutMethod\": \"PAYOUT-BANKTRANSFER\",\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountName\": \"Rahul Jain\",\r\n        \"bankAccountNumber\": \"123456789012\",\r\n        \"ifscCode\": \"HDFC021212\"\r\n    },\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 100.0,\r\n    \"errorMsg\": \"This customer can not be processed !\",\r\n    \"purpose\": \"payout for testing\",\r\n    \"created_on\": 1769411447,\r\n    \"merchantRef\": \"6977137755e0628e3600c562\",\r\n    \"status\": \"ERROR\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1769411447\r\n        },\r\n        {\r\n            \"status\": \"error\",\r\n            \"timestamp\": 1769411447\r\n        }\r\n    ],\r\n    \"currency\": \"INR\",\r\n    \"extraFee\": \"0\",\r\n    \"paymentOn\": 0,\r\n    \"checkout_url\": \"https://test4.paymentsclub.net/payout/092e59f94279a3742fa3715fe9a2112a/\",\r\n    \"taxAmount\": 0.0,\r\n    \"taxPercent\": 0.0,\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n    \"redirectType\": \"POST\",\r\n    \"sessionId\": \"\",\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"trxMethod\": \"BANKTRANSFER\",\r\n    \"success_callback\": \"\",\r\n    \"failure_callback\": \"\"\r\n}"}],"_postman_id":"608342b1-dff5-48fb-b73f-3fe3286733aa"}],"id":"87db92b1-5b1f-4118-87c7-b5e97e4de751","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/Uxy8jmp5RP-c360-oIMAZy2As8naqJdARgKsWU0x_BtszfJlwdRVM6-obffbtjTABfI9V0hxH4Ad-Ns96We42lIMdL434tTzLJ6aEQBt0dzX_ZXeM4RtG_kmEeem7WIsN520Zh5PS3xTFYNzOmks0ak\" />\n\n<ol>\n<li><p>The merchant initiates the payout via the create payout API. If successful, they will receive a paid status in the response. If any additional fields are required from the user, the status would be in pending and the user needs to be redirected to the checkout_url.</p>\n</li>\n<li><p>After a successful or failed payment by the end user, an appropriate webhook would be sent to the merchant. If the user would be redirected to the checkout_url for some additional details, once the user clicks on Pay, the user will be redirected to the appropriate redirect URL.</p>\n</li>\n</ol>\n<p>Available payout methods: PAYOUT-BANKTRANSFER</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"42cacc0d-d134-4323-bd90-34cd80aa23cf","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"381327d3-02d0-4fdc-a168-8cc4e061c2e1","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"87db92b1-5b1f-4118-87c7-b5e97e4de751"}],"id":"57bfd92d-a8ed-4707-a1eb-a6e603816199","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"614f1f41-357c-49f2-93b6-f4f3996d1377","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"cafa4f62-060e-4ebc-8a1d-969c36d83409","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"57bfd92d-a8ed-4707-a1eb-a6e603816199","description":""},{"name":"🇲🇽 SPEI Payments","item":[{"name":"Concepts","item":[],"id":"26e6991a-0ca5-45e9-9099-38d5905b5343","description":"<ol>\n<li><p><strong>CLABE (Clave Bancaria Estandarizada):</strong> A 18-digit standardized bank account identifier used to route funds correctly.</p>\n</li>\n<li><p><strong>Expiration Window:</strong> SPEI instructions typically expire within a 3 days; merchants must display clear expiry times to reduce failed payments.</p>\n</li>\n<li><p><strong>Webhook-Driven Confirmation:</strong> Once funds arrive, the SPEI network triggers a webhook to notify your system—no polling required.</p>\n</li>\n</ol>\n<h3 id=\"customer-journey\">Customer Journey</h3>\n<ol>\n<li><p><strong>Select SPEI at Checkout:</strong></p>\n<ul>\n<li><p>User adds items to cart, proceeds to checkout, and clicks “Pay with SPEI.”</p>\n</li>\n<li><p>Merchant’s site sends a Payin API request to generate SPEI instructions.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Display Payment Instructions:</strong></p>\n<ul>\n<li><p>Merchant shows a summary screen with:</p>\n<ul>\n<li><p><strong>Beneficiary CLABE (One-time CLABE)</strong></p>\n</li>\n<li><p><strong>Beneficiary Name</strong></p>\n</li>\n<li><p><strong>Amount (MXN)</strong></p>\n</li>\n<li><p><strong>Expiration Time</strong> (e.g., “Expires in 2 hours”)</p>\n</li>\n</ul>\n</li>\n</ul>\n</li>\n<li><p><strong>Customer Initiates Transfer:</strong></p>\n<ul>\n<li><p>Customer logs into their bank’s web/mobile app.</p>\n</li>\n<li><p>They select “Transfer via SPEI,” enter the provided CLABE, amount, and reference.</p>\n</li>\n<li><p>Customer confirms transfer (two-factor auth, OTP, or biometric—bank-dependent).</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Funds Sent &amp; Confirmation:</strong></p>\n<ul>\n<li><p>Once Banco de México settles the transfer (typically &lt;15 minutes), PaySecure’s SPEI webhook fires.</p>\n</li>\n<li><p>Merchant backend receives webhook payload with transaction status = “paid” (or “error,” “cancelled,” as applicable).</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Merchant Acknowledges Payment:</strong></p>\n<ul>\n<li><p>Backend updates order status to “Paid”</p>\n</li>\n<li><p>Frontend redirects customer to success page or sends confirmation email/SMS.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Edge Cases &amp; Failure Handling:</strong></p>\n<ul>\n<li><p>If customer never initiates transfer before expiration, status = “expired.”</p>\n</li>\n<li><p>If customer sends incorrect CLABE/amount, merchant receives webhook with error codes—trigger “error” flow.</p>\n</li>\n</ul>\n</li>\n</ol>\n","_postman_id":"26e6991a-0ca5-45e9-9099-38d5905b5343"},{"name":"Payin API","item":[{"name":"Payin API","id":"ffe274f7-0563-41a9-8b7a-d1b9b53850c7","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer {{your_API_Key}}"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"country\": \"MX\",\n        \"city\": \"123\",\n        \"stateCode\": \"ca\",\n        \"full_name\": \"Test test\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\",\n        \"phone\": \"9999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"MXN\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"price\": \"100\"\n            }\n        ]\n    },\n    \"paymentMethod\": \"SPEI\",\n    \"extraParam\": {},\n    \"status\": \"created\",\n    \"brand_id\": \"{{your_brand_id_}}\",\n    \"send_receipt\": \"\",\n    \"skip_capture\": \"\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<h3 id=\"1-endpoint--authentication\">1. Endpoint &amp; Authentication</h3>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-bash\">http POST &lt;https://api.paysecure.net/api/v1/purchases&gt;\nHeaders:\n  Authorization: Bearer {LIVE_API_KEY}\n  Content-Type: application/json\n\n</code></pre>\n<p>– Use your live or sandbox API key in the <code>Authorization</code> header.</p>\n<p>– All requests must be sent as <code>application/json</code>.</p>\n<hr />\n<h3 id=\"2-request-payload-structure\">2. Request Payload Structure</h3>\n<p>Supply a JSON payload with these top‐level objects:</p>\n<ul>\n<li><p><code>client</code> (customer details)</p>\n</li>\n<li><p><code>purchase</code> (order details)</p>\n</li>\n<li><p><code>paymentMethod</code> (string, must be <code>\"SPEI\"</code>)</p>\n</li>\n<li><p><code>extraParam</code> (optional, leave <code>{}</code> if unused)</p>\n</li>\n<li><p><code>status</code> (set to <code>\"created\"</code>)</p>\n</li>\n<li><p><code>brand_id</code> (your merchant/brand UUID)</p>\n</li>\n<li><p>Redirect &amp; callback URLs</p>\n</li>\n</ul>\n<hr />\n<h3 id=\"3-displaying-spei-instructions-to-end-user\">3. Displaying SPEI Instructions to End User</h3>\n<p>Once you parse <code>payInDetails</code> from the response:</p>\n<ol>\n<li><p><strong>Show CLABE, Beneficiary &amp; Amount</strong></p>\n</li>\n<li><p><strong>Display Expiration</strong></p>\n</li>\n<li><p><strong>Show Redirect Path (Optional)</strong></p>\n<ul>\n<li>If you’re using the hosted <code>checkout_url</code>, simply redirect customers to it and let Paysecure handle the UI.</li>\n</ul>\n</li>\n</ol>\n<hr />\n<h3 id=\"4-webhook-handling--status-transitions\">4. Webhook Handling &amp; Status Transitions</h3>\n<ol>\n<li><p><strong>Configure Webhooks</strong></p>\n<ul>\n<li>In Paysecure’s Dashboard, set your <code>success_callback</code> and <code>failure_callback</code> URLs (one for each event type).</li>\n</ul>\n</li>\n<li><p><strong>Listen for These Events</strong>:</p>\n<ul>\n<li><p><code>payment.paid</code> – Banco de México has settled the transfer.</p>\n</li>\n<li><p><code>payment.error</code> – CLABE/amount mismatch or network error.</p>\n</li>\n<li><p><code>payment.expired</code> – Customer did not pay before <code>expireInMin</code>.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Update Order Status</strong>:</p>\n<ul>\n<li><p>On <code>payment.paid</code>: mark as paid, trigger fulfillment, send confirmation.</p>\n</li>\n<li><p>On <code>payment.error</code>: alert customer, allow retry or alternative payment.</p>\n</li>\n<li><p>On <code>payment.expired</code>: cancel order.</p>\n</li>\n</ul>\n</li>\n</ol>\n","urlObject":{"protocol":"https","path":["api","v1","purchases"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"514b0237-ab71-4107-9777-75e79d627943","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer {{your_API_Key}}"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"country\": \"MX\",\n        \"city\": \"123\",\n        \"stateCode\": \"ca\",\n        \"full_name\": \"Test test\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\",\n        \"phone\": \"9999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"MXN\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"price\": \"100\"\n            }\n        ]\n    },\n    \"paymentMethod\": \"SPEI\",\n    \"extraParam\": {},\n    \"status\": \"created\",\n    \"brand_id\": \"{{your_brand_id_}}\",\n    \"send_receipt\": \"\",\n    \"skip_capture\": \"\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"683d768a22ae19559d740836\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"phone\": \"9999999999\",\n        \"full_name\": \"Test test\",\n        \"date_of_birth\": \"1970-07-10\",\n        \"street_address\": \"test test\",\n        \"country\": \"MX\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1748858506,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"SPEI\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"GET\",\n    \"force_recurring\": false,\n    \"created_on\": 1748858506,\n    \"extraParam\": {},\n    \"merchantRef\": \"683d768a22ae19559d740836\",\n    \"merchantName\": \"arunsinghal\",\n    \"purchase\": {\n        \"currency\": \"MXN\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 100,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 100,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"expireInMin\": \"4320\",\n        \"taxAmount\": 0,\n        \"taxPercent\": 0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 100,\n        \"currency\": \"MXN\",\n        \"net_amount\": 100,\n        \"fee_amount\": 0,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1748858506,\n        \"remote_paid_on\": 1748858506\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"test6\",\n        \"brand_name\": \"test6\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"amount\": 100,\n            \"masked_pan\": \"SPEI\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"103.59.75.242, 162.158.22.197, 130.176.183.5\",\n                \"type\": \"execute\",\n                \"payment_method\": \"SPEI\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"SPEI\",\n                \"processing_time\": 1748858506,\n                \"extra\": {\n                    \"amount\": 100,\n                    \"masked_pan\": \"SPEI\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAYMENT_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1748858506\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1748858506\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1748858506\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"{{your_brand_id}}\",\n    \"is_recurring_token\": false,\n    \"reference_generated\": \"PS786\",\n    \"issued\": \"2025-06-02\",\n    \"due\": 1748858506,\n    \"refund_upto\": 1749891706,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"0\",\n    \"trustScore\": \"2\",\n    \"payInDetails\": {\n        \"clabe\": \"710969000049618169\",\n        \"beneficiary\": \"CHOICEPAY LTD.\",\n        \"amount\": \"100.00\"\n    },\n    \"paidOn\": 0,\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 100,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"103.59.75.242, 162.158.22.197, 130.176.183.5\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/683d768a22ae19559d740836/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"ffe274f7-0563-41a9-8b7a-d1b9b53850c7"}],"id":"2c429738-5e7e-4b90-a5a2-7ddce8c77421","_postman_id":"2c429738-5e7e-4b90-a5a2-7ddce8c77421","description":""},{"name":"Payout API","item":[{"name":"Payout API","id":"a48eb645-7a13-4aee-b912-6e72d695edb9","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer {{your_API_Key}}"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"country\": \"MX\",\n        \"phone\": \"+14377717874\",\n        \"full_name\": \"MARCO ANTONIO FERNANDEZ RAMIREZ\",\n        \"stateCode\": \"test\",\n        \"spei_clabe\": \"012180027944986158\"\n    },\n    \"purpose\": \"payout\",\n    \"currency\": \"MXN\",\n    \"payoutMethod\": \"PAYOUT-SPEI\",\n    \"amount\": 20,\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\n    \"success_callback\": \"https://test1.com\",\n    \"failure_callback\": \"https://test2.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p><strong>Payout API Integration (SPEI)</strong></p>\n<hr />\n<h4 id=\"1-endpoint--authentication\">1. Endpoint &amp; Authentication</h4>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-bash\">http POST https://api.paysecure.net/api/v1/payout/\nHeaders:\n  Authorization: Bearer {LIVE_API_KEY}\n  Content-Type: application/json\n\n</code></pre>\n<ul>\n<li><p>Use your live or sandbox API key in the <code>Authorization</code> header.</p>\n</li>\n<li><p>All requests must be sent as <code>application/json</code>.</p>\n</li>\n</ul>\n<hr />\n<h4 id=\"2-request-payload-structure\">2. Request Payload Structure</h4>\n<p>Submit a JSON payload containing:</p>\n<ul>\n<li><p><code>client</code> (beneficiary details)</p>\n</li>\n<li><p><code>purpose</code> (should be <code>\"payout\"</code>)</p>\n</li>\n<li><p><code>currency</code> (always <code>\"MXN\"</code>)</p>\n</li>\n<li><p><code>payoutMethod</code> (must be <code>\"PAYOUT-SPEI\"</code>)</p>\n</li>\n<li><p><code>amount</code> (numeric, in major units)</p>\n</li>\n<li><p>Redirect &amp; callback URLs</p>\n</li>\n</ul>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">jsonCopy{\n  \"client\": {\n    \"email\": \"ashishm.21190@gmail.com\",\n    \"country\": \"MX\",\n    \"phone\": \"+14377717874\",\n    \"full_name\": \"MARCO ANTONIO FERNANDEZ RAMIREZ\",\n    \"stateCode\": \"test\",\n    \"spei_clabe\": \"012180027944986158\"\n  },\n  \"purpose\": \"payout\",\n  \"currency\": \"MXN\",\n  \"payoutMethod\": \"PAYOUT-SPEI\",\n  \"amount\": 20,\n  \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\n  \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\n  \"success_callback\": \"https://test1.com\",\n  \"failure_callback\": \"https://test2.com\"\n}\n\n</code></pre>\n<ul>\n<li><p><strong>client.email</strong>, <strong>client.phone</strong>, <strong>client.full_name</strong>, <strong>client.country</strong>, <strong>client.stateCode</strong>: Required beneficiary/contact info.</p>\n</li>\n<li><p><strong>client.spei_clabe</strong>: 18-digit CLABE of beneficiary’s bank account (validate format client-side to avoid runtime failures).</p>\n</li>\n<li><p><strong>purpose</strong>: Always set to <code>\"payout\"</code>.</p>\n</li>\n<li><p><strong>currency</strong>: Must be <code>\"MXN\"</code>.</p>\n</li>\n<li><p><strong>payoutMethod</strong>: Must be <code>\"PAYOUT-SPEI\"</code>.</p>\n</li>\n<li><p><strong>amount</strong>: Numeric amount (e.g., <code>20</code> for MXN 20.00).</p>\n</li>\n<li><p><strong>success_redirect</strong> / <strong>failure_redirect</strong>: URLs for end-user redirect after they click “Return to Merchant” (GET).</p>\n</li>\n<li><p><strong>success_callback</strong> / <strong>failure_callback</strong>: Webhook endpoints for asynchronous payout status notifications.</p>\n</li>\n</ul>\n<hr />\n<h4 id=\"3-sample-response--key-fields\">3. Sample Response &amp; Key Fields</h4>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">jsonCopy{\n  \"payoutId\": \"683d778dc74d23074a56ea94\",\n  \"client\": {\n    \"customerId\": \"NA\",\n    \"email\": \"ashishm.21190@gmail.com\",\n    \"phone\": \"+14377717874\",\n    \"full_name\": \"MARCO ANTONIO FERNANDEZ RAMIREZ\",\n    \"country\": \"MX\",\n    \"spei_clabe\": \"012180027944986155\",\n    \"stateCode\": \"test\"\n  },\n  \"updated_on\": 1748858765,\n  \"payoutMethod\": \"PAYOUT-SPEI\",\n  \"amountUnit\": \"MAJOR\",\n  \"amount\": 20.0,\n  \"errorMsg\": \"This customer can not be processed !\",\n  \"purpose\": \"test payout\",\n  \"created_on\": 1748858765,\n  \"merchantRef\": \"683d778dc74d23074a56ea94\",\n  \"status\": \"ERROR\",\n  \"status_history\": [\n    {\n      \"status\": \"created\",\n      \"timestamp\": 1748858765\n    },\n    {\n      \"status\": \"error\",\n      \"timestamp\": 1748858765\n    }\n  ],\n  \"currency\": \"MXN\",\n  \"paymentOn\": 0,\n  \"taxAmount\": 0.0,\n  \"taxPercent\": 0.0,\n  \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\n  \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\n  \"redirectType\": \"GET\",\n  \"success_callback\": \"https://test1.com\",\n  \"failure_callback\": \"https://test2.com\"\n}\n\n</code></pre>\n<ul>\n<li><p><strong>payoutId</strong> (<code>string</code>): Unique PaySecure identifier for this payout request.</p>\n</li>\n<li><p><strong>client.customerId</strong>: <code>\"NA\"</code> for a new beneficiary or your internal customer ID if returning.</p>\n</li>\n<li><p><strong>client.spei_clabe</strong>: Echoed beneficiary CLABE (note: if the CLABE in response differs by a digit, double-check formatting/validation).</p>\n</li>\n<li><p><strong>updated_on / created_on</strong>: Unix timestamps (seconds since epoch).</p>\n</li>\n<li><p><strong>payoutMethod</strong>: <code>\"PAYOUT-SPEI\"</code>.</p>\n</li>\n<li><p><strong>amountUnit</strong>: <code>\"MAJOR\"</code> indicates amount is in MXN major units (no subunit conversion required).</p>\n</li>\n<li><p><strong>amount</strong>: <code>20.0</code> (MXN 20.00).</p>\n</li>\n<li><p><strong>errorMsg</strong>: Describes any immediate rejection reason. If non-empty, <code>status</code> will be <code>\"ERROR\"</code>.</p>\n</li>\n<li><p><strong>purpose</strong>: Echo of the <code>\"payout\"</code> field or any custom string you passed.</p>\n</li>\n<li><p><strong>merchantRef</strong>: Mirror of <code>payoutId</code> by default; can be overwritten if you pass a custom reference.</p>\n</li>\n<li><p><strong>status</strong>: One of:</p>\n<ul>\n<li><p><code>\"created\"</code> → request accepted, preparing SPEI transfer</p>\n</li>\n<li><p><code>\"processing\"</code> → SPEI transfer initiated, awaiting Banco de México settlement</p>\n</li>\n<li><p><code>\"success\"</code> → funds successfully delivered</p>\n</li>\n<li><p><code>\"error\"</code> → immediate failure (e.g., invalid CLABE, validation issue)</p>\n</li>\n</ul>\n</li>\n<li><p><strong>status_history</strong>: Array showing timestamped states from <code>\"created\"</code> → <code>\"processing\"</code> → (<code>\"success\"</code> or <code>\"error\"</code>).</p>\n</li>\n<li><p><strong>paymentOn</strong>: Unix timestamp when the transfer actually occurred (0 if not delivered).</p>\n</li>\n<li><p><strong>redirectType</strong>: Always <code>\"GET\"</code>, meaning customer is redirected via HTTP GET to your provided URL.</p>\n</li>\n<li><p><strong>success_redirect</strong> / <strong>failure_redirect</strong> / <strong>success_callback</strong> / <strong>failure_callback</strong>: Echo of whatever you passed in request.</p>\n</li>\n</ul>\n<p><strong>Note:</strong> If you see <code>\"status\": \"ERROR\"</code> and an <code>errorMsg</code>, do not retry automatically—inspect the message, correct client data, then reinitiate a new payout request.</p>\n<hr />\n<h4 id=\"5-handling-payout-webhooks--status-flow\">5. Handling Payout Webhooks &amp; Status Flow</h4>\n<ol>\n<li><p><strong>Configure Webhooks</strong></p>\n<ul>\n<li>In your PaySecure Dashboard, register your <code>success_callback</code> and <code>failure_callback</code> URLs (these will receive POSTs once SPEI settles or fails).</li>\n</ul>\n</li>\n<li><p><strong>Listen for Events</strong></p>\n<ul>\n<li><p><code>payout.success</code>: Banco de México confirmed the credit to beneficiary’s CLABE.</p>\n</li>\n<li><p><code>payout.error</code>: CLABE invalid, account closed, or transfer rejected.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Update Your Records</strong></p>\n<ul>\n<li><p>On <code>payout.success</code>: Mark disbursement as complete; notify your finance/operations teams.</p>\n</li>\n<li><p>On <code>payout.error</code>: Log failure details, alert operations for manual review, and optionally retry after fixing the root cause.</p>\n</li>\n</ul>\n</li>\n</ol>\n","urlObject":{"protocol":"https","path":["api","v1","payout",""],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"0d66298d-10df-452c-adf1-7e427290722c","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer {{your_API_Key}}"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"country\": \"MX\",\n        \"phone\": \"+14377717874\",\n        \"full_name\": \"MARCO ANTONIO FERNANDEZ RAMIREZ\",\n        \"stateCode\": \"test\",\n        \"spei_clabe\": \"012180027944986158\"\n    },\n    \"purpose\": \"payout\",\n    \"currency\": \"MXN\",\n    \"payoutMethod\": \"PAYOUT-SPEI\",\n    \"amount\": 20,\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\n    \"success_callback\": \"https://test1.com\",\n    \"failure_callback\": \"https://test2.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"payoutId\": \"683d778dc74d23074a56ea94\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"phone\": \"+14377717874\",\n        \"full_name\": \"MARCO ANTONIO FERNANDEZ RAMIREZ\",\n        \"country\": \"MX\",\n        \"spei_clabe\": \"012180027944986155\",\n        \"stateCode\": \"test\"\n    },\n    \"updated_on\": 1748858765,\n    \"payoutMethod\": \"PAYOUT-SPEI\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 20,\n    \"errorMsg\": \"\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1748858765,\n    \"merchantRef\": \"683d778dc74d23074a56ea94\",\n    \"status\": \"paid\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1748858765\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1748858765\n        }\n    ],\n    \"currency\": \"MXN\",\n    \"paymentOn\": 0,\n    \"taxAmount\": 0,\n    \"taxPercent\": 0,\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\n    \"redirectType\": \"GET\",\n    \"success_callback\": \"https://test1.com\",\n    \"failure_callback\": \"https://test2.com\"\n}"}],"_postman_id":"a48eb645-7a13-4aee-b912-6e72d695edb9"}],"id":"1ebbb130-1f03-4294-a36b-fcaa409439fb","_postman_id":"1ebbb130-1f03-4294-a36b-fcaa409439fb","description":""}],"id":"7715610e-7143-44b2-879e-e17318c5ca6e","description":"<h2 id=\"overview\">Overview</h2>\n<p>SPEI (Sistema de Pagos Electrónicos Interbancarios) is Mexico’s real-time interbank transfer network operated by Banco de México. By integrating SPEI as a payment option, merchants can offer a frictionless, low-cost alternative to cards—funds settle in minutes, not days. SPEI is ubiquitous in Mexico (think coffee-to-cash within seconds), and this integration lets you tap into that network without reinventing the wheel.</p>\n<p>Key benefits:</p>\n<ul>\n<li><p><strong>Instant Settlement:</strong> Funds move from payer’s bank to merchant’s account in near real-time.</p>\n</li>\n<li><p><strong>Broad Adoption:</strong> Over 90% of Mexican bank accounts are SPEI-enabled.</p>\n</li>\n<li><p><strong>Low Fees:</strong> Typically lower transaction fees compared to card rails.</p>\n</li>\n<li><p><strong>Regulatory Compliance:</strong> Leverages Banco de México’s secure infrastructure and industry-standard validations.</p>\n</li>\n</ul>\n","_postman_id":"7715610e-7143-44b2-879e-e17318c5ca6e"},{"name":"🌍 MobileMoney (Africa)","item":[{"name":"Concepts","item":[],"id":"8df72e5e-85f0-48b8-ab91-74d37ed07d3c","description":"<h2 id=\"mobile-money-overview\"><strong>Mobile Money Overview</strong></h2>\n<p>Mobile Money is a digital payment service that allows users to send, receive, and manage money via their mobile devices. It facilitates secure and instant transactions directly between mobile wallets in the country, offering a convenient alternative to traditional banking methods in Africa.</p>\n<p>This payment method enables merchants to accept payments via Mobile Money from number of countries in Africa, and also to do payouts as well (to cutomer's local mobile wallet)</p>\n<h3 id=\"payins\"><strong>Payins</strong></h3>\n<p><strong>How It Works</strong></p>\n<p>The payin process harnesses mobile money capabilities to support effortless collections. Merchants can initiate payment requests via USSD, offering a secure, efficient, and flexible method to collect customer payments.</p>\n<blockquote>\n<p>💡 Note that the refunds are not possible over Mobile Money. Merchants have to initiate a PayOut request manually to process any refunds. </p>\n</blockquote>\n<p><strong>Key Steps</strong></p>\n<ol>\n<li><p><strong>Initiate Transfer Request:</strong><br /> The merchant sends a transaction request to the Mobile Money PayIn API. This request includes the customer’s mobile number, the collection amount, and an optional message.</p>\n</li>\n<li><p><strong>Send Notification:</strong><br /> The customer receives a USSD pop-up with payment instructions on their mobile device.</p>\n</li>\n<li><p><strong>Customer Completes Transfer:</strong><br /> The customer follows the USSD instructions, enters their security PIN if required, and authorizes the transfer of funds to the merchant’s account.</p>\n</li>\n<li><p><strong>Confirm Transfer Completion:</strong><br /> Once the payment is successful, the merchant receives a confirmation via a webhook indicating a successful transaction.</p>\n</li>\n<li><p><strong>Update Merchant’s Account:</strong><br /> The merchant’s system updates the customer’s account balance to reflect the received funds.</p>\n</li>\n</ol>\n<img src=\"https://content.pstmn.io/889a56dc-0e8a-4926-989a-9b9023d099eb/aW1hZ2UucG5n\" width=\"499\" height=\"319\" />\n\n<h3 id=\"payouts\"><strong>Payouts</strong></h3>\n<p>The payout API offers seamless payouts to customers over mobile money. Whether processing refunds, rewards, or other disbursements, our APIs delivers efficient, reliable transactions with real-time fund transfers and detailed transaction tracking.</p>\n<p><strong>Key Steps:</strong></p>\n<ol>\n<li><p><strong>Initiate Payout Request:</strong><br /> When a customer requests a withdrawal, the merchant site calls the Paysecure Payouts API to start the mobile money payout. This request includes the customer’s mobile number, the transfer amount, and the currency.</p>\n</li>\n<li><p><strong>Send Notification:</strong><br /> Customers receive an immediate USSD notification confirming the successful payout, while merchants are notified via an instant webhook.</p>\n</li>\n<li><p><strong>Update Merchant’s Account:</strong><br /> The merchant’s account balance is promptly updated to reflect the transaction.</p>\n</li>\n</ol>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"37a81c67-ae58-4bc3-ba2d-c5dce10b019d","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"6b1eb9d3-2e59-41ba-be4d-d6d1bd4a2636","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"8df72e5e-85f0-48b8-ab91-74d37ed07d3c"},{"name":"Coverage","item":[],"id":"3ae95e68-12aa-4cb2-878e-477ec02a45ad","description":"<h3 id=\"fully-supported-countries-pay-ins--pay-outs\">Fully Supported Countries: Pay-ins &amp; Pay-outs</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Country</strong></th>\n<th><strong>Region</strong></th>\n<th><strong>Telco</strong></th>\n<th><strong>Settlement Type</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Cameroon</td>\n<td>FSSA</td>\n<td>MTN</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Cameroon*</td>\n<td>FSSA</td>\n<td>Orange</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>DRC</td>\n<td>SEA</td>\n<td>Airtel</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>DRC</td>\n<td>SEA</td>\n<td>Orange</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>DRC</td>\n<td>SEA</td>\n<td>Vodacom</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Uganda</td>\n<td>SEA</td>\n<td>Airtel</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Uganda</td>\n<td>SEA</td>\n<td>MTN**</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Zambia</td>\n<td>SEA</td>\n<td>Airtel_*\\_</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Zambia</td>\n<td>SEA</td>\n<td>MTN</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n</tbody>\n</table>\n</div><hr />\n<p><strong>Footnotes:</strong></p>\n<ul>\n<li><p>For Cameroon, a licence is required.</p>\n</li>\n<li><p>MTN support in Uganda covers only pay-ins (collections).</p>\n</li>\n<li><p>Airtel support in Zambia covers only pay-ins (collections).</p>\n</li>\n</ul>\n<h2 id=\"partially-supported-countries\">Partially Supported Countries</h2>\n<h3 id=\"pay-ins-collections-only--crossborder\">Pay-ins (Collections) Only – Crossborder</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Country</strong></th>\n<th><strong>Region</strong></th>\n<th><strong>Telco</strong></th>\n<th><strong>Settlement Type</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Benin</td>\n<td>FSSA</td>\n<td>Moov</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Benin</td>\n<td>FSSA</td>\n<td>MTN</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Burkina Faso</td>\n<td>FSSA</td>\n<td>Moov</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Burkina Faso</td>\n<td>FSSA</td>\n<td>Orange</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Burkina Faso</td>\n<td>FSSA</td>\n<td>Mobicash</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Côte d'Ivoire</td>\n<td>FSSA</td>\n<td>Moov</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Côte d'Ivoire</td>\n<td>FSSA</td>\n<td>MTN</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Côte d'Ivoire</td>\n<td>FSSA</td>\n<td>Orange</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Côte d'Ivoire</td>\n<td>FSSA</td>\n<td>Wave</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Guinea Conakry</td>\n<td>FSSA</td>\n<td>MTN</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Guinea Conakry</td>\n<td>FSSA</td>\n<td>Orange</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Kenya</td>\n<td>SEA</td>\n<td>M-Pesa</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Mali</td>\n<td>FSSA</td>\n<td>Mobicash</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Mali</td>\n<td>FSSA</td>\n<td>Orange</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Nigeria</td>\n<td>AWA</td>\n<td>Baxi</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Nigeria</td>\n<td>AWA</td>\n<td>Banks</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Rwanda</td>\n<td>SEA</td>\n<td>Airtel</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Rwanda</td>\n<td>SEA</td>\n<td>MTN</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Senegal</td>\n<td>FSSA</td>\n<td>Free</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Senegal</td>\n<td>FSSA</td>\n<td>Orange</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Senegal</td>\n<td>FSSA</td>\n<td>Wave</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Tanzania</td>\n<td>SEA</td>\n<td>Airtel</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Tanzania</td>\n<td>SEA</td>\n<td>Vodacom</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Tanzania</td>\n<td>SEA</td>\n<td>Tigo</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Togo</td>\n<td>FSSA</td>\n<td>Moov – Flooz</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Togo</td>\n<td>FSSA</td>\n<td>Togocell T-Money</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n</tbody>\n</table>\n</div><p><em>Additional countries going live in General Release in Q2 2025: Botswana, Congo Brazzaville, and Gabon.</em></p>\n<p><em>South Africa will go liver in Q3 2025.</em></p>\n<hr />\n<h3 id=\"pay-outs-disbursement-only--crossborder\">Pay-outs (Disbursement) Only – Crossborder</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Country</strong></th>\n<th><strong>Region</strong></th>\n<th><strong>Telco</strong></th>\n<th><strong>Disbursement Type</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Ethiopia</td>\n<td>FSSA</td>\n<td>Amole</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Malawi</td>\n<td>SEA</td>\n<td>Airtel</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>Malawi</td>\n<td>SEA</td>\n<td>TNM</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n<tr>\n<td>South Sudan</td>\n<td>FSSA</td>\n<td>Mgurush</td>\n<td>Crossborder – USD, EUR</td>\n</tr>\n</tbody>\n</table>\n</div><p><em>Additional countries going live in General Release in Q2 2025 (subject to successful testing and compliance review): Botswana, Congo Brazzaville, Gabon, Ivory Coast (Côte d'Ivoire), Nigeria, Rwanda, Senegal, and Tanzania.</em><br /><strong>South Africa will go live in Q3.</strong><br /><em><strong>More countries to be launched in Q2 – please speak with your Account Manager or Sales Representative for further details.</strong></em></p>\n<p><strong>Region Abbreviations:</strong></p>\n<ul>\n<li><p><strong>FSSA:</strong> Francophone Sub-Saharan Africa</p>\n</li>\n<li><p><strong>SEA:</strong> Southern and Eastern Africa</p>\n</li>\n<li><p><strong>AWA:</strong> Anglophone West Africa</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"a7f80829-4146-40ff-8926-db335174cb41","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"9d6f4082-9c8c-4c0a-a1d8-7f05488c9dd4","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"3ae95e68-12aa-4cb2-878e-477ec02a45ad"},{"name":"PayIn API","item":[{"name":"Purchases","id":"46af627b-0976-4433-a642-c89f04497544","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"full_name\": \"akshaya singhal\",\n        \"email\": \"akshaya@gmail.com\",\n        \"country\": \"CD\",\n        \"city\": \"London\",\n        \"stateCode\": \"RJ\",\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\n        \"zip_code\": \"W1S 3BE\",\n        \"date_of_birth\": \"1994-31-04\",\n        \"phone\": \"+243999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"CDF\",\n        \"products\": [\n            {\n                \"name\": \"Test Product\",\n                \"price\": \"100\"\n            }\n        ]\n    },\n    \"paymentMethod\": \"MOBILEMONEY\",\n    \"brand_id\": \"your-brand-id\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a user, should be a valid email.</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>City of the user.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. It must be upper case.</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>ISO-3166-2 State Code. Must be in upper case.</td>\n</tr>\n<tr>\n<td>client.street_address</td>\n<td>street address of the user.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>zip code of the user.</td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td>Phone number of the user. Country code is mandatory.  <br />Example: +234999999999</td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td>Full name of the user. Minimum 2 words with atleast 1 character in each word.</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />eg. This should be 'TZS' for Tanzania  <br />CDF for Congo.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Amount in decimal upto 2 places.</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in progress</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is UNSUCCESSFUL</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td></td>\n</tr>\n<tr>\n<td>Enter Valid Email</td>\n<td></td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td></td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect/failure_redirect/brand_id is missing</td>\n<td></td>\n</tr>\n<tr>\n<td>brand_id cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>failure_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid failure_redirect: minimum 10 characters</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products[0].name/purchase.products[0].price are missing</td>\n<td></td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td></td>\n</tr>\n<tr>\n<td>Currency \"{curr_name}\" is Not Allowed</td>\n<td></td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong> For certain use cases, in addition to long format purchase Id, Paysecure also provides a 7 digit unique code for each purchase starting with digit 4, eg 4000001</p>\n<p><em>“purchaseIdShortCode”: “4000013\"</em></p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"c3272678-8c3d-4a56-b6ec-2b6abad272c3","id":"c3272678-8c3d-4a56-b6ec-2b6abad272c3","name":"PayIn API","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","purchases",""],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"6d8b64fc-4fec-40a2-a46d-471b4e19e86f","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"full_name\": \"akshaya singhal\",\n        \"email\": \"akshaya@gmail.com\",\n        \"country\": \"CD\",\n        \"city\": \"London\",\n        \"stateCode\": \"RJ\",\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\n        \"zip_code\": \"W1S 3BE\",\n        \"date_of_birth\": \"1994-31-04\",\n        \"phone\": \"+243999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"CDF\",\n        \"products\": [\n            {\n                \"name\": \"Test Product\",\n                \"price\": \"100\"\n            }\n        ]\n    },\n    \"paymentMethod\": \"MOBILEMONEY\",\n    \"brand_id\": \"your-brand-id\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"Date","value":"Fri, 06 Dec 2024 14:59:14 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Frame-Options","value":"SAMEORIGIN"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"CF-Cache-Status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"endpoints\":[{\"url\":\"https:\\/\\/a.nel.cloudflare.com\\/report\\/v4?s=pWCTJZboe33ICYkJiwuwk9QQ4TLxjgXAKCGEbQUbwdP%2Bdbr%2FHFvOVzWWsAS7UIypOGSXOnu52hAILUoGn0yrB2iqXMR9PhPHoTuxnVIEyihZEXx8Fv7QXgASe%2F4CUAQc%2BMupXRwPfFI%3D\"}],\"group\":\"cf-nel\",\"max_age\":604800}"},{"key":"NEL","value":"{\"success_fraction\":0,\"report_to\":\"cf-nel\",\"max_age\":604800}"},{"key":"Server","value":"cloudflare"},{"key":"CF-RAY","value":"8edd237addbf0f97-EWR"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"},{"key":"server-timing","value":"cfL4;desc=\"?proto=TCP&rtt=223565&min_rtt=223292&rtt_var=63299&sent=15&recv=16&lost=0&retrans=0&sent_bytes=4524&recv_bytes=3359&delivery_rate=19323&cwnd=255&unsent_bytes=0&cid=6b5591269d33c417&ts=10327&x=0\""}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"purchaseId\": \"69ec68f9f76f0f58bd700058\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"agarapex@gmail.com\",\n        \"phone\": \"243995980380\",\n        \"full_name\": \"Rahul Agarwal\",\n        \"date_of_birth\": \"1994-31-04\",\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\n        \"country\": \"CD\",\n        \"city\": \"Jaipur\",\n        \"zip_code\": \"W1S 3BE\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"RJ\"\n    },\n    \"updated_on\": 1777101049,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"MOBILEMONEY\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"errorCode\": \"NA\",\n    \"force_recurring\": false,\n    \"created_on\": 1777101049,\n    \"merchantRef\": \"69ec68f9f76f0f58bd700058\",\n    \"purchase\": {\n        \"currency\": \"CDF\",\n        \"products\": [\n            {\n                \"name\": \"gaming cards\",\n                \"quantity\": 1.0,\n                \"price\": 1000.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 1000.0,\n        \"requestAmount\": 1000.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"Testing\",\n        \"brand_name\": \"Testing\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1777101049\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"59c5ed48-caf9-464a-ba54-26e1e02bc1bc\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS1711\",\n    \"issued\": \"2026-04-25\",\n    \"due\": 1777101049,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"extraFee\": \"0\",\n    \"totalRefunded\": 0.0,\n    \"paidOn\": 0,\n    \"receivedAmt\": 0.0,\n    \"taxAmount\": 0.0,\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"sessionId\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0.0,\n    \"success_redirect\": \"https://google.com/\",\n    \"failure_redirect\": \"https://paysecure.net\",\n    \"pending_redirect\": \"https://facebook.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://staging.paysecure.net/merchant\",\n    \"failure_callback\": \"https://staging.paysecure.net/merchant\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"2406:b400:75:584c:8889:bfe5:9552:8720\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/5f95c39387eefc684560013794f41455/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"46af627b-0976-4433-a642-c89f04497544"}],"id":"c3272678-8c3d-4a56-b6ec-2b6abad272c3","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"01f39bca-f385-49ef-94ec-4d74b94590cf","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"5a3cd411-e01a-4595-b9d3-dc1c9f85eded","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"c3272678-8c3d-4a56-b6ec-2b6abad272c3","description":""},{"name":"Payout API","item":[{"name":"Payout","id":"a4eeaba3-6437-4676-9991-c20b5603c577","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"full_name\": \"akshaya singhal\",\n        \"email\": \"akshaya@gmail.com\",\n        \"country\": \"CD\",\n        \"city\": \"London\",\n        \"stateCode\": \"RJ\",\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\n        \"zip_code\": \"W1S 3BE\",\n        \"date_of_birth\": \"1994-31-04\",\n        \"phone\": \"+243999999999\"\n    },\n    \"purpose\": \"Testing payout\",\n    \"currency\": \"CDF\",\n    \"payoutMethod\": \"PAYOUT-MOBILEMONEY\",\n    \"amount\": 100.0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payout, the very first call to make is /payout/ API with the required data in the request body.</p>\n<p>To generate a PayOut, you are required to provide the <code>API key</code> (in the header), which can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.full_name</td>\n<td>Full name of the receiver. Minimum 2 words with atleast 1 character in each word.</td>\n</tr>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a receiver, should be a valid email.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. It must be upper case.</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>ISO-3166-2 State Code. Must be in upper case.</td>\n</tr>\n<tr>\n<td>client.street_address</td>\n<td>street address of the receiver.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>zip code of the receiver.</td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td>Phone number of the receiver. Country code is mandatory.  <br />Example: +234999999999</td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>Payout-MOBILEMONEY</td>\n</tr>\n<tr>\n<td>Amount</td>\n<td>Amount in currency upto 2 decimal points</td>\n</tr>\n<tr>\n<td>Currency</td>\n<td>Note this is currency account for which you have balance.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the payout is successful</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the payout is in progress</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the payout is unsuccessful.</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>Purpose of Payout</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"af88a1fa-f54a-44e6-9339-8b08fdcf6ab9","id":"af88a1fa-f54a-44e6-9339-8b08fdcf6ab9","name":"Payout API","type":"folder"}},"urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"74bf4153-5231-48c6-bf34-80f04313ab95","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"full_name\": \"akshaya singhal\",\n        \"email\": \"akshaya@gmail.com\",\n        \"country\": \"CD\",\n        \"city\": \"London\",\n        \"stateCode\": \"RJ\",\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\n        \"zip_code\": \"W1S 3BE\",\n        \"date_of_birth\": \"1994-31-04\",\n        \"phone\": \"+243999999999\"\n    },\n    \"purpose\": \"Testing payout\",\n    \"currency\": \"CDF\",\n    \"payoutMethod\": \"PAYOUT-MOBILEMONEY\",\n    \"amount\": 100.0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\n    \"payoutId\": \"69ec70c5b7b9052cc4823367\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"full_name\": \"akshaya singhal\",\n        \"email\": \"akshaya@gmail.com\",\n        \"country\": \"CD\",\n        \"city\": \"London\",\n        \"stateCode\": \"RJ\",\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\n        \"zip_code\": \"W1S 3BE\",\n        \"date_of_birth\": \"1994-31-04\",\n        \"phone\": \"+243999999999\"\n    },\n    \"updated_on\": 1777103045,\n    \"payoutMethod\": \"PAYOUT-MOBILEMONEY\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 100.0,\n    \"errorMsg\": \"\",\n    \"is_test\": false,\n    \"purpose\": \"Testing payout\",\n    \"created_on\": 1777103045,\n    \"merchantRef\": \"69ec70c5b7b9052cc4823367\",\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1777103045\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1777103045\n        }\n    ],\n    \"currency\": \"CDF\",\n    \"extraFee\": \"0\",\n    \"paymentOn\": 0,\n    \"checkout_url\": \"https://api.choicepay.ca/payout/0685d9437d0eb79e48ee8158542d9918/\",\n    \"taxAmount\": 0.0,\n    \"taxPercent\": 0.0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"redirectType\": \"POST\",\n    \"sessionId\": \"\",\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"trxMethod\": \"\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n    \"utc_offset\": \"NA\"\n}"}],"_postman_id":"a4eeaba3-6437-4676-9991-c20b5603c577"}],"id":"af88a1fa-f54a-44e6-9339-8b08fdcf6ab9","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"e5e8cf42-6e5f-4ccc-8a9a-c6dcf09877c6","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"1e5e8c08-f87e-479e-8c7c-e25db0db2530","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"af88a1fa-f54a-44e6-9339-8b08fdcf6ab9","description":""}],"id":"f50a1563-a6d6-4611-8a9b-40a3d3569cca","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"b177c2ae-d430-4717-9bde-9a46c46ba114","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"b4de97bb-3c28-4ede-83f0-642e8b2a2bc3","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"f50a1563-a6d6-4611-8a9b-40a3d3569cca","description":""},{"name":"🌎 Google Pay Redirect","item":[{"name":"Concepts","item":[],"id":"9321edd6-8d85-49db-a100-8f71334ce5e8","description":"<h2 id=\"overview\">Overview</h2>\n<p>Google Pay enables customers to make payments on a merchant’s website or app using credit or debit cards securely stored in their Google Account. During checkout, Google Pay presents a payment sheet where customers can select their preferred card and confirm the transaction.</p>\n<p>Customers add their payment cards to the Google Pay wallet, which securely stores the card details. When making a purchase, they simply choose Google Pay as the payment method and complete the payment using a saved card—eliminating the need to enter card information repeatedly.</p>\n<hr />\n<h2 id=\"features\">Features</h2>\n<ul>\n<li><p><strong>Convenient</strong>: Customers can pay using cards already saved in Google Pay, reducing friction during checkout.</p>\n</li>\n<li><p><strong>Secure</strong>: Uses tokenization to ensure sensitive card information is never exposed during the payment flow.</p>\n</li>\n<li><p><strong>3D Secure support</strong>: The payment handle created through the integration supports 3D Secure authentication when required, enabling secure transactions.</p>\n</li>\n<li><p><strong>Wide coverage</strong>: Supported across multiple regions and currencies.</p>\n</li>\n</ul>\n<hr />\n<p>By integrating Google Pay through the <strong>Paysecure API</strong>, you can offer your customers a fast, secure, and seamless payment experience.</p>\n<hr />\n<h2 id=\"note\">Note</h2>\n<p>This is a <strong>redirection-based payment method</strong>. During the payment flow, the user is redirected to a third-party application or interface, where the Google Pay button is displayed for completing the transaction.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"3689411e-823f-4b25-b92c-6ea3ad01be49","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"e1823e12-d492-42be-9907-ad507a512152","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"9321edd6-8d85-49db-a100-8f71334ce5e8"},{"name":"APIs","item":[{"name":"Purchases","id":"5d920ac8-00ac-497e-815a-9ff1e4dc3571","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"RJ\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"brand_id\": \"your-brandid\",\r\n    \"paymentMethod\": \"GOOGLEPAY-REDIRECT\",\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"parameters-in-the-request-body\"><strong>Parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.full_name</td>\n<td>Conditional.  <br />But Recommended to pass the complete name of the client. Atleast 2 words recommended.</td>\n</tr>\n<tr>\n<td>client.email</td>\n<td>Conditional.  <br />But Recommended to pass a correct email id.</td>\n</tr>\n<tr>\n<td>paymentMethod</td>\n<td>Conditional.  <br />Mandatory if you are not using Paysecure Cashier. Else Non Mandatory.  <br />Value: GOOGLEPAY-REDIRECT</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>Mandatory.  <br />ISO 4217 code for currency you want to send the transaction in. This should be 'BRL' for PIX.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>Mandatory.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Mandatory.  <br />Price in decimal format upto 2 decimals.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Mandatory.  <br />Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is in progress state.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Mandatory  <br />URL to send the user if the transactions has failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"4343530a-d2c9-4451-9282-511a0c127003","id":"4343530a-d2c9-4451-9282-511a0c127003","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"b6834130-5bf5-445a-b771-bce69a237b75","name":"Purchase - success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"RJ\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"brand_id\": \"your-brandid\",\r\n    \"paymentMethod\": \"GOOGLEPAY-REDIRECT\",\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69634df44549cbd3547ac750\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"updated_on\": 1768115701,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"GOOGLEPAY-REDIRECT\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1768115700,\r\n    \"merchantRef\": \"69634df44549cbd3547ac750\",\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 1.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 1.0,\r\n        \"requestAmount\": 1.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 1.0,\r\n        \"currency\": \"EUR\",\r\n        \"net_amount\": 1.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1768115700,\r\n        \"remote_paid_on\": 1768115700\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Testing\",\r\n        \"brand_name\": \"Testing\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 1.0,\r\n            \"masked_pan\": \"GOOGLEPAY-REDIRECT\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"183.83.53.41\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"GOOGLEPAY-REDIRECT\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"GOOGLEPAY-REDIRECT\",\r\n                \"processing_time\": 1768115700,\r\n                \"extra\": {\r\n                    \"amount\": 1.0,\r\n                    \"masked_pan\": \"GOOGLEPAY-REDIRECT\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAYMENT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1768115700\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1768115700\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1768115701\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"59c5ed48-caf9-464a-ba54-26e1e02bc1bc\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS363\",\r\n    \"issued\": \"2026-01-11\",\r\n    \"due\": 1768115700,\r\n    \"refund_upto\": 1783664101,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"0\",\r\n    \"trustScore\": \"1\",\r\n    \"extraFee\": \"0\",\r\n    \"pix_payload\": {},\r\n    \"payInDetails\": {},\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 1.0,\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"183.83.53.41\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/deb852445bd4b0fa6c4587f652174ab9/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"17be7bad-328c-4294-98ef-f658433dbbf5","name":"Purchase - failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"RJ\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"brand_id\": \"your-brandid\",\r\n    \"paymentMethod\": \"GOOGLEPAY-REDIRECT\",\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"5d920ac8-00ac-497e-815a-9ff1e4dc3571"},{"name":"Session","id":"c5c799b2-2b9e-43bc-af12-5a5be8f1a1ba","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"POST","header":[],"body":{"mode":"raw","raw":"","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession","description":"<p><strong>OVERVIEW</strong></p>\n<p>The <code>createSession</code> API is designed to initiate a payment session for a customer after their profile has been created via the <strong>createCustomer</strong> API. The session is automatically generated at the backend on the merchant’s checkout URL. This session allows the customer to continue with their transaction without having to manually interact with the session URL, and ensures the session remains active until the payment is completed or the session expires.</p>\n<p>This API improves the user experience by reducing transaction failures and enhancing the overall payment process, thus reducing transaction churn rates.</p>\n<h3 id=\"mandatory-parameters\">Mandatory Parameters</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th>Description</th>\n<th>Example</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>customerId</td>\n<td>String</td>\n<td>The unique ID of the customer (generated from createCustomer).</td>\n<td>6731a609b6bb5a43ad66c4a6</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"usage-flow\"><strong>Usage Flow</strong></h3>\n<ol>\n<li><p><strong>Customer completes the</strong> <strong><code>createCustomer</code></strong> <strong>API</strong>: Once the customer is created via the <code>createCustomer</code> API, the merchant proceeds to call the <code>createSession</code> API to generate a session.</p>\n</li>\n<li><p><strong>Merchant sends</strong> <strong><code>createSession</code></strong> <strong>request</strong>: The merchant sends a <code>POST</code> request to the <code>createSession</code> API with the customer’s <code>customerId</code> and the merchant’s <code>brandId</code>.</p>\n</li>\n<li><p><strong>Session created automatically on the checkout URL</strong>: PaySecure creates the session and associates it with the merchant’s checkout page. This session remains active on the backend, allowing the customer to continue the payment process without interruption.</p>\n</li>\n<li><p><strong>Customer proceeds to checkout</strong>: The customer is redirected to the checkout page as part of the merchant's payment flow, where the session is automatically validated. The session remains active for a set period, allowing the customer to complete the payment without needing to manually interact with the session URL.</p>\n</li>\n<li><p><strong>Session Expiry</strong>: The session expires after the set expiration time (<code>expiryOn</code>), ensuring the payment process is completed within the defined window. Default is 15 mins from the creation time.</p>\n</li>\n</ol>\n<hr />\n<h3 id=\"benefits\"><strong>Benefits</strong></h3>\n<ul>\n<li><p><strong>Seamless Checkout</strong>: The session URL is automatically generated and active at the backend, ensuring a smoother and uninterrupted customer experience.</p>\n</li>\n<li><p><strong>Reduced Transaction Failures</strong>: By ensuring the session remains active during the payment process, the chances of transaction failures due to session timeouts are minimized.</p>\n</li>\n<li><p><strong>Improved User Experience</strong>: The customer does not need to click on a session URL or navigate away from the page, leading to faster and more secure payment processing.</p>\n</li>\n</ul>\n","urlObject":{"path":["createSession"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"6048873b-b2c1-4fbd-85d8-72e39f410864","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"it is mandatory to pass the BrandId in header for each createSession request. ","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"69034a5a61b460084d20c23b\",\r\n    \"merchantRef\": \"rahultestcustomer1@paysecure.net\", // optional\r\n    \"currency\": \"EUR\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"10\"\r\n        },\r\n        {\r\n            \"name\": \"Product2\",\r\n            \"price\": \"12\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"22\", // optional, but if present have precedence over sum of prices.\r\n    \"paymentMethod\": \"GOOGLEPAY-REDIRECT\", //optional\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"status":"OK","code":200,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"sessionUrl\": \"https://api.choicepay.ca/payment-session/6963533a0a18ea65153a81e7/\",\r\n    \"brandId\": \"brand_id_value\",\r\n    \"customerId\": \"69034a5a61b460084d20c23b\",\r\n    \"sessionId\": \"6963533a0a18ea65153a81e7\",\r\n    \"expiryOn\": 1768117950,\r\n    \"createdOn\": 1768117050\r\n}"},{"id":"8d08c02e-a9a8-4192-a891-fabcd537041d","name":"Invalid Session","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"it is mandatory to pass the BrandId in header for each createSession request. ","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"69034a5a61b460084d20c23b\",\r\n    \"merchantRef\": \"rahultestcustomer1@paysecure.net\", // optional\r\n    \"currency\": \"EUR\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"10\"\r\n        },\r\n        {\r\n            \"name\": \"Product2\",\r\n            \"price\": \"12\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"22\", // optional, but if present have precedence over sum of prices.\r\n    \"paymentMethod\": \"GOOGLEPAY-REDIRECT\", //optional\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"status":"Bad Request","code":400,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Customer does not exist with this Customer Id\",\r\n    \"code\": \"Customer Id is invalid\"\r\n}"}],"_postman_id":"c5c799b2-2b9e-43bc-af12-5a5be8f1a1ba"},{"name":"Get Status","id":"8ea51fca-2dcc-440e-a281-ad78e19d4999","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"4343530a-d2c9-4451-9282-511a0c127003","id":"4343530a-d2c9-4451-9282-511a0c127003","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"e6651942-f04b-4851-b431-df1c8e6c0ae1","name":"Purchase - success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69634df44549cbd3547ac750\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"updated_on\": 1768115701,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"GOOGLEPAY-REDIRECT\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1768115700,\r\n    \"merchantRef\": \"69634df44549cbd3547ac750\",\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 1.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 1.0,\r\n        \"requestAmount\": 1.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 1.0,\r\n        \"currency\": \"EUR\",\r\n        \"net_amount\": 1.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1768115700,\r\n        \"remote_paid_on\": 1768115700\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Testing\",\r\n        \"brand_name\": \"Testing\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 1.0,\r\n            \"masked_pan\": \"GOOGLEPAY-REDIRECT\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"183.83.53.41\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"GOOGLEPAY-REDIRECT\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"GOOGLEPAY-REDIRECT\",\r\n                \"processing_time\": 1768115700,\r\n                \"extra\": {\r\n                    \"amount\": 1.0,\r\n                    \"masked_pan\": \"GOOGLEPAY-REDIRECT\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1768115700\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1768115700\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1768115701\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1768115701\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"59c5ed48-caf9-464a-ba54-26e1e02bc1bc\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS363\",\r\n    \"issued\": \"2026-01-11\",\r\n    \"due\": 1768115700,\r\n    \"refund_upto\": 1783664101,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"0\",\r\n    \"trustScore\": \"1\",\r\n    \"extraFee\": \"0\",\r\n    \"pix_payload\": {},\r\n    \"payInDetails\": {},\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 1.0,\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"183.83.53.41\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/deb852445bd4b0fa6c4587f652174ab9/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"afebd644-1ca2-4858-b508-e897f7067f2b","name":"Purchase - failure","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"8ea51fca-2dcc-440e-a281-ad78e19d4999"}],"id":"4343530a-d2c9-4451-9282-511a0c127003","description":"<p><strong>API Flow</strong></p>\n<ol>\n<li><p>The merchant initiates the purchase via the create purchase API and passing the appropriate payment method. If successful, they receive a checkout URL in the response JSON.</p>\n</li>\n<li><p>Upon utilizing the checkout URL, the user will be presented with a screen where he will be shown a button to pay via Googlepay.</p>\n</li>\n<li><p>After clicking the button, the user will see all the cards stored in the google wallet and he can choose one of the cards to make the purchase.</p>\n</li>\n<li><p>After a successful or failed payment by the end user, an appropriate webhook would be sent to the merchant. The user would also be redirected to the appropriate redirect URL.</p>\n</li>\n</ol>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"6ff637b4-6d33-454d-9510-bd0f0c7822e6","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"997f4d68-cf32-4e3e-b85f-dabd79a83a02","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"4343530a-d2c9-4451-9282-511a0c127003"}],"id":"04956c92-9ce9-4b78-9d86-3425b5cb764b","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"5edc9d3a-d3d6-4aa0-bf4b-d62efef1f209","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"13c2507f-e1c9-45f3-b599-0f551ebfe68c","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"04956c92-9ce9-4b78-9d86-3425b5cb764b","description":""},{"name":"🌎 Apple Pay Redirect","item":[{"name":"Concepts","item":[],"id":"3cec7ff8-e53b-4e0c-99c9-2752ea75ba89","description":"<h2 id=\"overview\">Overview</h2>\n<p>Apple Pay enables customers to make payments on a merchant’s website or app using credit or debit cards securely stored in their Apple Wallet. During checkout, Apple Pay presents a payment sheet where customers can select their preferred card and confirm the payment using <strong>Touch ID, Face ID, or their device passcode</strong>.</p>\n<p>Customers add their payment cards to Apple Wallet, which securely stores the card information. When making a purchase, they simply select Apple Pay as the payment method and complete the transaction using a saved card—eliminating the need to manually enter card details for each payment.</p>\n<hr />\n<h2 id=\"features\">Features</h2>\n<ul>\n<li><p><strong>Convenient</strong>: Customers can pay using cards already saved in Apple Pay, reducing checkout friction.</p>\n</li>\n<li><p><strong>Secure</strong>: Uses device-specific tokenization (DPAN/MPAN) to protect sensitive card data during the payment process.</p>\n</li>\n<li><p><strong>3D Secure support</strong>: The payment handle created through the integration supports 3D Secure authentication when required, ensuring secure transactions.</p>\n</li>\n<li><p><strong>Wide coverage</strong>: Supported across multiple regions and currencies.</p>\n</li>\n</ul>\n<hr />\n<p>By integrating Apple Pay through the <strong>Paysecure API</strong>, you can provide your customers with a fast, secure, and seamless payment experience.</p>\n<hr />\n<h2 id=\"note\">Note</h2>\n<p>This is a <strong>redirection-based payment method</strong>. During the payment flow, the user is redirected to a third-party application or interface, where the Apple Pay button is displayed to complete the payment.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"3689411e-823f-4b25-b92c-6ea3ad01be49","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"e1823e12-d492-42be-9907-ad507a512152","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"3cec7ff8-e53b-4e0c-99c9-2752ea75ba89"},{"name":"APIs","item":[{"name":"Purchases","id":"c6e162ac-9043-4c1d-b099-3023cb63fa2e","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"RJ\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"brand_id\": \"your-brandid\",\r\n    \"paymentMethod\": \"APPLEPAY-REDIRECT\",\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"parameters-in-the-request-body\"><strong>Parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.full_name</td>\n<td>Conditional.  <br />But Recommended to pass the complete name of the client. Atleast 2 words recommended.</td>\n</tr>\n<tr>\n<td>client.email</td>\n<td>Conditional.  <br />But Recommended to pass a correct email id.</td>\n</tr>\n<tr>\n<td>paymentMethod</td>\n<td>Conditional.  <br />Mandatory if you are not using Paysecure Cashier. Else Non Mandatory.  <br />Value: APPLEPAY-REDIRECT</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>Mandatory.  <br />ISO 4217 code for currency you want to send the transaction in. This should be 'BRL' for PIX.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>Mandatory.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Mandatory.  <br />Price in decimal format upto 2 decimals.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Mandatory.  <br />Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is in progress state.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Mandatory  <br />URL to send the user if the transactions has failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"244e1dc4-2e65-49df-9603-13b033c55a84","id":"244e1dc4-2e65-49df-9603-13b033c55a84","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"aa080992-badd-4568-a832-faf030c556d7","name":"Purchase - success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"RJ\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"brand_id\": \"your-brandid\",\r\n    \"paymentMethod\": \"APPLEPAY-REDIRECT\",\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69634df44549cbd3547ac750\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"updated_on\": 1768115701,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"APPLEPAY-REDIRECT\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1768115700,\r\n    \"merchantRef\": \"69634df44549cbd3547ac750\",\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 1.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 1.0,\r\n        \"requestAmount\": 1.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 1.0,\r\n        \"currency\": \"EUR\",\r\n        \"net_amount\": 1.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1768115700,\r\n        \"remote_paid_on\": 1768115700\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Testing\",\r\n        \"brand_name\": \"Testing\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 1.0,\r\n            \"masked_pan\": \"APPLEPAY-REDIRECT\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"183.83.53.41\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"APPLEPAY-REDIRECT\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"APPLEPAY-REDIRECT\",\r\n                \"processing_time\": 1768115700,\r\n                \"extra\": {\r\n                    \"amount\": 1.0,\r\n                    \"masked_pan\": \"APPLEPAY-REDIRECT\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAYMENT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1768115700\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1768115700\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1768115701\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"59c5ed48-caf9-464a-ba54-26e1e02bc1bc\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS363\",\r\n    \"issued\": \"2026-01-11\",\r\n    \"due\": 1768115700,\r\n    \"refund_upto\": 1783664101,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"0\",\r\n    \"trustScore\": \"1\",\r\n    \"extraFee\": \"0\",\r\n    \"pix_payload\": {},\r\n    \"payInDetails\": {},\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 1.0,\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"183.83.53.41\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/deb852445bd4b0fa6c4587f652174ab9/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"b657474e-07a1-4404-acef-e8a4cb9688fe","name":"Purchase - failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"RJ\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards \",\r\n                \"price\": 10\r\n            }\r\n        ]\r\n    },\r\n    \"brand_id\": \"your-brandid\",\r\n    \"paymentMethod\": \"APPLEPAY-REDIRECT\",\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"c6e162ac-9043-4c1d-b099-3023cb63fa2e"},{"name":"Session","id":"52cebcaf-9fa8-4a79-863f-80ae0eb4a53d","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"POST","header":[],"body":{"mode":"raw","raw":"","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession","description":"<p><strong>OVERVIEW</strong></p>\n<p>The <code>createSession</code> API is designed to initiate a payment session for a customer after their profile has been created via the <strong>createCustomer</strong> API. The session is automatically generated at the backend on the merchant’s checkout URL. This session allows the customer to continue with their transaction without having to manually interact with the session URL, and ensures the session remains active until the payment is completed or the session expires.</p>\n<p>This API improves the user experience by reducing transaction failures and enhancing the overall payment process, thus reducing transaction churn rates.</p>\n<h3 id=\"mandatory-parameters\">Mandatory Parameters</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th>Description</th>\n<th>Example</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>customerId</td>\n<td>String</td>\n<td>The unique ID of the customer (generated from createCustomer).</td>\n<td>6731a609b6bb5a43ad66c4a6</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"usage-flow\"><strong>Usage Flow</strong></h3>\n<ol>\n<li><p><strong>Customer completes the</strong> <strong><code>createCustomer</code></strong> <strong>API</strong>: Once the customer is created via the <code>createCustomer</code> API, the merchant proceeds to call the <code>createSession</code> API to generate a session.</p>\n</li>\n<li><p><strong>Merchant sends</strong> <strong><code>createSession</code></strong> <strong>request</strong>: The merchant sends a <code>POST</code> request to the <code>createSession</code> API with the customer’s <code>customerId</code> and the merchant’s <code>brandId</code>.</p>\n</li>\n<li><p><strong>Session created automatically on the checkout URL</strong>: PaySecure creates the session and associates it with the merchant’s checkout page. This session remains active on the backend, allowing the customer to continue the payment process without interruption.</p>\n</li>\n<li><p><strong>Customer proceeds to checkout</strong>: The customer is redirected to the checkout page as part of the merchant's payment flow, where the session is automatically validated. The session remains active for a set period, allowing the customer to complete the payment without needing to manually interact with the session URL.</p>\n</li>\n<li><p><strong>Session Expiry</strong>: The session expires after the set expiration time (<code>expiryOn</code>), ensuring the payment process is completed within the defined window. Default is 15 mins from the creation time.</p>\n</li>\n</ol>\n<hr />\n<h3 id=\"benefits\"><strong>Benefits</strong></h3>\n<ul>\n<li><p><strong>Seamless Checkout</strong>: The session URL is automatically generated and active at the backend, ensuring a smoother and uninterrupted customer experience.</p>\n</li>\n<li><p><strong>Reduced Transaction Failures</strong>: By ensuring the session remains active during the payment process, the chances of transaction failures due to session timeouts are minimized.</p>\n</li>\n<li><p><strong>Improved User Experience</strong>: The customer does not need to click on a session URL or navigate away from the page, leading to faster and more secure payment processing.</p>\n</li>\n</ul>\n","urlObject":{"path":["createSession"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"a42b811f-947a-4222-bfd8-f1b32ec551a7","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"it is mandatory to pass the BrandId in header for each createSession request. ","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"69034a5a61b460084d20c23b\",\r\n    \"merchantRef\": \"rahultestcustomer1@paysecure.net\", // optional\r\n    \"currency\": \"EUR\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"10\"\r\n        },\r\n        {\r\n            \"name\": \"Product2\",\r\n            \"price\": \"12\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"22\", // optional, but if present have precedence over sum of prices.\r\n    \"paymentMethod\": \"APPLEPAY-REDIRECT\", //optional\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"status":"OK","code":200,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"sessionUrl\": \"https://api.choicepay.ca/payment-session/6963533a0a18ea65153a81e7/\",\r\n    \"brandId\": \"brand_id_value\",\r\n    \"customerId\": \"69034a5a61b460084d20c23b\",\r\n    \"sessionId\": \"6963533a0a18ea65153a81e7\",\r\n    \"expiryOn\": 1768117950,\r\n    \"createdOn\": 1768117050\r\n}"},{"id":"f809dc95-85d0-4086-8997-7fc2b79cb6fd","name":"Invalid Session","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"it is mandatory to pass the BrandId in header for each createSession request. ","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"69034a5a61b460084d20c23b\",\r\n    \"merchantRef\": \"rahultestcustomer1@paysecure.net\", // optional\r\n    \"currency\": \"EUR\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"10\"\r\n        },\r\n        {\r\n            \"name\": \"Product2\",\r\n            \"price\": \"12\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"22\", // optional, but if present have precedence over sum of prices.\r\n    \"paymentMethod\": \"APPLEPAY-REDIRECT\", //optional\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"status":"Bad Request","code":400,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Customer does not exist with this Customer Id\",\r\n    \"code\": \"Customer Id is invalid\"\r\n}"}],"_postman_id":"52cebcaf-9fa8-4a79-863f-80ae0eb4a53d"},{"name":"Get Status","id":"8b7d7852-2f6b-43a4-981d-381cf8640167","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"244e1dc4-2e65-49df-9603-13b033c55a84","id":"244e1dc4-2e65-49df-9603-13b033c55a84","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"7bbe0532-9c73-49dc-b6b7-5e5ae4fc9251","name":"Purchase - success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69634df44549cbd3547ac750\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"rahultest@gmail.com\",\r\n        \"phone\": \"+91 9634088561\",\r\n        \"full_name\": \"Rahul Agarwal\",\r\n        \"date_of_birth\": \"1994-31-04\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"RJ\"\r\n    },\r\n    \"updated_on\": 1768115701,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"APPLEPAY-REDIRECT\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1768115700,\r\n    \"merchantRef\": \"69634df44549cbd3547ac750\",\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"gaming cards\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 1.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 1.0,\r\n        \"requestAmount\": 1.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 1.0,\r\n        \"currency\": \"EUR\",\r\n        \"net_amount\": 1.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1768115700,\r\n        \"remote_paid_on\": 1768115700\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Testing\",\r\n        \"brand_name\": \"Testing\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 1.0,\r\n            \"masked_pan\": \"APPLEPAY-REDIRECT\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"183.83.53.41\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"APPLEPAY-REDIRECT\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"APPLEPAY-REDIRECT\",\r\n                \"processing_time\": 1768115700,\r\n                \"extra\": {\r\n                    \"amount\": 1.0,\r\n                    \"masked_pan\": \"APPLEPAY-REDIRECT\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1768115700\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1768115700\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1768115701\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1768115701\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"59c5ed48-caf9-464a-ba54-26e1e02bc1bc\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS363\",\r\n    \"issued\": \"2026-01-11\",\r\n    \"due\": 1768115700,\r\n    \"refund_upto\": 1783664101,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"0\",\r\n    \"trustScore\": \"1\",\r\n    \"extraFee\": \"0\",\r\n    \"pix_payload\": {},\r\n    \"payInDetails\": {},\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 1.0,\r\n    \"success_redirect\": \"https://your-redirect-url?issucces=true\",\r\n    \"pending_redirect\": \"https://your-redirect-url?ispending=true\",\r\n    \"failure_redirect\": \"https://your-redirect-url?isfailure=true\",\r\n    \"success_callback\": \"https://your-webhook-url\",\r\n    \"failure_callback\": \"https://your-webhook-url\"\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"183.83.53.41\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/deb852445bd4b0fa6c4587f652174ab9/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"f21572cc-a323-4b92-8e88-ea8571cc715b","name":"Purchase - failure","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"8b7d7852-2f6b-43a4-981d-381cf8640167"}],"id":"244e1dc4-2e65-49df-9603-13b033c55a84","description":"<p><strong>API Flow</strong></p>\n<ol>\n<li><p>The merchant initiates the purchase via the create purchase API and passing the appropriate payment method. If successful, they receive a checkout URL in the response JSON.</p>\n</li>\n<li><p>Upon utilizing the checkout URL, the user will be presented with a screen where he will be shown a button to pay via Applepay.</p>\n</li>\n<li><p>After clicking the button, the user will see all the cards stored in the Apple wallet and he can choose one of the cards to make the purchase.</p>\n</li>\n<li><p>After a successful or failed payment by the end user, an appropriate webhook would be sent to the merchant. The user would also be redirected to the appropriate redirect URL.</p>\n</li>\n</ol>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"6ff637b4-6d33-454d-9510-bd0f0c7822e6","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"997f4d68-cf32-4e3e-b85f-dabd79a83a02","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"244e1dc4-2e65-49df-9603-13b033c55a84"}],"id":"2ac6ed3d-0987-4fd0-9396-8cb7ecdb728e","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"5edc9d3a-d3d6-4aa0-bf4b-d62efef1f209","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"13c2507f-e1c9-45f3-b599-0f551ebfe68c","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"2ac6ed3d-0987-4fd0-9396-8cb7ecdb728e","description":""},{"name":"🌎 Google Pay (Seamless)","item":[{"name":"Concepts","item":[],"id":"849ddad3-24d4-44fb-a4f7-6fefbc36b4eb","description":"<h2 id=\"get-started\"><strong>Get started</strong></h2>\n<p>Paysecure’s Server-to-Server (S2S) integration for Google Pay allows merchants to process Google Pay transactions securely from their backend systems. In this model, merchants are responsible for generating the Google Pay payment token on their client application and sending it to their server, which then communicates with Paysecure APIs.</p>\n<p>This integration uses DIRECT tokenization, where payment data is securely generated by Google Pay and passed to Paysecure for processing.</p>\n<p>This integration is recommended for merchants who require:</p>\n<ul>\n<li><p>Integration with Google Pay wallets</p>\n</li>\n<li><p>Secure handling of tokenized payment data</p>\n</li>\n<li><p>Flexibility in choosing PCI scope (encrypted vs decrypted flow)</p>\n</li>\n</ul>\n<hr />\n<h2 id=\"how-it-works\"><strong>How it works</strong></h2>\n<p>The Google Pay S2S payment flow follows a two-step process:</p>\n<h4 id=\"1-generate-google-pay-token-client-side\"><strong>1. Generate Google Pay Token (Client-side)</strong></h4>\n<p>The merchant integrates Google Pay SDK (Web/Android) to generate a payment token using DIRECT flow.</p>\n<h4 id=\"2-submit-token-via-s2s\"><strong>2. Submit Token via S2S</strong></h4>\n<p>The merchant server sends the Google Pay token (encrypted or decrypted) to Paysecure via the /purchase API.</p>\n<hr />\n<h2 id=\"supported-tokenization-type\"><strong>Supported Tokenization Type</strong></h2>\n<p>Paysecure supports DIRECT flow only.</p>\n<p>PAYMENT_GATEWAY flow is not supported yet.</p>\n<hr />\n<h2 id=\"google-pay-processing-overview\"><strong>Google Pay Processing Overview</strong></h2>\n<p>Google Pay transactions are processed as card-not-present payments using tokenized card data (PAN/DPAN) along with a cryptogram provided by Google Pay.</p>\n<p>These transactions go through:</p>\n<ul>\n<li><p>Card network (Visa, Mastercard, etc.)</p>\n</li>\n<li><p>Issuing bank authorization</p>\n</li>\n<li><p>Risk and fraud checks</p>\n</li>\n</ul>\n<hr />\n<h2 id=\"integration-options\"><strong>Integration Options</strong></h2>\n<p>Paysecure supports two integration modes:</p>\n<hr />\n<h3 id=\"1-encrypted-token-flow-recommended\"><strong>1. Encrypted Token Flow (Recommended)</strong></h3>\n<p>In this flow, the merchant sends the encrypted Google Pay token to Paysecure. Paysecure decrypts and processes the payment.</p>\n<h4 id=\"key-characteristics\">Key Characteristics</h4>\n<ul>\n<li><p>Merchant does not handle PAN</p>\n</li>\n<li><p>Reduced PCI scope</p>\n</li>\n<li><p>Recommended for most merchants</p>\n</li>\n</ul>\n<h4 id=\"pci-impact\">PCI Impact</h4>\n<p>Merchants can significantly reduce PCI DSS scope since sensitive card data is handled by Paysecure.</p>\n<hr />\n<h3 id=\"2-decrypted-token-flow\"><strong>2. Decrypted Token Flow</strong></h3>\n<p>In this flow, the merchant decrypts the Google Pay token and sends decrypted token details to Paysecure.</p>\n<h4 id=\"key-characteristics-1\">Key Characteristics</h4>\n<ul>\n<li><p>PAN is available at merchant side</p>\n</li>\n<li><p>Faster processing</p>\n</li>\n<li><p>Full control over payment data</p>\n</li>\n</ul>\n<h4 id=\"pci-impact-1\">PCI Impact</h4>\n<p>Merchants must be PCI DSS compliant (SAQ D) as they handle raw card data.</p>\n<hr />\n<h2 id=\"before-you-begin\"><strong>Before you begin</strong></h2>\n<p>Ensure the following prerequisites are met:</p>\n<ul>\n<li><p>You have received your API credentials from Paysecure.</p>\n</li>\n<li><p>You have a valid Google Merchant ID</p>\n</li>\n<li><p>You have integrated Google Pay SDK to generate tokens</p>\n</li>\n<li><p>You have configured DIRECT tokenization in Google Pay</p>\n</li>\n<li><p>Your server can make secure HTTPS requests</p>\n</li>\n<li><p>You have a valid brand_id provided by Paysecure</p>\n</li>\n</ul>\n<h3 id=\"additional-requirements-encrypted-flow\">Additional Requirements (Encrypted Flow)</h3>\n<ul>\n<li><p>Generate EC key pair (P-256 / secp256r1)</p>\n</li>\n<li><p>Register public key in Google Pay Console</p>\n</li>\n<li><p>Share private key securely with Paysecure</p>\n</li>\n</ul>\n<h3 id=\"additional-requirements-decrypted-flow\">Additional Requirements (Decrypted Flow)</h3>\n<ul>\n<li><p>Implement token decryption using Google Tink library</p>\n</li>\n<li><p>Ensure full PCI DSS compliance</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"3689411e-823f-4b25-b92c-6ea3ad01be49","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"e1823e12-d492-42be-9907-ad507a512152","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"849ddad3-24d4-44fb-a4f7-6fefbc36b4eb"},{"name":"APIs","item":[{"name":"Purchases (Encrypted Flow)","id":"ca82497b-59f6-464e-9265-d2a4d3fe5e1e","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"price\": \"10\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"GOOGLEPAY\",\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"googlepay_param\": {\r\n            \"google_merchant_id\": \"merchant:1234567890\",\r\n            \"googlepay_encrypted_payload\": \"{\\\"signature\\\":\\\"MEUCIQC...\\\",\\\"intermediateSigningKey\\\":{...},\\\"protocolVersion\\\":\\\"ECv2\\\",\\\"signedMessage\\\":\\\"{...}\\\"}\"\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To process a Google Pay transaction, a Purchase must first be created using the /purchases API. The Google Pay token must be included in the request under extraParam.googlepay_param.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"parameters-in-the-request-body\"><strong>Parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.full_name</td>\n<td>Conditional.  <br />But Recommended to pass the complete name of the client. Atleast 2 words recommended.</td>\n</tr>\n<tr>\n<td>client.email</td>\n<td>Conditional.  <br />But Recommended to pass a correct email id.</td>\n</tr>\n<tr>\n<td>paymentMethod</td>\n<td>Conditional.  <br />Mandatory if you are not using Paysecure Cashier. Else Non Mandatory.  <br />Value: GOOGLEPAY</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>Mandatory.  <br />ISO 4217 code for currency you want to send the transaction in. This should be 'BRL' for PIX.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>Mandatory.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Mandatory.  <br />Price in decimal format upto 2 decimals.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Mandatory.  <br />Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is in progress state.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Mandatory  <br />URL to send the user if the transactions has failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"flow-diagram\">Flow Diagram:</h3>\n<img src=\"https://content.pstmn.io/2dd13473-b015-4a40-b71a-542585919bcc/RW5jcnlwdGVkIEZsb3cucG5n\" />","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"00f20fbd-c463-4137-b120-3628f0bd57fa","id":"00f20fbd-c463-4137-b120-3628f0bd57fa","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"06222a4a-f09e-4985-9638-db6e78b79b21","name":"Purchase - success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n   \"client\": {\r\n       \"customerId\": \"NA\",\r\n       \"email\": \"himanshu1@paysecure.net\",\r\n       \"full_name\": \"OpHM\",\r\n       \"date_of_birth\": \"1800-01-01\",\r\n       \"street_address\": \"SB-124\",\r\n       \"country\": \"BR\",\r\n       \"city\": \"DLJPR\",\r\n       \"zip_code\": \"110001\",\r\n       \"cc\": [],\r\n       \"bcc\": [],\r\n       \"stateCode\": \"DL\"\r\n   },\r\n   \"purchase\": {\r\n       \"currency\": \"EUR\",\r\n       \"products\": [\r\n           {\r\n               \"name\": \"e-commerce\",\r\n               \"price\": \"10\"\r\n           }\r\n       ]\r\n   },\r\n   \"paymentMethod\": \"GOOGLEPAY\",\r\n   \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n   \"success_redirect\": \"https://google.com/\",\r\n   \"pending_redirect\": \"https://paysecure.net\",\r\n   \"failure_redirect\": \"https://facebook.com/\",\r\n   \"success_callback\": \"https://your.success.callback.com\",\r\n   \"failure_callback\": \"https://your.failure.callback.com\",\r\n      \"extraParam\": {\r\n    \"googlepay_param\": {\r\n      \"google_merchant_id\": \"merchant:1234567890\",\r\n      \"googlepay_encrypted_payload\":     \"{\\\"signature\\\":\\\"MEUCIQC...\\\",\\\"intermediateSigningKey\\\":{...},\\\"protocolVersion\\\":\\\"ECv2\\\",\\\"signedMessage\\\":\\\"{...}\\\"}\"  \r\n      }\r\n   }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69cce01f5bae56fd5547a993\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"updated_on\": 1775034399,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"GOOGLEPAY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1775034399,\r\n    \"merchantRef\": \"69cce01f5bae56fd5547a993\",\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"requestAmount\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Omega Pixel\",\r\n        \"brand_name\": \"Omega Pixel\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {},\r\n        \"country\": \"\",\r\n        \"attempts\": []\r\n    },\r\n    \"status\": \"CREATED\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1775034399\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS1032\",\r\n    \"issued\": \"2026-04-01\",\r\n    \"due\": 1775034399,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"extraFee\": \"0\",\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"103.80.161.238\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6b5a5977ac8e022facb31f3346f61ed0/\",\r\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/69cce01f5bae56fd5547a993/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"ebbb5c73-648f-4e47-b48f-9b756f4860d0","name":"Purchase - failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"price\": \"10\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"GOOGLEPAY\",\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"googlepay_param\": {\r\n            \"google_merchant_id\": \"merchant:1234567890\",\r\n            \"googlepay_encrypted_payload\": \"{\\\"signature\\\":\\\"MEUCIQC...\\\",\\\"intermediateSigningKey\\\":{...},\\\"protocolVersion\\\":\\\"ECv2\\\",\\\"signedMessage\\\":\\\"{...}\\\"}\"\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"ca82497b-59f6-464e-9265-d2a4d3fe5e1e"},{"name":"Purchases (Decrypted Flow)","id":"ffa051c7-a8cb-4526-81fc-b778a3b80f5b","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"price\": \"10\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"GOOGLEPAY\",\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"googlepay_param\": {\r\n            \"google_merchant_id\": \"merchant:1234567890\",\r\n            \"googlepay_decrypted_payload\": {\r\n                \"messageExpiration\": \"1735689600000\",\r\n                \"messageId\": \"AH2EjtfkYz...\",\r\n                \"paymentMethod\": \"CARD\",\r\n                \"paymentMethodDetails\": {\r\n                    \"pan\": \"4111111111111111\",\r\n                    \"expirationMonth\": 12,\r\n                    \"expirationYear\": 2027,\r\n                    \"authMethod\": \"CRYPTOGRAM_3DS\",\r\n                    \"cryptogram\": \"AgAAAAAABk4D...\",\r\n                    \"eciIndicator\": \"05\"\r\n                },\r\n                \"gatewayMerchantId\": \"your_gateway_merchant_id\"\r\n            }\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To process a Google Pay transaction, a Purchase must first be created using the /purchases API. The Google Pay token must be included in the request under extraParam.googlepay_param.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"parameters-in-the-request-body\"><strong>Parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.full_name</td>\n<td>Conditional.  <br />But Recommended to pass the complete name of the client. Atleast 2 words recommended.</td>\n</tr>\n<tr>\n<td>client.email</td>\n<td>Conditional.  <br />But Recommended to pass a correct email id.</td>\n</tr>\n<tr>\n<td>paymentMethod</td>\n<td>Conditional.  <br />Mandatory if you are not using Paysecure Cashier. Else Non Mandatory.  <br />Value: GOOGLEPAY</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>Mandatory.  <br />ISO 4217 code for currency you want to send the transaction in. This should be 'BRL' for PIX.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>Mandatory.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Mandatory.  <br />Price in decimal format upto 2 decimals.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Mandatory.  <br />Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is in progress state.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Mandatory  <br />URL to send the user if the transactions has failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"flow-diagram\">Flow Diagram:</h3>\n<img src=\"https://content.pstmn.io/8d726da8-02f8-49a4-a3a9-765cd3e1dd9a/RGVjcnlwdGVkIEZsb3cucG5n\" />","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"00f20fbd-c463-4137-b120-3628f0bd57fa","id":"00f20fbd-c463-4137-b120-3628f0bd57fa","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"824e26d0-47fc-4fa9-ae82-f0da1d93e4c7","name":"Purchase - success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"price\": \"10\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"GOOGLEPAY\",\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"googlepay_param\": {\r\n            \"google_merchant_id\": \"merchant:1234567890\",\r\n            \"googlepay_decrypted_payload\": {\r\n                \"messageExpiration\": \"1735689600000\",\r\n                \"messageId\": \"AH2EjtfkYz...\",\r\n                \"paymentMethod\": \"CARD\",\r\n                \"paymentMethodDetails\": {\r\n                    \"pan\": \"4111111111111111\",\r\n                    \"expirationMonth\": 12,\r\n                    \"expirationYear\": 2027,\r\n                    \"authMethod\": \"CRYPTOGRAM_3DS\",\r\n                    \"cryptogram\": \"AgAAAAAABk4D...\",\r\n                    \"eciIndicator\": \"05\"\r\n                },\r\n                \"gatewayMerchantId\": \"your_gateway_merchant_id\"\r\n            }\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69cce01f5bae56fd5547a993\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"updated_on\": 1775034399,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"GOOGLEPAY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1775034399,\r\n    \"merchantRef\": \"69cce01f5bae56fd5547a993\",\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"requestAmount\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Omega Pixel\",\r\n        \"brand_name\": \"Omega Pixel\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {},\r\n        \"country\": \"\",\r\n        \"attempts\": []\r\n    },\r\n    \"status\": \"CREATED\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1775034399\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS1032\",\r\n    \"issued\": \"2026-04-01\",\r\n    \"due\": 1775034399,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"extraFee\": \"0\",\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"103.80.161.238\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6b5a5977ac8e022facb31f3346f61ed0/\",\r\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/69cce01f5bae56fd5547a993/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"628fac99-314c-4b2b-ab54-7ad1ee06f6a2","name":"Purchase - failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"price\": \"10\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"GOOGLEPAY\",\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"googlepay_param\": {\r\n            \"google_merchant_id\": \"merchant:1234567890\",\r\n            \"googlepay_decrypted_payload\": {\r\n                \"messageExpiration\": \"1735689600000\",\r\n                \"messageId\": \"AH2EjtfkYz...\",\r\n                \"paymentMethod\": \"CARD\",\r\n                \"paymentMethodDetails\": {\r\n                    \"pan\": \"4111111111111111\",\r\n                    \"expirationMonth\": 12,\r\n                    \"expirationYear\": 2027,\r\n                    \"authMethod\": \"CRYPTOGRAM_3DS\",\r\n                    \"cryptogram\": \"AgAAAAAABk4D...\",\r\n                    \"eciIndicator\": \"05\"\r\n                },\r\n                \"gatewayMerchantId\": \"your_gateway_merchant_id\"\r\n            }\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"ffa051c7-a8cb-4526-81fc-b778a3b80f5b"},{"name":"Get Status","id":"3650713e-dbbe-43e8-b7f2-09cd0b1ce0f8","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"00f20fbd-c463-4137-b120-3628f0bd57fa","id":"00f20fbd-c463-4137-b120-3628f0bd57fa","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"05adb543-5008-4800-94a8-a914e5b024fb","name":"Purchase - success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69cce01f5bae56fd5547a993\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"updated_on\": 1775034399,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"GOOGLEPAY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1775034399,\r\n    \"merchantRef\": \"69cce01f5bae56fd5547a993\",\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"requestAmount\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Omega Pixel\",\r\n        \"brand_name\": \"Omega Pixel\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {},\r\n        \"country\": \"\",\r\n        \"attempts\": []\r\n    },\r\n    \"status\": \"CREATED\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1775034399\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS1032\",\r\n    \"issued\": \"2026-04-01\",\r\n    \"due\": 1775034399,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"extraFee\": \"0\",\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"103.80.161.238\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6b5a5977ac8e022facb31f3346f61ed0/\",\r\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/69cce01f5bae56fd5547a993/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"7fb23790-4b86-4b46-8241-75fe235ceb00","name":"Purchase - failure","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"3650713e-dbbe-43e8-b7f2-09cd0b1ce0f8"}],"id":"00f20fbd-c463-4137-b120-3628f0bd57fa","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"6ff637b4-6d33-454d-9510-bd0f0c7822e6","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"997f4d68-cf32-4e3e-b85f-dabd79a83a02","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"00f20fbd-c463-4137-b120-3628f0bd57fa","description":""}],"id":"82a70137-3b50-42dd-b13b-c78308dde29e","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"5edc9d3a-d3d6-4aa0-bf4b-d62efef1f209","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"13c2507f-e1c9-45f3-b599-0f551ebfe68c","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"82a70137-3b50-42dd-b13b-c78308dde29e","description":""},{"name":"🌎 Apple Pay (Seamless)","item":[{"name":"Concepts","item":[],"id":"c6a84b27-89f1-4950-b951-b5fe7685a8ca","description":"<h2 id=\"get-started\"><strong>Get started</strong></h2>\n<p>Paysecure’s Server-to-Server (S2S) integration for Apple Pay allows merchants to process Apple Pay transactions securely from their backend systems. In this model, merchants are responsible for generating the Apple Pay payment token on their client application and sending it to their server, which then communicates with Paysecure APIs.</p>\n<p>This integration uses DIRECT tokenization, where payment data is securely generated by Apple Pay and passed to Paysecure for processing.</p>\n<p>This integration is recommended for merchants who require:</p>\n<ul>\n<li><p>Integration with Apple Pay wallets</p>\n</li>\n<li><p>Secure handling of tokenized payment data</p>\n</li>\n<li><p>Flexibility in choosing PCI scope (encrypted vs decrypted flow)</p>\n</li>\n</ul>\n<hr />\n<h2 id=\"how-it-works\"><strong>How it works</strong></h2>\n<p>The Apple Pay S2S payment flow follows a two-step process:</p>\n<h4 id=\"1-generate-apple-pay-token-client-side\"><strong>1. Generate</strong> Apple <strong>Pay Token (Client-side)</strong></h4>\n<p>The merchant integrates Apple Pay SDK (Web/Android) to generate a payment token using DIRECT flow.</p>\n<h4 id=\"2-submit-token-via-s2s\"><strong>2. Submit Token via S2S</strong></h4>\n<p>The merchant server sends the Apple Pay token (encrypted or decrypted) to Paysecure via the /purchase API.</p>\n<hr />\n<h2 id=\"apple-pay-processing-overview\">Apple <strong>Pay Processing Overview</strong></h2>\n<p>Apple Pay transactions are processed as card-not-present payments using:</p>\n<ul>\n<li><p>Tokenized card data (DPAN)</p>\n</li>\n<li><p>Cryptogram generated by Apple</p>\n</li>\n<li><p>Device-based authentication (Face ID / Touch ID / Passcode)</p>\n</li>\n</ul>\n<p>These transactions go through:</p>\n<ul>\n<li><p>Card network (Visa, Mastercard, Amex, etc.)</p>\n</li>\n<li><p>Issuing bank authorization</p>\n</li>\n<li><p>Risk and fraud checks</p>\n</li>\n</ul>\n<hr />\n<h2 id=\"integration-options\">Integration Options</h2>\n<p>Paysecure supports two integration modes:</p>\n<hr />\n<h3 id=\"1-encrypted-token-flow-recommended\">1. Encrypted Token Flow (Recommended)</h3>\n<p>In this flow, the merchant sends the encrypted Apple Pay token to Paysecure. Paysecure decrypts and processes the payment.</p>\n<h4 id=\"key-characteristics\">Key Characteristics</h4>\n<ul>\n<li><p>Merchant does not handle PAN</p>\n</li>\n<li><p>Reduced PCI scope</p>\n</li>\n<li><p>Recommended for most merchants</p>\n</li>\n</ul>\n<h4 id=\"pci-impact\">PCI Impact</h4>\n<p>Merchants can significantly reduce PCI DSS scope since sensitive card data is handled by Paysecure.</p>\n<hr />\n<h3 id=\"2-decrypted-token-flow\">2. Decrypted Token Flow</h3>\n<p>In this flow, the merchant decrypts the Apple Pay token and sends card details to Paysecure.</p>\n<h4 id=\"key-characteristics-1\">Key Characteristics</h4>\n<ul>\n<li><p>PAN/DPAN available at merchant side</p>\n</li>\n<li><p>Full control over payment data</p>\n</li>\n</ul>\n<h4 id=\"pci-impact-1\">PCI Impact</h4>\n<p>Merchants must be PCI DSS compliant (SAQ D) as they handle raw card data.</p>\n<hr />\n<h2 id=\"before-you-begin\">Before you begin</h2>\n<p>Ensure the following prerequisites are met:</p>\n<ul>\n<li><p>You have received your API credentials from Paysecure</p>\n</li>\n<li><p>You have an Apple Merchant ID</p>\n</li>\n<li><p>You have configured Apple Pay on your domain/app</p>\n</li>\n<li><p>Your server can make secure HTTPS requests</p>\n</li>\n<li><p>You have a valid brand_id provided by Paysecure</p>\n</li>\n</ul>\n<hr />\n<h3 id=\"additional-requirements-encrypted-flow\">Additional Requirements (Encrypted Flow)</h3>\n<ul>\n<li><p>Configure Apple Pay certificates (Payment Processing Certificate)</p>\n</li>\n<li><p>Share certificate details securely with Paysecure (if required)</p>\n</li>\n</ul>\n<hr />\n<h3 id=\"additional-requirements-decrypted-flow\">Additional Requirements (Decrypted Flow)</h3>\n<ul>\n<li><p>Implement Apple Pay token decryption</p>\n</li>\n<li><p>Use Apple’s Payment Processing certificate and private key</p>\n</li>\n<li><p>Ensure full PCI DSS compliance</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"3689411e-823f-4b25-b92c-6ea3ad01be49","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"e1823e12-d492-42be-9907-ad507a512152","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"c6a84b27-89f1-4950-b951-b5fe7685a8ca"},{"name":"APIs","item":[{"name":"Purchases (Encrypted Flow)","id":"a1742d94-d994-476a-a7fd-108ba23fc19e","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"customer@example.com\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"Product\",\r\n                \"price\": \"10.00\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"APPLEPAY\",\r\n    \"brand_id\": \"your_brand_id\",\r\n    \"success_redirect\": \"https://success.com\",\r\n    \"pending_redirect\": \"https://pending.com\",\r\n    \"failure_redirect\": \"https://failure.com\",\r\n    \"extraParam\": {\r\n        \"applepay_param\": {\r\n            \"applepay_token\": {\r\n                \"version\": \"EC_v1\",\r\n                \"data\": \"...\",\r\n                \"signature\": \"...\",\r\n                \"header\": {\r\n                    \"ephemeralPublicKey\": \"...\",\r\n                    \"publicKeyHash\": \"...\",\r\n                    \"transactionId\": \"...\"\r\n                }\r\n            }\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To process an Apple Pay transaction, a Purchase must be created using the /purchases API. The Apple Pay token must be included under extraParam.applepay_param.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"parameters-in-the-request-body\"><strong>Parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.full_name</td>\n<td>Conditional.  <br />But Recommended to pass the complete name of the client. Atleast 2 words recommended.</td>\n</tr>\n<tr>\n<td>client.email</td>\n<td>Conditional.  <br />But Recommended to pass a correct email id.</td>\n</tr>\n<tr>\n<td>paymentMethod</td>\n<td>Conditional.  <br />Mandatory if you are not using Paysecure Cashier. Else Non Mandatory.  <br />Value: APPLEPAY</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>Mandatory.  <br />ISO 4217 code for currency you want to send the transaction in. This should be 'BRL' for PIX.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>Mandatory.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Mandatory.  <br />Price in decimal format upto 2 decimals.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Mandatory.  <br />Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is in progress state.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Mandatory  <br />URL to send the user if the transactions has failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"d6b3e1ec-5e8c-4dad-89b1-94de65b6052b","id":"d6b3e1ec-5e8c-4dad-89b1-94de65b6052b","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"0ff287ca-234d-4d18-bc8e-00bcbb3e2426","name":"Purchase - success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"customer@example.com\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"Product\",\r\n                \"price\": \"10.00\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"APPLEPAY\",\r\n    \"brand_id\": \"your_brand_id\",\r\n    \"success_redirect\": \"https://success.com\",\r\n    \"pending_redirect\": \"https://pending.com\",\r\n    \"failure_redirect\": \"https://failure.com\",\r\n    \"extraParam\": {\r\n        \"applepay_param\": {\r\n            \"applepay_token\": {\r\n                \"version\": \"EC_v1\",\r\n                \"data\": \"...\",\r\n                \"signature\": \"...\",\r\n                \"header\": {\r\n                    \"ephemeralPublicKey\": \"...\",\r\n                    \"publicKeyHash\": \"...\",\r\n                    \"transactionId\": \"...\"\r\n                }\r\n            }\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69cce01f5bae56fd5547a993\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"updated_on\": 1775034399,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"APPLEPAY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1775034399,\r\n    \"merchantRef\": \"69cce01f5bae56fd5547a993\",\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"requestAmount\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Omega Pixel\",\r\n        \"brand_name\": \"Omega Pixel\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {},\r\n        \"country\": \"\",\r\n        \"attempts\": []\r\n    },\r\n    \"status\": \"CREATED\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1775034399\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS1032\",\r\n    \"issued\": \"2026-04-01\",\r\n    \"due\": 1775034399,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"extraFee\": \"0\",\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"103.80.161.238\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6b5a5977ac8e022facb31f3346f61ed0/\",\r\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/69cce01f5bae56fd5547a993/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"6f59c08a-fa12-4d24-a8c3-e656356554b4","name":"Purchase - failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"customer@example.com\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"Product\",\r\n                \"price\": \"10.00\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"APPLEPAY\",\r\n    \"brand_id\": \"your_brand_id\",\r\n    \"success_redirect\": \"https://success.com\",\r\n    \"pending_redirect\": \"https://pending.com\",\r\n    \"failure_redirect\": \"https://failure.com\",\r\n    \"extraParam\": {\r\n        \"applepay_param\": {\r\n            \"applepay_token\": {\r\n                \"version\": \"EC_v1\",\r\n                \"data\": \"...\",\r\n                \"signature\": \"...\",\r\n                \"header\": {\r\n                    \"ephemeralPublicKey\": \"...\",\r\n                    \"publicKeyHash\": \"...\",\r\n                    \"transactionId\": \"...\"\r\n                }\r\n            }\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"a1742d94-d994-476a-a7fd-108ba23fc19e"},{"name":"Purchases (Decrypted Flow)","id":"e08cd967-f33c-4976-89e2-a251e6c02a8e","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"customer@example.com\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"Product\",\r\n                \"price\": \"10.00\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"APPLEPAY\",\r\n    \"brand_id\": \"your_brand_id\",\r\n    \"success_redirect\": \"https://success.com\",\r\n    \"pending_redirect\": \"https://pending.com\",\r\n    \"failure_redirect\": \"https://failure.com\",\r\n    \"extraParam\": {\r\n        \"applepay_param\": {\r\n            \"applepay_decrypted_payload\": {\r\n                \"applicationPrimaryAccountNumber\": \"4111111111111111\",\r\n                \"applicationExpirationDate\": \"2712\",\r\n                \"currencyCode\": \"840\",\r\n                \"transactionAmount\": 1000,\r\n                \"deviceManufacturerIdentifier\": \"040010030273\",\r\n                \"paymentDataType\": \"3DSecure\",\r\n                \"paymentData\": {\r\n                    \"onlinePaymentCryptogram\": \"AgAAAAAABk4D...\",\r\n                    \"eciIndicator\": \"05\"\r\n                }\r\n            }\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To process an Apple Pay transaction, a Purchase must be created using the /purchases API. The Apple Pay token must be included under extraParam.applepay_param.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"parameters-in-the-request-body\"><strong>Parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.full_name</td>\n<td>Conditional.  <br />But Recommended to pass the complete name of the client. Atleast 2 words recommended.</td>\n</tr>\n<tr>\n<td>client.email</td>\n<td>Conditional.  <br />But Recommended to pass a correct email id.</td>\n</tr>\n<tr>\n<td>paymentMethod</td>\n<td>Conditional.  <br />Mandatory if you are not using Paysecure Cashier. Else Non Mandatory.  <br />Value: APPLEPAY</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>Mandatory.  <br />ISO 4217 code for currency you want to send the transaction in. This should be 'BRL' for PIX.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>Mandatory.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Mandatory.  <br />Price in decimal format upto 2 decimals.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Mandatory.  <br />Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Mandatory.  <br />URL to send the user if the transactions is in progress state.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Mandatory  <br />URL to send the user if the transactions has failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"d6b3e1ec-5e8c-4dad-89b1-94de65b6052b","id":"d6b3e1ec-5e8c-4dad-89b1-94de65b6052b","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"7817d7e5-4ec0-4d56-825f-8b765f46f8e1","name":"Purchase - success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"customer@example.com\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"Product\",\r\n                \"price\": \"10.00\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"APPLEPAY\",\r\n    \"brand_id\": \"your_brand_id\",\r\n    \"success_redirect\": \"https://success.com\",\r\n    \"pending_redirect\": \"https://pending.com\",\r\n    \"failure_redirect\": \"https://failure.com\",\r\n    \"extraParam\": {\r\n        \"applepay_param\": {\r\n            \"applepay_decrypted_payload\": {\r\n                \"applicationPrimaryAccountNumber\": \"4111111111111111\",\r\n                \"applicationExpirationDate\": \"2712\",\r\n                \"currencyCode\": \"840\",\r\n                \"transactionAmount\": 1000,\r\n                \"deviceManufacturerIdentifier\": \"040010030273\",\r\n                \"paymentDataType\": \"3DSecure\",\r\n                \"paymentData\": {\r\n                    \"onlinePaymentCryptogram\": \"AgAAAAAABk4D...\",\r\n                    \"eciIndicator\": \"05\"\r\n                }\r\n            }\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69cce01f5bae56fd5547a993\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"updated_on\": 1775034399,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"APPLEPAY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1775034399,\r\n    \"merchantRef\": \"69cce01f5bae56fd5547a993\",\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"requestAmount\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Omega Pixel\",\r\n        \"brand_name\": \"Omega Pixel\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {},\r\n        \"country\": \"\",\r\n        \"attempts\": []\r\n    },\r\n    \"status\": \"CREATED\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1775034399\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS1032\",\r\n    \"issued\": \"2026-04-01\",\r\n    \"due\": 1775034399,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"extraFee\": \"0\",\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"103.80.161.238\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6b5a5977ac8e022facb31f3346f61ed0/\",\r\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/69cce01f5bae56fd5547a993/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"c9fa190e-324c-4f29-83af-90a58be3d2a8","name":"Purchase - failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"customer@example.com\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"Product\",\r\n                \"price\": \"10.00\"\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"APPLEPAY\",\r\n    \"brand_id\": \"your_brand_id\",\r\n    \"success_redirect\": \"https://success.com\",\r\n    \"pending_redirect\": \"https://pending.com\",\r\n    \"failure_redirect\": \"https://failure.com\",\r\n    \"extraParam\": {\r\n        \"applepay_param\": {\r\n            \"applepay_decrypted_payload\": {\r\n                \"applicationPrimaryAccountNumber\": \"4111111111111111\",\r\n                \"applicationExpirationDate\": \"2712\",\r\n                \"currencyCode\": \"840\",\r\n                \"transactionAmount\": 1000,\r\n                \"deviceManufacturerIdentifier\": \"040010030273\",\r\n                \"paymentDataType\": \"3DSecure\",\r\n                \"paymentData\": {\r\n                    \"onlinePaymentCryptogram\": \"AgAAAAAABk4D...\",\r\n                    \"eciIndicator\": \"05\"\r\n                }\r\n            }\r\n        }\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"e08cd967-f33c-4976-89e2-a251e6c02a8e"},{"name":"Get Status","id":"440ee1d3-bbab-4cea-839f-906bbfa21015","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"d6b3e1ec-5e8c-4dad-89b1-94de65b6052b","id":"d6b3e1ec-5e8c-4dad-89b1-94de65b6052b","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"88812de1-05f4-46cc-a6df-5071b35383e1","name":"Purchase - success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"69cce01f5bae56fd5547a993\",\r\n    \"client\": {\r\n        \"customerId\": \"NA\",\r\n        \"email\": \"himanshu1@paysecure.net\",\r\n        \"full_name\": \"OpHM\",\r\n        \"date_of_birth\": \"1800-01-01\",\r\n        \"street_address\": \"SB-124\",\r\n        \"country\": \"BR\",\r\n        \"city\": \"DLJPR\",\r\n        \"zip_code\": \"110001\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"DL\"\r\n    },\r\n    \"updated_on\": 1775034399,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"GOOGLEPAY\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"errorCode\": \"NA\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1775034399,\r\n    \"merchantRef\": \"69cce01f5bae56fd5547a993\",\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"requestAmount\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"taxAmount\": 0.0,\r\n        \"taxPercent\": 0.0,\r\n        \"request_client_details\": [],\r\n        \"email_message\": \"\"\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"Omega Pixel\",\r\n        \"brand_name\": \"Omega Pixel\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {},\r\n        \"country\": \"\",\r\n        \"attempts\": []\r\n    },\r\n    \"status\": \"CREATED\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1775034399\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"f1764688-d991-481b-be63-9ee7f33dcd31\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS1032\",\r\n    \"issued\": \"2026-04-01\",\r\n    \"due\": 1775034399,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"extraFee\": \"0\",\r\n    \"paidOn\": 0,\r\n    \"receivedAmt\": 0.0,\r\n    \"taxAmount\": 0.0,\r\n    \"surcharge\": 0.0,\r\n    \"surchargeType\": \"\",\r\n    \"sessionId\": \"\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"success_redirect\": \"https://google.com/\",\r\n    \"failure_redirect\": \"https://facebook.com/\",\r\n    \"pending_redirect\": \"https://paysecure.net\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"103.80.161.238\",\r\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6b5a5977ac8e022facb31f3346f61ed0/\",\r\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/69cce01f5bae56fd5547a993/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"5012686e-170a-4ece-8938-1c36efe4e863","name":"Purchase - failure","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"440ee1d3-bbab-4cea-839f-906bbfa21015"}],"id":"d6b3e1ec-5e8c-4dad-89b1-94de65b6052b","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"6ff637b4-6d33-454d-9510-bd0f0c7822e6","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"997f4d68-cf32-4e3e-b85f-dabd79a83a02","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"d6b3e1ec-5e8c-4dad-89b1-94de65b6052b","description":""}],"id":"59acd0e3-9f0b-432f-bd6f-f6bf5479c57b","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"5edc9d3a-d3d6-4aa0-bf4b-d62efef1f209","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"13c2507f-e1c9-45f3-b599-0f551ebfe68c","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"59acd0e3-9f0b-432f-bd6f-f6bf5479c57b","description":""},{"name":"🌐 Paymint - Crypto Wallet","item":[{"name":"Concepts","item":[],"id":"1ed487a7-97d2-418f-8ece-197e8ed30fcb","description":"<h3 id=\"customer-payment-flow\">Customer Payment Flow</h3>\n<p>1. Onboarding &amp; Wallet Creation</p>\n<ul>\n<li><p>Customer visits your site and selects a product/service.</p>\n</li>\n<li><p>At checkout, if the merchant has not pre-populated the email field, the system prompts the customer to input their email address.</p>\n</li>\n</ul>\n<p>2. Fiat Payment Initiation</p>\n<ul>\n<li><p>Customer selects a payment method and pays in fiat (currency shown on the checkout screen).</p>\n</li>\n<li><p>Paysecure monitors the transaction and, on successful payment, give success to merchant.</p>\n</li>\n<li><p>On the backend, we convert the amount to stablecoin (e.g., USDC).</p>\n</li>\n</ul>\n<p>3. Post Fiat-Payment Notification</p>\n<ul>\n<li>Merchant can track the transaction through webhooks or the Paysecure dashboard.</li>\n</ul>\n<p>4. Fiat to Crypto Conversion (Behind the scenes)</p>\n<ul>\n<li><p>The fiat amount is converted to crypto using Paysecure’s exchange integrations.</p>\n</li>\n<li><p>The converted crypto is credited to the customer’s wallet in real time.</p>\n</li>\n</ul>\n<p>5. Merchant Crypto Settlement</p>\n<ul>\n<li><p>The required amount is automatically transferred from the customer’s Paymint wallet to your merchant's Paymint wallet.</p>\n</li>\n<li><p>Both transactions (funding and transfer) are recorded in Paysecure’s ledger for compliance and traceability.</p>\n</li>\n</ul>\n<p>6. Wallet Management<br />Customer Dashboard Access Customers can manage their Paymint wallets through paymint.locker, where they can view wallet balance and transaction history.</p>\n<p>7. Wallet Security</p>\n<ul>\n<li><p>2FA verification for wallet access.</p>\n</li>\n<li><p>Ledger integrity checks for all transactions.</p>\n</li>\n</ul>\n<p>Wallet Recovery or Closure</p>\n<ul>\n<li>Customers can recover wallet access via OTP/email.</li>\n</ul>\n","_postman_id":"1ed487a7-97d2-418f-8ece-197e8ed30fcb"},{"name":"Payin API","item":[{"name":"Purchases","id":"92d46cd4-9e67-424e-99bc-ca81676c90ac","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"seo2009@test.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"CA\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"CAD\",\r\n        \"expireInMin\": \"80\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 100\r\n            }\r\n        ]\r\n    },\r\n    \"extraParam\": {\r\n        \"IsCryptoPurchase\": \"yes\"\r\n    },\r\n    \"paymentMethod\": \"\",\r\n    \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\r\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://your.success.callback.url\",\r\n    \"failure_callback\": \"https://your.success.failure.url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. It must be upper case.  <br />This should be \"CA\" for Interac</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”.. Must be in upper case.</td>\n</tr>\n<tr>\n<td>client.street_address</td>\n<td></td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td></td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td></td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />This should be 'CAD' for Interac</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>name of the product or service</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>extraParam.IsCryptoPurchase</td>\n<td>for paymint, send \"Yes\"</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in progress</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is UNSUCCESSFUL</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>The <code>purchase.expireInMin</code>, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td></td>\n</tr>\n<tr>\n<td>Enter Valid Email</td>\n<td></td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td></td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect/failure_redirect/brand_id is missing</td>\n<td></td>\n</tr>\n<tr>\n<td>brand_id cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>failure_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid failure_redirect: minimum 10 characters</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products[0].name/purchase.products[0].price are missing</td>\n<td></td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td></td>\n</tr>\n<tr>\n<td>Currency \"{curr_name}\" is Not Allowed</td>\n<td></td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong> For certain use cases, in addition to long format purchase Id, Paysecure also provides a 7 digit unique code for each purchase starting with digit 4, eg 4000001</p>\n<p><em>“purchaseIdShortCode”: “4000013\"</em></p>\n","urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"4719aa82-9154-4d48-9647-d86a0ab84de9","name":"Purchase- success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"seo2009@test.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"London\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"CA\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"CAD\",\r\n        \"expireInMin\": \"80\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test \",\r\n                \"price\": 100\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"INTERAC-ETRANSFER\",\r\n    \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\r\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://your.success.callback.url\",\r\n    \"failure_callback\": \"https://your.success.failure.url\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\"purchaseId\":\"67efd0ff97be603f97a3a697\",\"client\":{\"customerId\":\"NA\",\"email\":\"ashishm.21190@gmail.com\",\"phone\":\"+447755564318\",\"full_name\":\"Test test\",\"date_of_birth\":\"1970-07-10\",\"street_address\":\"10 New Burlington Street Apt. 214\",\"country\":\"CA\",\"city\":\"London\",\"zip_code\":\"W1S 3BE\",\"cc\":[],\"bcc\":[],\"gender\":\"MALE\",\"avatarUrl\":\"https://res.cloudinary.com/w22/image/upload/v1663783641/photos/currencies/ngn.png\",\"stateCode\":\"QLD\"},\"updated_on\":1743769856,\"type\":\"purchase\",\"paymentMethod\":\"INTERAC-ETRANSFER\",\"amountUnit\":\"MAJOR\",\"errorMsg\":\"\",\"redirectType\":\"GET\",\"force_recurring\":false,\"created_on\":1743769855,\"merchantRef\":\"67efd0ff97be603f97a3a697\",\"merchantName\":\"arunsinghal\",\"purchase\":{\"currency\":\"CAD\",\"products\":[{\"name\":\"test\",\"quantity\":1.0,\"price\":1.0,\"discount\":0,\"tax_percent\":\"0.00\"}],\"total\":1.0,\"language\":\"en\",\"notes\":\"\",\"debt\":0,\"total_formatted\":1.0,\"expireInMin\":\"43200\",\"taxAmount\":0.0,\"taxPercent\":0.0,\"request_client_details\":[],\"email_message\":\"\"},\"payment\":{\"is_outgoing\":false,\"payment_type\":\"PURCHASE\",\"amount\":1.0,\"currency\":\"CAD\",\"net_amount\":1.0,\"fee_amount\":0.0,\"pending_amount\":0.0,\"pending_unfreeze_on\":null,\"description\":\"\",\"paid_on\":1743769855,\"remote_paid_on\":1743769855},\"issuer_details\":{\"website\":\"\",\"legal_street_address\":\"\",\"legal_country\":\"\",\"legal_city\":\"\",\"legal_zip_code\":\"\",\"bank_accounts\":[{}],\"legal_name\":\"test6\",\"brand_name\":\"test6\",\"registration_number\":\"\",\"tax_number\":\"\"},\"transaction_data\":{\"payment_method\":\"\",\"flow\":\"payform\",\"extra\":{\"amount\":1.0,\"masked_pan\":\"INTERAC-ETRANSFER\"},\"country\":\"\",\"attempts\":[{\"client_ip\":\"103.59.75.41, 162.158.88.44, 130.176.93.146\",\"type\":\"execute\",\"payment_method\":\"INTERAC-ETRANSFER\",\"flow\":\"payform\",\"successful\":true,\"country\":\"INTERAC-ETRANSFER\",\"processing_time\":1743769855,\"extra\":{\"amount\":1.0,\"masked_pan\":\"INTERAC-ETRANSFER\"}}]},\"status\":\"PAYMENT_IN_PROCESS\",\"status_history\":[{\"status\":\"created\",\"timestamp\":1743769855},{\"status\":\"pending_execute\",\"timestamp\":1743769855},{\"status\":\"payment_in_process\",\"timestamp\":1743769856},{\"status\":\"viewed\",\"timestamp\":1744026697}],\"viewedOn\":1744026697,\"is_test\":false,\"brand_id\":\"30f7ce6e-3b7e-46a2-9b50-484fc55be689\",\"send_receipt\":false,\"is_recurring_token\":false,\"skip_capture\":false,\"reference_generated\":\"PS620\",\"issued\":\"2025-04-04\",\"due\":1743769855,\"refund_upto\":0,\"cc_descriptor\":\"Africhange Technologies\",\"fraudScore\":\"NA\",\"trustScore\":\"NA\",\"payInDetails\":{\"name\":\"INTERAC\",\"emailAddress\":\"transfer@ieft.ca\",\"secretQA\":\"66a8c78af1fc2f768304bce4\",\"secretAnswer\":\"ps8766a8af\"},\"paidOn\":0,\"receivedAmt\":0.0,\"refund_availability\":\"NONE\",\"refundable_amount\":0.0,\"success_redirect\":\"https://your.redirect.url/getResponse.jsp?success=true\",\"failure_redirect\":\"https://your.redirect.url/getResponse.jsp?success=false\",\"cancel_redirect\":\"\",\"success_callback\":\"https://your.success.callback.url\",\"failure_callback\":\"https://your.success.failure.url\",\"platform\":\"API\",\"created_from_ip\":\"103.59.75.41, 162.158.88.44, 130.176.93.146\",\"checkout_url\":\"https://api.choicepay.ca/payments/67efd0ff97be603f97a3a697/\",\"payoutProcess\":false}"}],"_postman_id":"92d46cd4-9e67-424e-99bc-ca81676c90ac"},{"name":"Get Status","id":"b431e2a4-2e55-4322-a223-3f4861e0f761","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<p><strong>Note:</strong> With respect to bank transfers, the purchase request is synonymous with the PayIn request.</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"01e5e26f-1b1a-4d55-ac2c-79bc2e26a63c","name":"Purchases-success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"6790e75fa46a5a5bb0b00e55\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"phone\": \"+14377717874\",\n        \"full_name\": \"Test test\",\n        \"date_of_birth\": \"1970-07-10\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"country\": \"CA\",\n        \"city\": \"London\",\n        \"zip_code\": \"W1S 3BE\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"gender\": \"MALE\",\n        \"stateCode\": \"QLD\"\n    },\n    \"updated_on\": 1737549752,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"INTERAC-ETRANSFER\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"Transaction succeeded-APPROVED\",\n    \"redirectType\": \"GET\",\n    \"force_recurring\": false,\n    \"created_on\": 1737549663,\n    \"merchantRef\": \"6790e75fa46a5a5bb0b00e55\",\n    \"merchantName\": \"arunsinghal\",\n    \"purchase\": {\n        \"currency\": \"CAD\",\n        \"products\": [\n            {\n                \"name\": \"test\",\n                \"quantity\": 1,\n                \"price\": 1,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 2,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"expireInMin\": \"43200\",\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 1,\n        \"currency\": \"CAD\",\n        \"net_amount\": 1,\n        \"fee_amount\": 0,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1737549663,\n        \"remote_paid_on\": 1737549663\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"test6\",\n        \"brand_name\": \"test6\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"amount\": 1,\n            \"masked_pan\": \"INTERAC-ETRANSFER\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"103.59.75.42, 172.71.186.102, 130.176.183.14\",\n                \"type\": \"execute\",\n                \"payment_method\": \"INTERAC-ETRANSFER\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"INTERAC\",\n                \"processing_time\": 1737549663,\n                \"extra\": {\n                    \"amount\": 1,\n                    \"masked_pan\": \"INTERAC-ETRANSFER\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1737549663\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1737549663\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1737549664\n        },\n        {\n            \"status\": \"paid 2.0\",\n            \"timestamp\": 1737549752\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1737549750\n        }\n    ],\n    \"viewedOn\": 1738749942,\n    \"is_test\": false,\n    \"brand_id\": \"30f7ce6e-3b7e-46a2-9b50-484fc55be689\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS376\",\n    \"issued\": \"2025-01-22\",\n    \"due\": 1737549663,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"Africhange Technologies\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"payInDetails\": {\n        \"name\": \"INTERAC\",\n        \"emailAddress\": \"deposit@ieft.ca\",\n        \"secretQA\": \"66a8c78af1fc2f768304bce4\",\n        \"secretAnswer\": \"ps8766a8af\"\n    },\n    \"paidOn\": 1737549752,\n    \"receivedAmt\": 2,\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://your.redirect.url/getResponse.jsp?success=true\",\n    \"failure_redirect\": \"https://your.redirect.url/getResponse.jsp?success=false\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://webhook.site/83df9776-3590-4e25-9222-870e931ac868\",\n    \"failure_callback\": \"https://webhook.site/83df9776-3590-4e25-9222-870e931ac868\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"103.59.75.42, 172.71.186.102, 130.176.183.14\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6790e75fa46a5a5bb0b00e55/\",\n    \"payoutProcess\": false\n}"},{"id":"ab504a8a-46e6-44f3-bfa1-0ff18f16f872","name":"Purchases Error","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"code":400,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Error Message\",\n    \"code\": \"error_code\"\n}"}],"_postman_id":"b431e2a4-2e55-4322-a223-3f4861e0f761"}],"id":"67f75209-0017-4799-9838-0e9c3ebc564f","description":"<p><strong>API Flow</strong></p>\n<ol>\n<li><p>The merchant initiates the purchase via the <code>/purchases</code> API. If successful, they receive PayIn details along with a checkout URL in the response JSON</p>\n</li>\n<li><p>The merchant then has 2 options</p>\n<ol>\n<li><p>If the \"paymentMethod\" is passed, the payment instructions are shared with the customer. The flow differs as per the payment method.</p>\n</li>\n<li><p>If the \"paymentMethod\" is not passed, the custoemr is redirected to Paysecure cashier and complet the payment.</p>\n</li>\n</ol>\n</li>\n<li><p>After a successful or failed payment by the end user, an appropriate webhook would be sent to the merchant and the user would be redirected to the appropriate success or failure redirect URL.</p>\n</li>\n</ol>\n","_postman_id":"67f75209-0017-4799-9838-0e9c3ebc564f"}],"id":"760117f9-433e-4465-8d5e-88ac77e5668b","description":"<h2 id=\"overview\">Overview</h2>\n<p>Paymint is a new payment method by Paysecure that allows your customers to pay in fiat while you receive funds directly in cryptocurrency, such as USDC. With Paymint, you can offer your customers a seamless payment experience in their local currency, while crypto conversion and settlement are handled in the background.<br />This guide explains the core concepts and outlines the API integration steps required to enable Paymint on your platform.</p>\n","_postman_id":"760117f9-433e-4465-8d5e-88ac77e5668b"},{"name":"🌎 Neosurf - Voucher Payments","item":[{"name":"Concepts","item":[],"id":"7252f287-c86d-450c-977a-27a17be513ac","description":"<h2 id=\"1-what-is-a-neosurf-voucher\">1. What Is a Neosurf Voucher?</h2>\n<p>A <strong>Neosurf voucher</strong> is a prepaid payment instrument that lets users make online purchases without needing a bank account or credit card. Each voucher comes with a unique code (and sometimes a PIN) and is issued in fixed denominations. These vouchers are particularly popular for digital goods and services such as gaming, software, and entertainment.</p>\n<p><strong>Key Features:</strong></p>\n<ul>\n<li><p><strong>Prepaid &amp; Secure:</strong> Funds are preloaded, reducing fraud risk.</p>\n</li>\n<li><p><strong>Anonymous:</strong> No need to share personal banking details.</p>\n</li>\n<li><p><strong>Fixed Denominations:</strong> Typically available in preset values (e.g., €10, €20, €50).</p>\n</li>\n<li><p><strong>Instant Use:</strong> Once purchased, the voucher can be used immediately for online transactions.</p>\n</li>\n</ul>\n<hr />\n<h2 id=\"2-how-can-a-customer-buy-a-neosurf-voucher\">2. How Can a Customer Buy a Neosurf Voucher?</h2>\n<p>Neosurf vouchers are available both online and at physical retail locations. Availability varies by region, and the list below provides a general guide.</p>\n<h3 id=\"europe\"><strong>Europe</strong></h3>\n<ul>\n<li><p><strong>Western &amp; Central Europe:</strong></p>\n<ul>\n<li><p><strong>Countries:</strong> France, Germany, United Kingdom, Italy, Spain, Belgium, Netherlands, Luxembourg, Switzerland, Austria, Portugal, Ireland, Denmark, Sweden, Norway, Finland.</p>\n</li>\n<li><p><strong>Where to Buy:</strong> Local convenience stores, newsagents, supermarkets, and authorized online resellers.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Eastern Europe:</strong></p>\n<ul>\n<li><p><strong>Countries:</strong> Poland, Czech Republic, Hungary, Romania, etc.</p>\n</li>\n<li><p><strong>Where to Buy:</strong> Local retail outlets and specialized online vendors.</p>\n</li>\n</ul>\n</li>\n</ul>\n<h3 id=\"north-america\"><strong>North America</strong></h3>\n<ul>\n<li><p><strong>United States &amp; Canada:</strong></p>\n<ul>\n<li><strong>Where to Buy:</strong> Select online vendors and select physical retail outlets (availability may be limited). Always verify with local authorized distributors.</li>\n</ul>\n</li>\n</ul>\n<h3 id=\"asia\"><strong>Asia</strong></h3>\n<ul>\n<li><p><strong>Southeast Asia:</strong></p>\n<ul>\n<li><p><strong>Countries:</strong> Singapore, Malaysia, Indonesia, Thailand.</p>\n</li>\n<li><p><strong>Where to Buy:</strong> Authorized e-voucher platforms online.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Other Regions:</strong></p>\n<ul>\n<li>Availability may vary. Check the Neosurf official website for up-to-date information.</li>\n</ul>\n</li>\n</ul>\n<h3 id=\"africa\"><strong>Africa</strong></h3>\n<ul>\n<li><p><strong>Example Countries:</strong></p>\n<ul>\n<li><strong>South Africa, Morocco, Tunisia:</strong> Available through select online platforms and local authorized vendors.</li>\n</ul>\n</li>\n</ul>\n<h3 id=\"oceania\"><strong>Oceania</strong></h3>\n<ul>\n<li><p><strong>Australia &amp; New Zealand:</strong></p>\n<ul>\n<li>Vouchers may be available primarily via online resellers; check local availability.</li>\n</ul>\n</li>\n</ul>\n<blockquote>\n<p>Note: For the most comprehensive and current list of regions and authorized vendors, please refer to the official Neosurf website or contact Neosurf support. </p>\n</blockquote>\n<hr />\n<h2 id=\"3-how-to-pay-using-a-neosurf-voucher\">3. How to Pay Using a Neosurf Voucher</h2>\n<p>The payment process using a Neosurf voucher with Paysecure is streamlined to offer a secure and user-friendly checkout experience. The high-level flow is as follows:</p>\n<ol>\n<li><p><strong>User Selects Neosurf at Checkout:</strong></p>\n<p> On your payment page, the customer chooses “Neosurf” as their payment method.</p>\n</li>\n<li><p><strong>API Call Initiation:</strong></p>\n<ul>\n<li><p>Merchant invokes Paysecure’s <code>/v1/purchases</code> endpoint with <code>paymentMethod = NEOSURF</code>.</p>\n</li>\n<li><p>Paysecure returns a <code>checkoutUrl</code> where the customer is redirected to Neosurf page and asked to enter their Neosurf voucher code or pay via MyNeosurf account in selected regions.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Voucher Validation:</strong></p>\n<p> Neosurf checks the voucher’s validity and available balance. <strong>If valid,</strong> the billing amount is debited from the voucher.</p>\n</li>\n<li><p><strong>Transaction Confirmation:</strong></p>\n<p> A successful webhook response confirms the transaction, and the merchant system can finalize the order.</p>\n</li>\n</ol>\n<h2 id=\"4-why-should-a-merchant-accept-neosurf-voucher\">4. Why Should a Merchant Accept NeoSurf Voucher?</h2>\n<p>Integrating Neosurf offers several compelling advantages for merchants:</p>\n<ul>\n<li><p><strong>Broader Customer Reach:</strong></p>\n<ul>\n<li>Attract customers without bank accounts or credit cards, especially in regions where traditional banking is less prevalent.</li>\n</ul>\n</li>\n<li><p><strong>Enhanced Security &amp; Reduced Fraud:</strong></p>\n<ul>\n<li>Prepaid vouchers reduce the risk of fraudulent transactions since funds are preloaded.</li>\n</ul>\n</li>\n<li><p><strong>Increased Conversion Rates:</strong></p>\n<ul>\n<li>Offering a simple and fast payment option can lower cart abandonment rates, particularly in digital and gaming markets.</li>\n</ul>\n</li>\n<li><p><strong>Customer Privacy:</strong></p>\n<ul>\n<li>NeoSurf enables anonymous transactions, appealing to users concerned about data privacy.</li>\n</ul>\n</li>\n<li><p><strong>Competitive Advantage:</strong></p>\n<ul>\n<li>Stand out by offering multiple payment options, making your platform more attractive to a diverse audience.</li>\n</ul>\n</li>\n<li><p><strong>Streamlined Integration:</strong></p>\n<ul>\n<li>With direct integration via Paysecure’s API, merchants can quickly add NeoSurf without complex changes to their existing payment workflows</li>\n</ul>\n</li>\n</ul>\n<p>Accepting NeoSurf not only diversifies your payment portfolio but also taps into a growing market of digital consumers looking for secure, convenient, and privacy-focused payment options.</p>\n","_postman_id":"7252f287-c86d-450c-977a-27a17be513ac"},{"name":"Payin API","item":[{"name":"Purchases","id":"120ba5e0-b3d5-4480-a21c-03eadbd4f27d","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer {{your_API_Key}}"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"example22@paysecure.net\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"stateCode\": \"ca\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\",\n        \"phone\": \"9999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"AUD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"price\": \"1\"\n            }\n        ]\n    },\n    \"paymentMethod\": \"NEOSURF\",\n    \"brand_id\": \"{{your_brand_id_}}\",\n    \"send_receipt\": \"\",\n    \"skip_capture\": \"\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<p>The API endpoint <a href=\"https://api.paysecure.net/api/v1/purchases\">/v1/purchases</a> is a POST request used to create a new purchase. The request body should contain the client information including email, address, and phone, the purchase details such as currency and products, the payment method, and various callback and redirect URLs.</p>\n<p><strong>Final Steps for Payin API Integration</strong></p>\n<ol>\n<li><p><strong>Set Up Authentication &amp; Headers</strong></p>\n<ul>\n<li><p><strong>Endpoint:</strong> POST &gt;</p>\n</li>\n<li><p><strong>Headers (mandatory):</strong></p>\n<ul>\n<li><p>Authorization: Bearer {LIVE_API_KEY}</p>\n</li>\n<li><p>Content-Type: application/json</p>\n</li>\n</ul>\n</li>\n</ul>\n</li>\n<li><p><strong>Construct the Request Payload</strong></p>\n<ul>\n<li><p>Build a JSON body with:</p>\n<ul>\n<li><p>client object (KYC/AML fields):</p>\n<ul>\n<li><p>email</p>\n</li>\n<li><p>country (ISO-2 code)</p>\n</li>\n<li><p>city</p>\n</li>\n<li><p>stateCode</p>\n</li>\n<li><p>street_address</p>\n</li>\n<li><p>zip_code</p>\n</li>\n<li><p>phone</p>\n</li>\n</ul>\n</li>\n<li><p>purchase object:</p>\n<ul>\n<li><p>currency</p>\n</li>\n<li><p>products array (≥1 item with name and price)</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Top-level fields:</strong></p>\n<ul>\n<li><p>paymentMethod (e.g., \"NEOSURF\")</p>\n</li>\n<li><p>brand_id (your Brand UUID)</p>\n</li>\n<li><p>success_redirect (HTTPS URL after success)</p>\n</li>\n<li><p>failure_redirect (HTTPS URL after failure)</p>\n</li>\n</ul>\n</li>\n</ul>\n</li>\n</ul>\n</li>\n<li><p><strong>Invoke the Payin API</strong></p>\n<ul>\n<li><p>Send the JSON payload to <a href=\"https://api.paysecure.net/v1/purchases\">https://api.paysecure.net/v1/purchases</a></p>\n</li>\n<li><p>Expect 200 OK with a response containing:</p>\n<ul>\n<li><p>purchaseId</p>\n</li>\n<li><p>status = PENDING</p>\n</li>\n<li><p>checkout_url</p>\n</li>\n</ul>\n</li>\n</ul>\n</li>\n<li><p><strong>Extract Key References</strong></p>\n<ul>\n<li><p>purchaseId (e.g., 68394314d3c4ef68d6cbb58c): for tracking/reconciliation.</p>\n</li>\n<li><p>checkout_url (e.g., <a href=\"https://api.paysecure.net/payments/68394314d3c4ef68d6cbb58c/\">https://api.paysecure.net/payments/68394314d3c4ef68d6cbb58c/</a>): redirect here so the customer can complete voucher entry.</p>\n</li>\n<li><p>Redirect Customer <code>window.location.href = response.checkout_url;</code> Customer enters their 10-digit Neosurf voucher on redirected page.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Listen for Webhook Notifications</strong></p>\n<ul>\n<li><p>Ensure your endpoint handles:</p>\n<ul>\n<li><p>purchase.paid</p>\n</li>\n<li><p>purchase.error</p>\n</li>\n<li><p>purchase.cancelled</p>\n</li>\n</ul>\n</li>\n<li><p>Each payload will include purchaseId, status, amount, currency, etc.</p>\n</li>\n</ul>\n</li>\n</ol>\n<h3 id=\"mandatory-parameters\">Mandatory Parameters</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Field</th>\n<th>Type</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><strong>Authorization</strong></td>\n<td>string</td>\n<td><code>Bearer {API_KEY}</code> (replace with your live or staging API key).</td>\n</tr>\n<tr>\n<td><strong>Content-Type</strong></td>\n<td>string</td>\n<td>Must be <code>application/json</code>.</td>\n</tr>\n<tr>\n<td><strong>client.email</strong></td>\n<td>string</td>\n<td>Customer’s email (e.g., <code>example22@paysecure.net</code>).</td>\n</tr>\n<tr>\n<td><strong>client.country</strong></td>\n<td>string</td>\n<td>ISO‐3166 Alpha-2 code (e.g., <code>IN</code>).</td>\n</tr>\n<tr>\n<td><strong>client.city</strong></td>\n<td>string</td>\n<td>City name or code (e.g., <code>123</code>).</td>\n</tr>\n<tr>\n<td><strong>client.stateCode</strong></td>\n<td>string</td>\n<td>State or province code (two letters where possible, e.g., <code>ca</code>).</td>\n</tr>\n<tr>\n<td><strong>client.street_address</strong></td>\n<td>string</td>\n<td>Street address line (e.g., <code>test test</code>).</td>\n</tr>\n<tr>\n<td><strong>client.zip_code</strong></td>\n<td>string</td>\n<td>Postal/ZIP code (e.g., <code>234567</code>).</td>\n</tr>\n<tr>\n<td><strong>client.phone</strong></td>\n<td>string</td>\n<td>Customer’s phone number (E.164 recommended, e.g., <code>9999999999</code>).</td>\n</tr>\n<tr>\n<td><strong>purchase.currency</strong></td>\n<td>string</td>\n<td>Currency code (e.g., <code>AUD</code>).</td>\n</tr>\n<tr>\n<td><strong>purchase.products</strong></td>\n<td>array</td>\n<td>Must contain at least one object with <code>name</code> and <code>price</code>.</td>\n</tr>\n<tr>\n<td>└─ <strong>products.name</strong></td>\n<td>string</td>\n<td>Product name or SKU (e.g., <code>dk</code>).</td>\n</tr>\n<tr>\n<td>└─ <strong>products.price</strong></td>\n<td>string</td>\n<td>Unit price in major currency units (e.g., <code>\"1\"</code> = 1.00 AUD).</td>\n</tr>\n<tr>\n<td><strong>paymentMethod</strong></td>\n<td>string</td>\n<td>Payment rail code (e.g., <code>NEOSURF</code>).</td>\n</tr>\n<tr>\n<td><strong>brand_id</strong></td>\n<td>string</td>\n<td>Live or staging Brand UUID (e.g., <code>c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636</code>).</td>\n</tr>\n<tr>\n<td><strong>success_redirect</strong></td>\n<td>string</td>\n<td>HTTPS URL to redirect after successful payment (e.g., <code>https://your.success.redirect.com</code>).</td>\n</tr>\n<tr>\n<td><strong>failure_redirect</strong></td>\n<td>string</td>\n<td>HTTPS URL to redirect after failed payment (e.g., <code>https://your.failure.redirect.com</code>).</td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"protocol":"https","path":["api","v1","purchases"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"17233b96-b785-4d48-8564-a465be451246","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer {{your_API_Key}}"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"example22@paysecure.net\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"stateCode\": \"ca\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\",\n        \"phone\": \"9999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"AUD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"price\": \"1\"\n            }\n        ]\n    },\n    \"paymentMethod\": \"NEOSURF\",\n    \"brand_id\": \"{{your_brand_id_}}\",\n    \"send_receipt\": \"\",\n    \"skip_capture\": \"\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"683d6bab12b471481d4f66cf\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"example22@paysecure.net\",\n        \"phone\": \"9999999999\",\n        \"date_of_birth\": \"1800-01-01\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1748855724,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"NEOSURF\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"GET\",\n    \"force_recurring\": false,\n    \"created_on\": 1748855723,\n    \"merchantRef\": \"683d6bab12b471481d4f66cf\",\n    \"merchantName\": \"arunsinghal\",\n    \"purchase\": {\n        \"currency\": \"AUD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 1,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 1,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"taxAmount\": 0,\n        \"taxPercent\": 0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 1,\n        \"currency\": \"AUD\",\n        \"net_amount\": 1,\n        \"fee_amount\": 0,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1748855723,\n        \"remote_paid_on\": 1748855723\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"test6\",\n        \"brand_name\": \"test6\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"amount\": 1,\n            \"masked_pan\": \"NEOSURF\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"103.59.75.242, 162.158.23.126, 130.176.183.12\",\n                \"type\": \"execute\",\n                \"payment_method\": \"NEOSURF\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"NEOSURF\",\n                \"processing_time\": 1748855723,\n                \"extra\": {\n                    \"amount\": 1,\n                    \"masked_pan\": \"NEOSURF\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAYMENT_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1748855723\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1748855723\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1748855724\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"30f7ce6e-3b7e-46a2-9b50-484fc55be689\",\n    \"is_recurring_token\": false,\n    \"reference_generated\": \"PS784\",\n    \"issued\": \"2025-06-02\",\n    \"due\": 1748855723,\n    \"refund_upto\": 1749024924,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"0\",\n    \"trustScore\": \"0\",\n    \"paidOn\": 0,\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 1,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"103.59.75.242, 162.158.23.126, 130.176.183.12\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/683d6bab12b471481d4f66cf/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"120ba5e0-b3d5-4480-a21c-03eadbd4f27d"}],"id":"81b36078-69fc-4f59-938c-162480cd2a86","_postman_id":"81b36078-69fc-4f59-938c-162480cd2a86","description":""},{"name":"Payout API","item":[{"name":"Payout API","id":"a2e61826-e638-45a1-9d52-82cfffee405d","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer {{your_API_Key}}"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"akshayadeepsinghal@gmail.com\",\n        \"country\": \"AU\",\n        \"phone\": \"+11111111\",\n        \"full_name\": \"PAYOUT USER\",\n        \"stateCode\": \"test\"\n    },\n    \"purpose\": \"test payout\",\n    \"currency\": \"AUD\",\n    \"payoutMethod\": \"PAYOUT-NEOSURF\",\n    \"amount\": 1,\n    \"success_callback\": \"https://success.com\",\n    \"failure_callback\": \"https://failure.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<h3 id=\"create-payout\">Create Payout</h3>\n<p>This endpoint allows you to initiate a payout transaction.</p>\n<h4 id=\"request-body\">Request Body</h4>\n<ul>\n<li><p><code>client</code> (object, required): Details of the client initiating the payout.</p>\n<ul>\n<li><p><code>email</code> (string): The email of the client.</p>\n</li>\n<li><p><code>country</code> (string): The country of the client.</p>\n</li>\n<li><p><code>phone</code> (string): The phone number of the client.</p>\n</li>\n<li><p><code>full_name</code> (string): The full name of the client.</p>\n</li>\n<li><p><code>stateCode</code> (string): The state code of the client.</p>\n</li>\n</ul>\n</li>\n<li><p><code>purpose</code> (string, required): The purpose of the payout.</p>\n</li>\n<li><p><code>currency</code> (string, required): The currency of the payout.</p>\n</li>\n<li><p><code>payoutMethod</code> (string, required): The method of payout.</p>\n</li>\n<li><p><code>amount</code> (number, required): The amount of the payout.</p>\n</li>\n<li><p><code>success_callback</code> (string, required): The URL to which the success callback will be sent.</p>\n</li>\n<li><p><code>failure_callback</code> (string, required): The URL to which the failure callback will be sent.</p>\n</li>\n</ul>\n<h4 id=\"response-body\">Response Body</h4>\n<p>The response will contain the details of the initiated payout transaction.</p>\n","urlObject":{"protocol":"https","path":["api","v1","payout",""],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"0c96792c-9c7a-4b84-a1be-97e5a162b85b","name":"New Request","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer {{your_API_Key}}"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"akshayadeepsinghal@gmail.com\",\n        \"country\": \"AU\",\n        \"phone\": \"+11111111\",\n        \"full_name\": \"PAYOUT USER\",\n        \"stateCode\": \"test\"\n    },\n    \"purpose\": \"test payout\",\n    \"currency\": \"AUD\",\n    \"payoutMethod\": \"PAYOUT-NEOSURF\",\n    \"amount\": 1,\n    \"success_callback\": \"https://success.com\",\n    \"failure_callback\": \"https://failure.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"payoutId\": \"683d6fee57aff00ab5faf3c6\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"akshayadeepsinghal@gmail.com\",\n        \"phone\": \"+11111111\",\n        \"full_name\": \"PAYOUT USER\",\n        \"country\": \"AU\",\n        \"stateCode\": \"test\"\n    },\n    \"updated_on\": 1748856814,\n    \"payoutMethod\": \"PAYOUT-NEOSURF\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 1,\n    \"errorMsg\": \"\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1748856814,\n    \"merchantRef\": \"683d6fee57aff00ab5faf3c6\",\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1748856814\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1748856816\n        }\n    ],\n    \"currency\": \"AUD\",\n    \"paymentOn\": 1748856816,\n    \"taxAmount\": 0,\n    \"taxPercent\": 0,\n    \"redirectType\": \"POST\",\n    \"success_callback\": \"https://success.com\",\n    \"failure_callback\": \"https://failure.com\"\n}"}],"_postman_id":"a2e61826-e638-45a1-9d52-82cfffee405d"}],"id":"879fab7b-7b05-48c9-8cc9-83a6c2f4a9ab","_postman_id":"879fab7b-7b05-48c9-8cc9-83a6c2f4a9ab","description":""}],"id":"ee3d7a36-88f2-43d9-b5f2-48e854c83239","description":"<p>Neosurf is now available as a payment method on Paysecure, giving your customers a fast, secure, and convenient prepaid payment option. This guide explains what a Neosurf voucher is, how to acquire one across different regions, how to process a payment with it, and other key details of the integration.</p>\n","_postman_id":"ee3d7a36-88f2-43d9-b5f2-48e854c83239"},{"name":"🇦🇺 PayID","item":[{"name":"Concepts","item":[],"id":"a513eff8-0040-4872-9f1f-5e9c53351119","description":"<h3 id=\"what-is-a-payid\">What is a PayID?</h3>\n<p>A <strong>PayID</strong> is a user-friendly alias (such as an email, mobile number, or ABN) linked to a bank account. Payments made to a PayID are resolved in real-time via the <strong>NPP (New Payments Platform)</strong> to the associated account.</p>\n<h3 id=\"use-cases\">Use Cases</h3>\n<ul>\n<li><p><strong>PayIn:</strong> Accept customer payments instantly with lower failure rates and no chargebacks.</p>\n</li>\n<li><p><strong>PayOut:</strong> Send real-time refunds, payroll, commissions, or supplier settlements via PayID.</p>\n</li>\n</ul>\n<hr />\n<h2 id=\"payin-customer-journey\">PayIn Customer Journey</h2>\n<ol>\n<li><p><strong>Customer Initiates Payment</strong><br /> On the merchant’s checkout page or app, the user selects PayID as the payment method and proceeds.</p>\n</li>\n<li><p><strong>API Call to Paysecure</strong><br /> The merchant initiates a <code>POST /purchases</code> request with transaction details (amount, currency). Paysecure responds with a <code>purchaseId</code>, <code>checkoutUrl</code>, and a <strong>merchant PayID</strong> to which the customer should transfer funds.</p>\n</li>\n<li><p><strong>Customer Authorizes via Banking App</strong><br /> The customer logs into their internet or mobile banking, enters the <strong>PayID</strong> (received from Paysecure), the <strong>exact amount</strong>, and confirms the transfer.</p>\n</li>\n<li><p><strong>Real-time Bank Transfer</strong><br /> The customer’s bank processes the payment via NPP. Funds are instantly credited to Paysecure’s account.</p>\n</li>\n<li><p><strong>Webhook Notification</strong><br /> Once payment is received, Paysecure sends a webhook (<code>purchase.paid</code>) to the merchant. Merchant updates order status to “paid.”</p>\n</li>\n<li><p><strong>Error Handling</strong><br /> If the payment fails (due to invalid PayID, rejection by bank, or insufficient funds), Paysecure returns a <code>purchase.failed</code> status.</p>\n</li>\n</ol>\n<hr />\n<h2 id=\"payout-customer-journey\">PayOut Customer Journey</h2>\n<ol>\n<li><p><strong>User Requests Withdrawal</strong><br /> A user initiates a payout (e.g., a refund, reward, or withdrawal) from the merchant interface.</p>\n</li>\n<li><p><strong>Merchant Approval</strong><br /> The merchant verifies and approves the request.</p>\n</li>\n<li><p><strong>API Call to Paysecure</strong><br /> Merchant sends a <code>POST /payouts</code> request with:</p>\n<ul>\n<li><p>Recipient's PayID (e.g., email or phone)</p>\n</li>\n<li><p>Amount</p>\n</li>\n<li><p>Currency</p>\n</li>\n<li><p>Optional reference or metadata</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Bank Transfer via NPP</strong><br /> Paysecure initiates the payout. Funds are credited to the recipient’s bank account in real-time via NPP.</p>\n</li>\n<li><p><strong>Webhook Notification</strong><br /> Once successful, Paysecure notifies the merchant (<code>payout.success</code>) so they can update their system.</p>\n</li>\n<li><p><strong>Failure Scenarios</strong><br /> If the PayID is invalid or unregistered, the payout fails. Paysecure responds with an error, and the merchant can retry after fixing the issue.</p>\n</li>\n</ol>\n<hr />\n","_postman_id":"a513eff8-0040-4872-9f1f-5e9c53351119"},{"name":"Payin API","item":[{"name":"Purchases","id":"13518cad-f986-4965-a8d7-40d727f1abcc","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"seo2009@test.com\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"city\": \"Sydney\",\n        \"full_name\": \"Test test\",\n        \"zip_code\": \"W1S 3BE\",\n        \"country\": \"AU\",\n        \"stateCode\": \"QLD\",\n        \"phone\": \"+447755564318\"\n    },\n    \"purchase\": {\n        \"currency\": \"AUD\",\n        \"products\": [\n            {\n                \"name\": \"test\",\n                \"price\": 100\n            }\n        ]\n    },\n    \"paymentMethod\": \"PAYID\",\n    \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\n    \"success_redirect\": \"<https://your.redirect.url/getResponse.jsp?success=true>\",\n    \"pending_redirect\": \"<https://your.redirect.url/getResponse.jsp?success=true>\",\n    \"failure_redirect\": \"<https://your.redirect.url/getResponse.jsp?success=false>\",\n    \"success_callback\": \"<https://your.success.callback.url>\",\n    \"failure_callback\": \"<https://your>..failure.callback.url\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<h3 id=\"purchase-api-endpoint\">Purchase API Endpoint</h3>\n<p>This endpoint allows you to create a new purchase transaction. It processes the purchase details, including client information, product details, and payment method, and returns the result of the transaction.</p>\n<h4 id=\"request-format\">Request Format</h4>\n<ul>\n<li><p><strong>Method</strong>: POST</p>\n</li>\n<li><p><strong>URL</strong>: <code>https://api.paysecure.net/api/v1/purchases</code></p>\n</li>\n<li><p><strong>Request Body</strong>: The request should be in JSON format and must include the following structure:</p>\n</li>\n</ul>\n<h4 id=\"response-structure\">Response Structure</h4>\n<p>The response will contain the result of the purchase transaction. The structure of the response may include:</p>\n<ul>\n<li><p><strong>status</strong>: Indicates the success or failure of the transaction.</p>\n</li>\n<li><p><strong>message</strong>: A descriptive message regarding the transaction status.</p>\n</li>\n<li><p><strong>transaction_id</strong>: Unique identifier for the transaction (if successful).</p>\n</li>\n<li><p><strong>redirect_url</strong>: URL to redirect the user based on the transaction result.</p>\n</li>\n</ul>\n<p>Make sure to handle the response appropriately based on the status returned.</p>\n","urlObject":{"protocol":"https","path":["api","v1","purchases"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"e5317fce-70d4-4c71-9bd3-5e235299c91d","name":"Success","originalRequest":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"seo2009@test.com\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"city\": \"Sydney\",\n        \"full_name\": \"Test test\",\n        \"zip_code\": \"W1S 3BE\",\n        \"country\": \"AU\",\n        \"stateCode\": \"QLD\",\n        \"phone\": \"+447755564318\"\n    },\n    \"purchase\": {\n        \"currency\": \"AUD\",\n        \"products\": [\n            {\n                \"name\": \"test\",\n                \"price\": 100\n            }\n        ]\n    },\n    \"paymentMethod\": \"PAYID\",\n    \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\n    \"success_redirect\": \"<https://your.redirect.url/getResponse.jsp?success=true>\",\n    \"pending_redirect\": \"<https://your.redirect.url/getResponse.jsp?success=true>\",\n    \"failure_redirect\": \"<https://your.redirect.url/getResponse.jsp?success=false>\",\n    \"success_callback\": \"<https://your.success.callback.url>\",\n    \"failure_callback\": \"<https://your>..failure.callback.url\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"68441c2a7559cf659fd7e835\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"arun44@gmail.com\",\n        \"phone\": \"+237679544810\",\n        \"full_name\": \"Olive Tsafack\",\n        \"street_address\": \"test test\",\n        \"country\": \"AU\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1749294123,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"PAYID\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"POST\",\n    \"force_recurring\": false,\n    \"created_on\": 1749294123,\n    \"merchantRef\": \"68441c2a7559cf659fd7e835\",\n    \"merchantName\": \"Merchant002\",\n    \"purchase\": {\n        \"currency\": \"AUD\",\n        \"products\": [\n            {\n                \"name\": \"test\",\n                \"quantity\": 1,\n                \"price\": 100,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 100,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"taxAmount\": 0,\n        \"taxPercent\": 0,\n        \"request_client_details\": [],\n        \"timezone\": \"MIT\",\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"44\",\n        \"brand_name\": \"44\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1749294123\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS19963\",\n    \"issued\": \"2025-06-07\",\n    \"due\": 1749294123,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"paidOn\": 0,\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"<https://your.redirect.url/getResponse.jsp?success=true>\",\n    \"failure_redirect\": \"<https://your.redirect.url/getResponse.jsp?success=false>\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"<https://webhook.site/ec813a7a-4dd1-4aa3-99f3-f01637ab224c>\",\n    \"failure_callback\": \"<https://webhook.site/ec813a7a-4dd1-4aa3-99f3-f01637ab224c>\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"183.83.54.51\",\n    \"checkout_url\": \"<https://staging.paysecure.net/payments/68441c2a7559cf659fd7e835/>\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"13518cad-f986-4965-a8d7-40d727f1abcc"}],"id":"6013152e-f36f-40fd-bb39-1b1c9756cc5f","_postman_id":"6013152e-f36f-40fd-bb39-1b1c9756cc5f","description":""},{"name":"Payout API","item":[{"name":"New Request","id":"2b3e619e-a276-4473-a627-ee7be41b939a","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"country\": \"CA\",\n        \"phone\": \"7665230591\",\n        \"full_name\": \"Test Person-uk\"\n    },\n    \"purpose\": \"testing payout\",\n    \"currency\": \"AUD\",\n    \"payoutMethod\": \"PAYOUT-PAYID\",\n    \"amount\": 50,\n    \"extraParam\": {\n        \"payId\": \"KeU6r2egQmQZeqUfkPYC7HSU1EDrn2GYyU\",\n        \"bankName\": \"test bank name\",\n        \"accountName\": \"arun\"\n    },\n    \"success_callback\": \"<https://success.com>\",\n    \"failure_callback\": \"<https://failure.com>\"\n}","options":{"raw":{"language":"json"}}},"url":"<https://staging.paysecure.net/api/v1/payout/>","description":"<h2 id=\"payout-request-api\">Payout Request API</h2>\n<p>This endpoint allows clients to initiate a payout transaction. It requires specific details about the client and the payout method to process the request successfully.</p>\n<h3 id=\"request-format\">Request Format</h3>\n<p>The request must be sent as a JSON object in the raw body. The following parameters are expected:</p>\n<ul>\n<li><p><strong>client</strong>: An object containing client information.</p>\n<ul>\n<li><p><strong>email</strong> (string): The email address of the client.</p>\n</li>\n<li><p><strong>country</strong> (string): The country of the client.</p>\n</li>\n<li><p><strong>phone</strong> (string): The phone number of the client.</p>\n</li>\n<li><p><strong>full_name</strong> (string): The full name of the client.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>purpose</strong> (string): A brief description of the reason for the payout (e.g., \"testing payout\").</p>\n</li>\n<li><p><strong>currency</strong> (string): The currency in which the payout is to be made (e.g., \"AUD\").</p>\n</li>\n<li><p><strong>payoutMethod</strong> (string): The method used for the payout (e.g., \"PAYOUT-PAYID\").</p>\n</li>\n<li><p><strong>amount</strong> (number): The amount to be paid out.</p>\n</li>\n<li><p><strong>extraParam</strong>: An object containing additional payout parameters.</p>\n<ul>\n<li><p><strong>payId</strong> (string): The unique identifier for the payout.</p>\n</li>\n<li><p><strong>bankName</strong> (string): The name of the bank associated with the payout.</p>\n</li>\n<li><p><strong>accountName</strong> (string): The name on the account receiving the payout.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>success_callback</strong> (string): A URL that will be called upon successful completion of the payout.</p>\n</li>\n<li><p><strong>failure_callback</strong> (string): A URL that will be called if the payout fails.</p>\n</li>\n</ul>\n<h3 id=\"response-structure\">Response Structure</h3>\n<p>The response from this endpoint will typically include details about the status of the payout request, which may include:</p>\n<ul>\n<li><p>A success message or error details.</p>\n</li>\n<li><p>A transaction ID for tracking purposes.</p>\n</li>\n<li><p>Any additional information relevant to the payout process.</p>\n</li>\n</ul>\n<p>Ensure to handle both success and failure callbacks appropriately based on the response received from this endpoint.</p>\n","urlObject":{"protocol":"<https","path":["api","v1","payout",">"],"host":["staging","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"2ad6dfcd-1019-4651-91f6-920b2a32a474","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"country\": \"CA\",\n        \"phone\": \"7665230591\",\n        \"full_name\": \"Test Person-uk\"\n    },\n    \"purpose\": \"testing payout\",\n    \"currency\": \"AUD\",\n    \"payoutMethod\": \"PAYOUT-PAYID\",\n    \"amount\": 50,\n    \"extraParam\": {\n        \"payId\": \"KeU6r2egQmQZeqUfkPYC7HSU1EDrn2GYyU\",\n        \"bankName\": \"test bank name\",\n        \"accountName\": \"arun\"\n    },\n    \"success_callback\": \"<https://success.com>\",\n    \"failure_callback\": \"<https://failure.com>\"\n}","options":{"raw":{"language":"json"}}},"url":"<https://staging.paysecure.net/api/v1/payout/>"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"payoutId\": \"683d6fee57aff00ab5faf3c6\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"akshayadeepsinghal@gmail.com\",\n        \"phone\": \"+11111111\",\n        \"full_name\": \"PAYOUT USER\",\n        \"country\": \"AU\",\n        \"stateCode\": \"test\"\n    },\n    \"updated_on\": 1748856814,\n    \"payoutMethod\": \"PAYOUT-PAYID\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 1,\n    \"errorMsg\": \"\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1748856814,\n    \"merchantRef\": \"683d6fee57aff00ab5faf3c6\",\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1748856814\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1748856816\n        }\n    ],\n    \"currency\": \"AUD\",\n    \"paymentOn\": 1748856816,\n    \"taxAmount\": 0,\n    \"taxPercent\": 0,\n    \"redirectType\": \"POST\",\n    \"success_callback\": \"<https://success.com>\",\n    \"failure_callback\": \"<https://failure.com>\"\n}"},{"id":"1815fc63-0dd8-44bc-bd5a-f321cebe9f74","name":"Error","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"ashishm.21190@gmail.com\",\n        \"country\": \"CA\",\n        \"phone\": \"7665230591\",\n        \"full_name\": \"Test Person-uk\"\n    },\n    \"purpose\": \"testing payout\",\n    \"currency\": \"AUD\",\n    \"payoutMethod\": \"PAYOUT-PAYID\",\n    \"amount\": 50,\n    \"extraParam\": {\n        \"payId\": \"KeU6r2egQmQZeqUfkPYC7HSU1EDrn2GYyU\",\n        \"bankName\": \"test bank name\",\n        \"accountName\": \"arun\"\n    },\n    \"success_callback\": \"<https://success.com>\",\n    \"failure_callback\": \"<https://failure.com>\"\n}","options":{"raw":{"language":"json"}}},"url":"<https://staging.paysecure.net/api/v1/payout/>"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"payoutId\": \"683d6fee57aff00ab5faf3c6\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"akshayadeepsinghal@gmail.com\",\n        \"phone\": \"+11111111\",\n        \"full_name\": \"PAYOUT USER\",\n        \"country\": \"AU\",\n        \"stateCode\": \"test\"\n    },\n    \"updated_on\": 1748856814,\n    \"payoutMethod\": \"PAYOUT-PAYID\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 1,\n    \"errorMsg\": \"\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1748856814,\n    \"merchantRef\": \"683d6fee57aff00ab5faf3c6\",\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1748856814\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1748856816\n        }\n    ],\n    \"currency\": \"AUD\",\n    \"paymentOn\": 1748856816,\n    \"taxAmount\": 0,\n    \"taxPercent\": 0,\n    \"redirectType\": \"POST\",\n    \"success_callback\": \"<https://success.com>\",\n    \"failure_callback\": \"<https://failure.com>\"\n}"}],"_postman_id":"2b3e619e-a276-4473-a627-ee7be41b939a"}],"id":"689b1fef-9768-405b-899d-d6fd01ea7f1b","_postman_id":"689b1fef-9768-405b-899d-d6fd01ea7f1b","description":""}],"id":"1bfa27ea-6d5d-4ea3-96a0-fdc6218087bc","description":"<p>PayID is a real-time payment method in Australia built on the New Payments Platform (NPP). It allows customers to make or receive payments using simple identifiers like their mobile number or email address, eliminating the need to remember BSB and account numbers.</p>\n<p>Paysecure enables merchants to both <strong>accept payments (PayIn)</strong> and <strong>send payouts (PayOut)</strong> using PayID. Transactions are settled instantly, and users benefit from seamless user experience with low friction.</p>\n","_postman_id":"1bfa27ea-6d5d-4ea3-96a0-fdc6218087bc"},{"name":"🌐 CryptoBridge","item":[{"name":"Concepts","item":[],"id":"7996156e-73f2-4897-b2c9-3096d5f2f5dd","description":"<h2 id=\"💸-customer-payin-journey\">💸 Customer PayIn Journey</h2>\n<ol>\n<li><p><strong>Checkout</strong><br /> Customer chooses <strong>CryptoBridge</strong> as the payment method on merchant's checkout page.</p>\n</li>\n<li><p><strong>Payment Pop-up Opens</strong><br /> A secure pop-up opens where the customer:</p>\n<ul>\n<li><p>Selects their preferred exchange or DeFi wallet</p>\n</li>\n<li><p>Links the account</p>\n</li>\n<li><p>Selects the eligible token and blockchain network</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Fee Preview</strong><br /> Customer reviews the full fee structure:</p>\n<ul>\n<li><p><strong>Gas Fee</strong>: Network charge</p>\n</li>\n<li><p><strong>Institution Fee</strong>: Fee from exchange or wallet provider</p>\n</li>\n<li><p><strong>Client Fee</strong>: Optional merchant fee (can be configured via <code>clientFee</code> param)</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Authentication &amp; Confirmation</strong><br /> The customer authenticates (if required by the linked wallet or exchange) and confirms the transfer.</p>\n</li>\n<li><p><strong>Payment &amp; Notification</strong><br /> On successful transfer:</p>\n<ul>\n<li><p>Crypto is sent to the merchant's <strong>receiver address</strong></p>\n</li>\n<li><p>Webhook is triggered to notify merchant of successful payment</p>\n</li>\n<li><p>Customer is redirected to success or failure URL based on transaction outcome</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Smart-Finding (Auto Swap)</strong><br /> If customer lacks sufficient balance in selected token, the system suggests a real-time token swap—reducing drop-offs and boosting conversions.</p>\n</li>\n</ol>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"f8dba0fe-d3c4-4f8c-b1a8-9d221100f135","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"68c870b0-f549-4841-8486-5021af6447fb","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"7996156e-73f2-4897-b2c9-3096d5f2f5dd"},{"name":"Payin API","item":[{"name":"Purchases","id":"e5aac5c2-09fc-4459-a55b-3ae1fec3bc2b","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"gaurav@gmail.com\",\n        \"full_name\": \"Gaurav Test\",\n        \"country\": \"US\",\n        \"city\": \"123\",\n        \"stateCode\": \"NYC\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\",\n        \"phone\": \"9999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"product name\",\n                \"price\": 5.86\n            }\n        ]\n    },\n    \"paymentMethod\": \"CRYPTO-BRIDGE\",\n    \"brand_id\": \"cec67fe3-a01d-4d0d-b100-9fafb200fe15\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"extraParam\": {\n        \"clientFee\": 0.1, //optional\n        \"toAddress\": [\n            {\n                \"symbol\": \"ETH\",\n                \"networkName\": \"ETHEREUM\",\n                \"address\": \"0xc4db7bBB898B98D15be823454d1dff6C308BC9A4\"\n            },\n            {\n                \"symbol\": \"USDC\",\n                \"networkName\": \"POLYGON\",\n                \"address\": \"0xc4cs7bBB898B89D15be823445d1dff6C380BC9D3\"\n            }\n        ]\n    }\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<h3 id=\"💡-key-fields-explained\">💡 Key Fields Explained</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Field</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><code>paymentMethod</code></td>\n<td>Always use <code>\"CRYPTO-BRIDGE\"</code> to trigger this payment method</td>\n</tr>\n<tr>\n<td><code>currency</code></td>\n<td>The fiat currency for the order (e.g., USD, EUR). You will be paid in crypto but this defines how much the customer will pay</td>\n</tr>\n<tr>\n<td><code>products</code></td>\n<td>One or more items being sold, with name and price</td>\n</tr>\n<tr>\n<td><code>extraParam.clientFee</code></td>\n<td>Optional: A custom fee you (the merchant) want to charge — shown to the user at checkout</td>\n</tr>\n<tr>\n<td><code>extraParam.toAddress</code></td>\n<td>Optional.  <br />Merchant can provide the list of wallet addresses, where they want to collect the deposit from the user. Can pass multiple addresses.</td>\n</tr>\n<tr>\n<td><code>extraParam.toAddress.symbol</code></td>\n<td>The symbol of the digital asset.  <br />Example: ETH, USDC etc.  <br />  <br />Possible Values:  <br />AAVE, ADA, APE, APT, ARB, AVAX, BLAST, BLUR, BNB, BTC, BUSD, CAKE, CASH, CRO, DAI, DEXE, DEVNETSOL, DOGE, ENA, ETH, EURC, FARTCOIN, FDUSD, FORM, FTM, GRT, HYPE, IMX, INJ, LDO, LEO, LINK, LTC, MANA, MATIC, MKR, MNT, MON, OP, PAXG, PENGU, POL, PYUSD, QNT, RLUSD, RNDR, S, SAND, SEPOLIAETH, SHIB, SNX, SOL, SUI, TON, TRUMP, TRX, TUSD, UNI, USD1, USD₮0, USDC, USDD, USDG, USDH, USDP, USDT, VIRTUAL, WAVAX, WBNB, WBTC, WETH, WHYPE, WIF, WMATIC, WMON, XLM, XRP</td>\n</tr>\n<tr>\n<td><code>extraParam.toAddress.networkName</code></td>\n<td>The network of the token.  <br />Example: ETHEREUM, POLYGON etc.  <br />  <br />Possible values:  <br />ETHEREUM, POLYGON, BSC, ARBITRUM, OPTIMISM, BASE, AVALANCHEC, BLAST, HYPEREVM, SOLANA, BITCOIN, TRON, LITECOIN, DOGECOIN, RIPPLE, APTOS, CARDANO, STELLAR, SUI, TON, SONIC, INJECTIVE, AVALANCHEX</td>\n</tr>\n<tr>\n<td><code>extraParam.toAddress.address</code></td>\n<td>The address to send the asset to.</td>\n</tr>\n<tr>\n<td><code>success_redirect</code> / <code>success_redirect</code> / <code>failure_redirect</code></td>\n<td>Where the user should land after completing or canceling the payment or if the transaction is in pending state.</td>\n</tr>\n<tr>\n<td><code>success_callback</code> / <code>failure_callback</code></td>\n<td>Your backend URL to receive transaction status via webhook.</td>\n</tr>\n<tr>\n<td><code>client</code></td>\n<td>Customer billing info</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9c83ec79-0519-44a1-ae6a-172ce50ba8b3","id":"9c83ec79-0519-44a1-ae6a-172ce50ba8b3","name":"Payin API","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","purchases"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"464d69c5-e208-4517-a598-172e02ff9d27","name":"Purchases","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"gaurav@gmail.com\",\n        \"full_name\": \"Gaurav Test\",\n        \"country\": \"US\",\n        \"city\": \"123\",\n        \"stateCode\": \"NYC\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\",\n        \"phone\": \"9999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"product name\",\n                \"price\": 5.86\n            }\n        ]\n    },\n    \"paymentMethod\": \"CRYPTO-BRIDGE\",\n    \"brand_id\": \"cec67fe3-a01d-4d0d-b100-9fafb200fe15\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"extraParam\": {\n        \"clientFee\": 0.1, //optional\n        \"toAddress\": [\n            {\n                \"symbol\": \"ETH\",\n                \"networkName\": \"ETHEREUM\",\n                \"address\": \"0xc4db7bBB898B98D15be823454d1dff6C308BC9A4\"\n            },\n            {\n                \"symbol\": \"USDC\",\n                \"networkName\": \"POLYGON\",\n                \"address\": \"0xc4cs7bBB898B89D15be823445d1dff6C380BC9D3\"\n            }\n        ]\n    }\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"6874ce9402f0f25ed8fc66a7\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"gaurav@gmail.com\",\n        \"phone\": \"9999999999\",\n        \"full_name\": \"Test test\",\n        \"date_of_birth\": \"1800-01-01\",\n        \"street_address\": \"test test\",\n        \"country\": \"US\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"tax_number\": \"39933551809\",\n        \"stateCode\": \"NYC\"\n    },\n    \"updated_on\": 1752485524,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"CRYPTO-BRIDGE\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"GET\",\n    \"force_recurring\": false,\n    \"created_on\": 1752485524,\n    \"extraParam\": {\n        \"clientFee\": 0.1,\n        \"toAddress\": [\n            {\n                \"symbol\": \"ETH\",\n                \"network\": \"ETHEREUM\",\n                \"address\": \"0xc4db7bBB898B98D15be823454d1dff6C308BC9A4\"\n            },\n            {\n                \"symbol\": \"USDC\",\n                \"network\": \"POLYGON\",\n                \"address\": \"0xc4cs7bBB898B89D15be823445d1dff6C380BC9D3\"\n            }\n        ]\n    },\n    \"merchantRef\": \"6874ce9402f0f25ed8fc66a7\",\n    \"merchantName\": \"test\",\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"product name\",\n                \"quantity\": 1,\n                \"price\": 5.86,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 5.86,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"taxAmount\": 0,\n        \"taxPercent\": 0,\n        \"request_client_details\": [],\n        \"timezone\": \"Asia/Hong_Kong\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 5.86,\n        \"currency\": \"USD\",\n        \"net_amount\": 5.86,\n        \"fee_amount\": 0,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1752485524,\n        \"remote_paid_on\": 1752485524\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"iUnicharge\",\n        \"brand_name\": \"iUnicharge\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"amount\": 5.86,\n            \"masked_pan\": \"CRYPTO-BRIDGE\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"103.59.75.157, 172.69.203.75, 18.68.12.102\",\n                \"type\": \"execute\",\n                \"payment_method\": \"CRYPTO-BRIDGE\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"CRYPTO-BRIDGE\",\n                \"processing_time\": 1752485524,\n                \"extra\": {\n                    \"amount\": 5.86,\n                    \"masked_pan\": \"CRYPTO-BRIDGE\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAYMENT_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1752485524\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1752485524\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1752485524\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"cec67fe3-a01d-4d0d-b100-9fafb200fe15\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS1682\",\n    \"issued\": \"2025-07-14\",\n    \"due\": 1752485524,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"100\",\n    \"trustScore\": \"2\",\n    \"paidOn\": 0,\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"103.59.75.157, 172.69.203.75, 18.68.12.102\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/6874ce9402f0f25ed8fc66a7/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"e5aac5c2-09fc-4459-a55b-3ae1fec3bc2b"}],"id":"9c83ec79-0519-44a1-ae6a-172ce50ba8b3","description":"<h2 id=\"🔗-how-to-accept-payments-with-cryptobridge-payin-api\">🔗 How to Accept Payments with CryptoBridge (PayIn API)</h2>\n<p>To let your customers pay in crypto (while you list your prices in fiat), you need to initiate a <strong>Create Purchase API</strong> call from your backend when a customer selects CryptoBridge at checkout. This API tells PaySecure the details of the transaction, customer, and where to redirect the user after payment.</p>\n<h3 id=\"🔥-what-happens-when-you-call-this-api\">🔥 What Happens When You Call This API</h3>\n<ul>\n<li><p>You send order details (amount, products, etc.) in <strong>USD or any fiat currency</strong></p>\n</li>\n<li><p>You specify that the <strong>payment method</strong> is <code>CRYPTO-BRIDGE</code></p>\n</li>\n<li><p>Optionally, you can <strong>add your own processing fee</strong> using <code>clientFee</code> — this will be shown to the customer before they confirm payment</p>\n</li>\n<li><p>PaySecure returns a secure <code>checkout_url</code> which you can use to <strong>redirect the customer to a crypto payment pop-up</strong></p>\n</li>\n<li><p>The customer pays using their crypto wallet or exchange, and once it's confirmed:</p>\n<ul>\n<li><p>You get an <strong>instant webhook notification</strong></p>\n</li>\n<li><p>The user is redirected back to your success or failure page</p>\n</li>\n</ul>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"7b9cd9a1-c219-482a-92cf-abdb73f6ff59","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"546a9dfe-fb6e-4cea-9680-a2b9afd0e21c","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"9c83ec79-0519-44a1-ae6a-172ce50ba8b3"}],"id":"d28835a4-cdc4-4f62-9abd-fe1394e57c61","description":"<h2 id=\"📖-overview\">📖 Overview</h2>\n<p><strong>CryptoBridge</strong> is a fiat-denominated crypto payment method that allows merchants to list goods and services in fiat while accepting payment in crypto. The platform automatically handles real-time conversion, token selection, and network routing—abstracting all crypto complexities from the merchant.</p>\n<p>Customers can link their exchange or DeFi wallets (from over 400+ supported providers including Binance, Coinbase, Metamask, etc.) and make seamless crypto transfers. Fees such as gas, institutional charges, and optional merchant processing fees are transparently displayed and deducted before confirmation.</p>\n<hr />\n<h3 id=\"✅-key-benefits\">✅ Key Benefits</h3>\n<ul>\n<li><p><strong>Fiat-based pricing</strong> with crypto-native checkout</p>\n</li>\n<li><p><strong>No crypto inventory management</strong> needed</p>\n</li>\n<li><p><strong>Real-time conversion</strong> of fiat to eligible tokens</p>\n</li>\n<li><p><strong>Access to 400+ exchanges and DeFi wallets</strong></p>\n</li>\n<li><p><strong>Smart token swapping</strong> feature for low-balance users – improves approval rates by up to 40%</p>\n</li>\n<li><p><strong>Full transparency</strong> in fee breakdown: gas, institutional, merchant/client fee</p>\n</li>\n<li><p><strong>Webhook-based confirmation</strong> for real-time order processing</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"a3955657-2d5f-4eca-9a6b-25ed19dbbf55","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"d1635f0b-9d52-487e-aa0b-588ed68ab5b8","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"d28835a4-cdc4-4f62-9abd-fe1394e57c61"},{"name":"Virtual Accounts (South Korea)","item":[{"name":"Concepts","item":[],"id":"c269a0fc-b08c-40e9-8fc4-6aa4ab00ed5c","description":"<h3 id=\"payin\"><strong>Payin</strong></h3>\n<p>The PayIn flow proceeds as follows:</p>\n<ol>\n<li><p><strong>Customer Initiates:</strong> The merchant’s site or app presents Virtual Account as a payment option to its customers. The customer selects it and clicks on Pay.</p>\n</li>\n<li><p><strong>API Request:</strong> The merchant calls Paysecure’s PayIn API (e.g. POST <code>/purchases</code> ) with the transaction amount and the currency. Paysecure returns a purchase ID and provide a URL for the customer to continue.</p>\n</li>\n<li><p><strong>Virtual Account Displayed</strong>: The customer is shown their unique bank account details in which they need to deposit the money.</p>\n</li>\n<li><p><strong>Customer Authorisation</strong>: The customer logs into their online/mobile banking and adds the bank account as a beneficiary and amount provided by Paysecure. They confirm the transaction in their banking app.</p>\n</li>\n<li><p><strong>Real-time Transfer</strong>: The customer’s bank sends the funds to the virtual account generated for the user.</p>\n</li>\n<li><p><strong>Notification</strong>: Once payment is received, Paysecure triggers a webhook to the merchant with details (amount, currency, payer info, timestamp, etc.). The purchase status in Paysecure can also be queried via the get status API.</p>\n</li>\n<li><p><strong>Merchant Fulfillment:</strong> Upon webhook confirmation, the merchant fulfills the order or credits the customer’s wallet.</p>\n</li>\n<li><p>If any step fails (e.g. the bank account is invalid, the customer’s bank declines the transfer, or there are insufficient funds), Paysecure returns an error status. The merchant sees the payment failed and can prompt the customer to retry or choose another method.</p>\n</li>\n</ol>\n","_postman_id":"c269a0fc-b08c-40e9-8fc4-6aa4ab00ed5c"},{"name":"Payin","item":[{"name":"Create Purchase","id":"7b497795-75ac-4a96-8e51-8bda611ff822","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n  \"client\": {\n    \"email\": \"seo2009@test.com\",\n    \"street_address\": \"10 New Burlington Street Apt. 214\",\n    \"city\": \"Sydney\",\n    \"full_name\": \"Test test\",\n    \"zip_code\": \"W1S 3BE\",\n    \"country\": \"KR\",\n    \"stateCode\": \"QLD\",\n    \"phone\": \"+447755564318\",\n    \"date_of_birth\": \"1970-07-10\"\n  },\n  \"purchase\": {\n    \"currency\": \"KRW\",\n    \"products\": [\n      {\n        \"name\": \"test\",\n        \"price\": 100\n      }\n    ]\n  },\n  \"paymentMethod\": \"VIRTUAL-ACCOUNT\",\n  \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\n  \"success_redirect\": \"https://your.success.redirect.url\",\n  \"pending_redirect\": \"https://your.pending.redirect.url\",\n  \"failure_redirect\": \"https://your.failure.redirect.url\",\n  \"success_callback\": \"https://your.success.callback.url\",\n  \"failure_callback\": \"https://your.failure.callback.url\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<h3 id=\"payin-api\"><strong>Payin API</strong></h3>\n<img src=\"https://content.pstmn.io/e448df41-3cb5-4b2a-9dc5-f961d9048bff/dW5uYW1lZC0yLnBuZw==\" alt height=\"301\" width=\"800\" />\n\n<p><strong>Integration Steps:</strong> To integrate Virtual Account payments with Paysecure, follow these steps:</p>\n<ol>\n<li><p><strong>Enable Virtual Account in Paysecure</strong>: Sign up with Paysecure and ensure the Virtual Account payment method is enabled for your merchant account. Get your API keys for authentication (test and live).</p>\n</li>\n<li><p><strong>Configure Webhooks</strong>: Set up Paysecure webhooks (e.g. transaction.paid, transaction.failed) so your system is notified of payment status changes.</p>\n</li>\n<li><p><strong>Implement PayIn</strong> (Customer Payments): In your checkout flow, allow the customer to choose Virtual Account and then call Paysecure’s PayIn API (e.g. POST /purchases ) with parameters such as amount, currency and paymentMethod=VIRTUAL-ACCOUNT. To generate a Purchase, you are required to provide the Brand ID (in the request body) and API key (in the header). Both can be located in the Dashboard section of your merchant account login.</p>\n</li>\n</ol>\n","urlObject":{"protocol":"https","path":["api","v1","purchases"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"17cc95a9-1660-4346-b53b-23345cf56455","name":"purchase-sucess","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n  \"client\": {\n    \"email\": \"seo2009@test.com\",\n    \"street_address\": \"10 New Burlington Street Apt. 214\",\n    \"city\": \"Sydney\",\n    \"full_name\": \"Test test\",\n    \"zip_code\": \"W1S 3BE\",\n    \"country\": \"KR\",\n    \"stateCode\": \"QLD\",\n    \"phone\": \"+447755564318\",\n    \"date_of_birth\": \"1970-07-10\"\n  },\n  \"purchase\": {\n    \"currency\": \"KRW\",\n    \"products\": [\n      {\n        \"name\": \"test\",\n        \"price\": 100\n      }\n    ]\n  },\n  \"paymentMethod\": \"VIRTUAL-ACCOUNT\",\n  \"brand_id\": \"f6aff7d7-bb40-4857-bc84-9b4c8310b043\",\n  \"success_redirect\": \"https://your.success.redirect.url\",\n  \"pending_redirect\": \"https://your.pending.redirect.url\",\n  \"failure_redirect\": \"https://your.failure.redirect.url\",\n  \"success_callback\": \"https://your.success.callback.url\",\n  \"failure_callback\": \"https://your.failure.callback.url\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"purchaseId\": \"68441c2a7559cf659fd7e835\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"arun44@gmail.com\",\n        \"phone\": \"+237679544810\",\n        \"full_name\": \"Olive Tsafack\",\n        \"street_address\": \"test test\",\n        \"country\": \"KR\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1749294123,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"VIRTUAL-ACCOUNT\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"POST\",\n    \"force_recurring\": false,\n    \"created_on\": 1749294123,\n    \"merchantRef\": \"68441c2a7559cf659fd7e835\",\n    \"merchantName\": \"Merchant002\",\n    \"purchase\": {\n        \"currency\": \"KRW\",\n        \"products\": [\n            {\n                \"name\": \"test\",\n                \"quantity\": 1,\n                \"price\": 100,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 100,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"taxAmount\": 0,\n        \"taxPercent\": 0,\n        \"request_client_details\": [],\n        \"timezone\": \"MIT\",\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"44\",\n        \"brand_name\": \"44\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1749294123\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS19963\",\n    \"issued\": \"2025-06-07\",\n    \"due\": 1749294123,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"paidOn\": 0,\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://your.success.redirect.url\",\n    \"pending_redirect\": \"https://your.pending.redirect.url\",\n    \"failure_redirect\": \"https://your.failure.redirect.url\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://your.success.callback.url\",\n    \"failure_callback\": \"https://your.failure.callback.url\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"183.83.54.51\",\n    \"checkout_url\": \"https://staging.paysecure.net/payments/68441c2a7559cf659fd7e835/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"7b497795-75ac-4a96-8e51-8bda611ff822"},{"name":"Get Status","id":"f9054032-1a2f-4657-a1ef-a706115ead59","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<p><strong>Note:</strong> With respect to bank transfers, the purchase request is synonymous with the PayIn request.</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"e61f373e-86e6-4269-b9fb-6e61c78c31b2","name":"Purchases-success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"65f95faa70fe897720c40a15\",\r\n    \"client\": {\r\n----\r\n       },\r\n    \"updated_on\": 1710841770,\r\n    \"type\": \"purchase\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"redirectType\": \"POST\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1710841770,\r\n    \"merchantRef\": \"65f95faa70fe897720c40a15\",\r\n    \"merchantName\": \"test\",\r\n    \"purchase\": {\r\n----\r\n    },\r\n    \"issuer_details\": {\r\n-----\r\n    },\r\n    \"transaction_data\": {\r\n----\r\n    },\r\n    \"status\": \"CREATED\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1710841770\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"90ed108b-6753-465d-8a21-e2cc604ff814\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS2697\",\r\n    \"issued\": \"2024-03-19\",\r\n    \"due\": 1710841770,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"paymentMethod\" : \"BANKTRANSFER\",\r\n    \"brand_id\": \"90ed108b-6753-465d-8a21-e2cc604ff814 \",\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\"\r\n    \"cancel_redirect\": \"\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"110.235.229.223\",\r\n    \"checkout_url\": \"https://app.paysecure.net/payments/65f95faa70fe897720c40a15/\"\r\n}\r\n"},{"id":"8aab2a7a-a219-4da6-81e0-f884f297d3a9","name":"Purchases","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}\r\n"}],"_postman_id":"f9054032-1a2f-4657-a1ef-a706115ead59"}],"id":"4fadd540-91b3-4fc4-b4f5-2358215f660e","_postman_id":"4fadd540-91b3-4fc4-b4f5-2358215f660e","description":""}],"id":"5c3b9f8c-0fa3-433c-88e5-b51b374b47dd","description":"<p>A <strong>Virtual Account (VA)</strong> is a unique, system-generated bank account number provided to a merchant or end-customer for the purpose of collecting payments.</p>\n<p>Unlike a traditional pooled account where many customers pay into the same bank account and merchants must rely on payer references to reconcile funds, a Virtual Account is unique per customer, transaction, or use case. This ensures that when a payment is received, it is automatically mapped and reconciled to the correct merchant/customer without manual intervention.</p>\n<h2 id=\"concepts\">Concepts</h2>\n<ul>\n<li><p><strong>Unique Identifiers:</strong> Each VA has its own account number or IBAN.</p>\n</li>\n<li><p><strong>Seamless Reconciliation:</strong> Payments are matched automatically based on the VA, eliminating reliance on free-text references.</p>\n</li>\n<li><p><strong>Local &amp; Cross-Border Coverage:</strong> Can be issued in multiple currencies and geographies (e.g., USD ACH, EUR SEPA, GBP FPS, INR UPI).</p>\n</li>\n<li><p><strong>Temporary or Permanent:</strong> Can be dynamic (per transaction/session) or static (per customer).</p>\n</li>\n<li><p><strong>Bank-Grade Security:</strong> Issued through Paysecure’s partner banks and fully compliant with local regulations.</p>\n</li>\n</ul>\n<h2 id=\"benefits\">Benefits</h2>\n<ul>\n<li><p><strong>Operational Efficiency</strong> – no manual reconciliation of payer references.</p>\n</li>\n<li><p><strong>Improved Customer Experience</strong> – clear payment instructions, fewer failed/misapplied payments.</p>\n</li>\n<li><p><strong>Global Reach</strong> – merchants can collect funds locally in multiple regions without needing a local bank entity.</p>\n</li>\n<li><p><strong>Scalability</strong> – supports thousands of customers with individual VAs.</p>\n</li>\n</ul>\n<h2 id=\"use-cases\"><strong>Use Cases</strong></h2>\n<ul>\n<li><p><strong>User-Specific Collections &amp; Attribution:</strong> Assign a unique VA to each user or customer, enabling precise tracking and reconciliation. Ideal for platforms needing granular visibility into who sent what and when.</p>\n</li>\n<li><p><strong>Digital Wallets &amp; Balances:</strong> Support digital wallets by integrating dedicated VAs per wallet to manage real-time balances.</p>\n</li>\n<li><p><strong>In-House Banking / Treasury Management:</strong> Use VAs to simulate an internal banking structure. This supports efficient ledger transfers between your internal entities, lowering operational cost and friction.</p>\n</li>\n<li><p><strong>One-Time Transaction Handling (Events, Invoices, Deposits):</strong> Create temporary or dynamic VAs for specific, short-term needs.</p>\n</li>\n<li><p><strong>Local &amp; Multi-Currency Receivables:</strong> Facilitate local payments in multiple currencies and countries without opening physical accounts.</p>\n</li>\n</ul>\n","_postman_id":"5c3b9f8c-0fa3-433c-88e5-b51b374b47dd"},{"name":"🌎 Paypal Wallet","item":[{"name":"Purchase","id":"c343ab6f-a8cf-4efa-99d0-3961f2a20202","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"example@paysecure.net\",\n        \"country\": \"US\",\n        \"city\": \"New York\",\n        \"stateCode\": \"ca\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\",\n        \"phone\": \"+1 202 555 0185\"\n    },\n    \"purchase\": {\n        \"products\": [\n            {\n                \"name\": \"Apple\",\n                \"price\": \"10\"\n            }\n        ]\n    },\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e \",\n    \"merchantRef\": \"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\n    \"paymentMethod\" : \"PAYPAL\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>The customer's email.</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>purchase.products</td>\n<td>An object which contains the list of products which the customer is buying.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>The name of the product.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"essential-optional-parameters\">Essential Optional Parameters</h2>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<p>Upon successul create on a Purchase you'd get a <code>\"purchaseId\"</code> . Use this ID for the next step in Server to server call by calling <code>p/{purchaseId}/?s2s=true .</code></p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n</tr>\n<tr>\n<td>some Mandatory Parameter are missing</td>\n</tr>\n<tr>\n<td>Invalid format of Date_of_Birth [allowed format: yyyy-mm-dd]</td>\n</tr>\n<tr>\n<td>Invalid Email Format</td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n</tr>\n<tr>\n<td>Merchant Limit is not set</td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n</tr>\n<tr>\n<td>Brand not found !</td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n</tr>\n<tr>\n<td>Only {{currencyCode}} currency is allowed.</td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n</tr>\n<tr>\n<td>Invalid_Parameter  <br />You'd usually get it when one or more mandatory parameters are not present in the request.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"91acdd13-96dc-4951-a2fe-f35eba7bc261","id":"91acdd13-96dc-4951-a2fe-f35eba7bc261","name":"🌎 Paypal Wallet","type":"folder"}},"urlObject":{"path":["purchases"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"f3a48139-3449-452c-9e4c-828fb597f757","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"example@paysecure.net\",\n        \"country\": \"US\",\n        \"city\": \"New York\",\n        \"stateCode\": \"ca\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\",\n        \"phone\": \"+1 202 555 0185\"\n    },\n    \"purchase\": {\n        \"products\": [\n            {\n                \"name\": \"Apple\",\n                \"price\": \"10\"\n            }\n        ]\n    },\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e \",\n    \"merchantRef\": \"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\n    \"paymentMethod\" : \"PAYPAL\",\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"status":"OK","code":200,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 15 Feb 2026 03:50:02 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"bff1fdeb-28e1-453f-b2c0-99f3a69a4938"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 3b66cea026f27925ba048cc96a0885ca.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"yfsFsvL9XV7VqG78CQKk9laeRufDW3YWnRMAbS5V0kuDeFbLRHCRoA=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=ph60P%2FQ%2BttujGhCyzKI4n0CieSKGeWXBq3hNAFV28RI6CHN0ZTI40y6TOdReaik7ID1%2BIrBFGqV3ifMplb6P4ahjmnh9pVLeT9kmoh4DzVA%3D\"}]}"},{"key":"CF-RAY","value":"9ce1d6ba4e8891fa-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"purchaseId\": \"64b032c3c6dccf7d329d9e7e\",\n    \"client\": {\n        \"email\": \"example@paysecure.net\",\n        \"country\": \"US\",\n        \"city\": \"New York\",\n        \"stateCode\": \"ca\",\n        \"street_address\": \"test test\",\n        \"zip_code\": \"234567\",\n        \"phone\": \"+1 202 555 0185\"\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1689268934,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1689268934,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"Apple\",\n                \"quantity\": 1,\n                \"price\": 10,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 10,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1689268934\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"is_recurring_token\": false,\n    \"reference_generated\": \"PS161\",\n    \"merchantRef\":\"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\n    \"issued\": \"2023-07-13\",\n    \"due\": 1689268934,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://api.paysecure.net/payments/64b032c3c6dccf7d329d9e7e/\",\n    \"direct_post_url\": \"http://api.paysecure.net/api/v1/p/64b032c3c6dccf7d329d9e7e/\"\n}"}],"_postman_id":"c343ab6f-a8cf-4efa-99d0-3961f2a20202"}],"id":"91acdd13-96dc-4951-a2fe-f35eba7bc261","description":"<h2 id=\"overview\">Overview</h2>\n<p>The <strong>PayPal Wallet</strong> integration enables merchants to accept payments from over 400 million active users worldwide. As one of the most trusted names in digital payments, offering PayPal can significantly increase conversion rates by providing a familiar, secure, and friction-free checkout experience.</p>\n<p>Unlike traditional card payments where users must manually enter sensitive details, the PayPal Wallet allows customers to pay using their stored credentials (credit cards, bank accounts, or PayPal balance) via a secure login.</p>\n<h3 id=\"key-features--benefits\">Key Features &amp; Benefits</h3>\n<ul>\n<li><p><strong>Higher Approval Rates:</strong> Transactions are authenticated directly by the user via their PayPal app or login, reducing the risk of fraud and issuer declines.</p>\n</li>\n<li><p><strong>Frictionless Checkout:</strong> Supports \"One Touch™\" payments, allowing returning users to skip login and pay in a single click.</p>\n</li>\n<li><p><strong>Global Reach:</strong> Automatically handles currency conversion, allowing you to accept payments from customers in 200+ markets.</p>\n</li>\n<li><p><strong>Security:</strong> Sensitive financial details are never shared with the merchant, minimizing your PCI compliance burden.</p>\n</li>\n</ul>\n<h3 id=\"how-it-works\">How it Works</h3>\n<p>Since PayPal requires user authentication, the integration follows a <strong>Redirect</strong> pattern:</p>\n<ol>\n<li><p><strong>Initiate:</strong> You send a purchase request to Paysecure with <code>paymentMethod: PAYPAL</code>.</p>\n</li>\n<li><p><strong>Redirect:</strong> Paysecure returns a <code>checkout_url</code>. You send the customer's browser to this URL.</p>\n</li>\n<li><p><strong>Authenticate:</strong> The customer logs into PayPal and approves the amount.</p>\n</li>\n<li><p><strong>Return:</strong> PayPal redirects the customer back to your <code>success_redirect</code> URL, and Paysecure triggers a server-to-server webhook to confirm the status.</p>\n</li>\n</ol>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"28227ab9-5ee8-44ff-9785-d9d8543f12c9","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"e19a8d8c-9c7d-4628-b871-3766d071e1d9","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"91acdd13-96dc-4951-a2fe-f35eba7bc261"},{"name":"Virtual Cards Payout","item":[{"name":"Create Customer","id":"a365ffd9-9add-4466-971c-5ce012f441ed","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"fullName\": \"Rahul Agarwal\", // mandatory\r\n    \"emailId\": \"rahul+26@paysecure.net\", // mandatory\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\", // mandatory with country code\r\n    \"city\": \"Jaipur\",\r\n    \"stateCode\": \"RJ\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\", // mandatory\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer","description":"<p><strong>OVERIEW</strong></p>\n<p>The <strong>createCustomer API</strong> allows merchants to create a customer profile on PaySecure when a user visits their website, facilitating a seamless payment experience by pre-filling the customer's details, on the PaySecure Cashier. The API takes in customer information and returns a unique customerID that can be passed in purchase payload, eliminating the need for customers to manually enter their details during transactions.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th><strong>Required</strong></th>\n<th>Description</th>\n<th>Example</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>merchantCustomerId</td>\n<td>String</td>\n<td>Yes</td>\n<td>unique customer ID provided by merchant. This can be email, mobile or an alphanumeric string</td>\n<td><a href=\"https://mailto:rahultestcustomer@paysecure.net\">rahultestcustomer@paysecure.net</a></td>\n</tr>\n<tr>\n<td>fullName</td>\n<td>String</td>\n<td>Yes</td>\n<td>Full name of the customer.</td>\n<td>Rahul Agarwal</td>\n</tr>\n<tr>\n<td>emailId</td>\n<td>String</td>\n<td>Yes</td>\n<td>Email address of the customer.</td>\n<td><a href=\"https://mailto:test@paysecure.net\">test@paysecure.net</a></td>\n</tr>\n<tr>\n<td>dateOfBirth</td>\n<td>String</td>\n<td>Optional</td>\n<td>Customer's date of birth in YYYY-MM-DD format.</td>\n<td>1995-12-27</td>\n</tr>\n<tr>\n<td>phoneNo</td>\n<td>String</td>\n<td>Yes</td>\n<td>Customer's phone number. Preferred with the country code</td>\n<td>+91 797639082</td>\n</tr>\n<tr>\n<td>city</td>\n<td>String</td>\n<td>Optional</td>\n<td>City of the customer.</td>\n<td>Jaipur</td>\n</tr>\n<tr>\n<td>stateCode</td>\n<td>String</td>\n<td>Yes</td>\n<td>State code of the customer.</td>\n<td>RJ</td>\n</tr>\n<tr>\n<td>zipCode</td>\n<td>String</td>\n<td>Optional</td>\n<td>Postal code of the customer's location.</td>\n<td>302018</td>\n</tr>\n<tr>\n<td>address</td>\n<td>String</td>\n<td>Optional</td>\n<td>Full address of the customer.</td>\n<td>House Number 53, Vaishali Nagar, Jaipur</td>\n</tr>\n<tr>\n<td>country</td>\n<td>String</td>\n<td>Yes</td>\n<td>Country code (ISO 3166-1 alpha-2).</td>\n<td>IN</td>\n</tr>\n<tr>\n<td>custRegDate</td>\n<td>Sting</td>\n<td>Optional</td>\n<td>Customer registration date on merchant site in YYYY-MM-DD format.</td>\n<td>2023-12-27</td>\n</tr>\n<tr>\n<td>successTxn</td>\n<td>String</td>\n<td>Optional</td>\n<td>Number of successful transactions customer has carried on merchant site.</td>\n<td>32</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"user-flow\"><strong>User Flow</strong></h3>\n<ol>\n<li><p><strong>Customer visits merchant's website</strong>: The customer selects the product or service and proceeds to checkout page.</p>\n</li>\n<li><p><strong>Merchant calls the</strong> <strong><code>createCustomer</code></strong> <strong>API</strong>: The merchant sends a <code>POST</code> request to the Paysecure API with the customer's details.</p>\n</li>\n<li><p><strong>Customer ID generation</strong>: Paysecure processes the request and generates a unique <code>customerId</code> which is returned in the response.</p>\n</li>\n<li><p><strong>Payment Process</strong>: The merchant uses the <code>customerId</code> for subsequent session creation, ensuring the customer doesn’t need to re-enter their details for future payments.</p>\n</li>\n</ol>\n<hr />\n<h3 id=\"benefits\"><strong>Benefits</strong></h3>\n<ul>\n<li><p><strong>Seamless user experience</strong>: The customer does not have to enter their details manually for every purchase.</p>\n</li>\n<li><p><strong>Faster Checkout</strong>: The merchant can use the <code>customerId</code> for faster payment processing.</p>\n</li>\n<li><p><strong>Data Security</strong>: Customer details are stored securely and can be reused across transactions, reducing the chances of errors.</p>\n</li>\n</ul>\n<h3 id=\"implementing-createcustomer-on-merchant-site\">Implementing createCustomer on merchant site:</h3>\n<p>The <code>createCustomer</code> can be implemented on merchant site in one of two ways, depending on merchant’s integration flow:</p>\n<p><strong>At Checkout:</strong></p>\n<p>When a customer initiates the checkout process, your system should invoke the <code>createCustomer</code> API, before actually starting the session.</p>\n<ul>\n<li><p><strong>Call</strong> <strong><code>createCustomer</code></strong>: This API call generates a unique customer ID.</p>\n</li>\n<li><p><strong>Use of Customer ID:</strong> Pass the returned customer ID in Session API, when creating a payment session.</p>\n</li>\n</ul>\n<p><strong>Upon Customer Login:</strong></p>\n<p>Alternatively, merchants may choose to call <code>createCustomer</code> at the time of customer login on their site.</p>\n<ul>\n<li><p><strong>Persistent Customer Profiles:</strong> This approach can help build or maintain a persistent customer profile, ensuring the customer ID is available for any subsequent payment sessions without needing to call <code>createCustomer</code> again.</p>\n</li>\n<li><p><strong>Integration Flexibility:</strong> This is useful for merchants who want to initialize customer data early in the customer journey rather than during checkout.</p>\n</li>\n</ul>\n<p>The method you choose depends on your business requirements and how your system is architected. Regardless of when you call it, the resulting customer ID must be passed to the <code>createSession</code> API to initiate a payment session.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"c97c753a-5d00-4906-ae7b-550aba404b1b","id":"c97c753a-5d00-4906-ae7b-550aba404b1b","name":"Virtual Cards Payout","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","customer"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"05e73928-3555-4b59-8f01-8aa98d50d624","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"If this parameter is passed in the header, a unique customer will be created under that particular Brand Name. else, the customer will be created under the main merchant (irrespective of the brands)","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"city\": \"Jaipur\",\r\n    \"stateCode\": \"RJ\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"CustRegDate\": \"2023-12-27\", //non-mandatory - customer registration date on merchant site\r\n    \"SuccessTxn\": \"32\", //non-mandatory - total successful customer orders on merchant site\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer"},"status":"OK","code":200,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"customerId\": \"691afbc6fd96d34a8113a34d\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"brandID\": \"1d666074-39be-4b90-aec9-e9de78fbdcb9\",\r\n    \"city\": \"Jaipur\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"stateCode\": \"RJ\",\r\n    \"custRegDate\": \"2023-12-27\",\r\n    \"successTrans\": 0,\r\n    \"createdOn\": 1763376070,\r\n    \"lastUpdated\": 0,\r\n    \"lastActivity\": 1763376070,\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}"},{"id":"410c37b2-df29-4a5f-abe7-2d3c91c432f4","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"If this parameter is passed in the header, a unique customer will be created under that particular Brand Name. else, the customer will be created under the main merchant (irrespective of the brands)","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"city\": \"Jaipur\",\r\n    \"stateCode\": \"RJ\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"CustRegDate\": \"2023-12-27\", //non-mandatory - customer registration date on merchant site\r\n    \"SuccessTxn\": \"32\", //non-mandatory - total successful customer orders on merchant site\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer"},"status":"Bad Request","code":400,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Invalid Email Format\",\r\n    \"code\": \"invalid_email\"\r\n}"},{"id":"8e24d453-54bd-41bb-8ccd-1221099b57ab","name":"Existing Customer","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"If this parameter is passed in the header, a unique customer will be created under that particular Brand Name. else, the customer will be created under the main merchant (irrespective of the brands)","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"city\": \"Jaipur\",\r\n    \"stateCode\": \"RJ\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"CustRegDate\": \"2023-12-27\", //non-mandatory - customer registration date on merchant site\r\n    \"SuccessTxn\": \"32\", //non-mandatory - total successful customer orders on merchant site\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer"},"status":"Unauthorized","code":401,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Customer already exists with this information\",\r\n    \"code\": \"customer_already_exists\"\r\n}"}],"_postman_id":"a365ffd9-9add-4466-971c-5ce012f441ed"},{"name":"Get Customer","id":"9e2b13ba-635c-4dce-9b40-58ccb661c89c","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\"\n}","options":{"raw":{"language":"json"}}},"url":"https://app.paysecure.net/api/v1/customer","description":"<p>This endpoint makes an HTTP GET request to retrieve customer information from the Paysecure API.</p>\n<h3 id=\"request\">Request</h3>\n<p>The request does not include any query parameters, but it uses a raw request body with the following parameter \"merchantCustomerId\", which will be the customer id on the merchant's side.</p>\n<h3 id=\"response\">Response</h3>\n<p>The response of this request can be documented as a JSON schema.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"c97c753a-5d00-4906-ae7b-550aba404b1b","id":"c97c753a-5d00-4906-ae7b-550aba404b1b","name":"Virtual Cards Payout","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","customer"],"host":["app","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"c0763be9-e9d9-4e35-8900-ee14e088b5d6","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\"\n}","options":{"raw":{"language":"json"}}},"url":"https://app.paysecure.net/api/v1/customer"},"status":"OK","code":200,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\n    \"customerId\": \"691afbc6fd96d34a8113a34d\",\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\",\n    \"fullName\": \"Rahul Agarwal\",\n    \"emailId\": \"rahul+26@paysecure.net\",\n    \"dateOfBirth\": \"1994-06-03\",\n    \"phoneNo\": \"+91 797639082\",\n    \"brandID\": \"1d666074-39be-4b90-aec9-e9de78fbdcb9\",\n    \"city\": \"Jaipur\",\n    \"zipCode\": \"302018\",\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\n    \"country\": \"IN\",\n    \"stateCode\": \"RJ\",\n    \"custRegDate\": \"2023-12-27\",\n    \"successTrans\": 0,\n    \"createdOn\": 1763376070,\n    \"lastUpdated\": 0,\n    \"lastActivity\": 1763376070,\n    \"extraParam\": {\n        \"param1\": \"value1\",\n        \"param2\": \"value2\",\n        \"param3\": \"value3\",\n        \"param4\": \"value4\"\n    }\n}"},{"id":"ce282aa6-0f89-497b-bc84-9c5e93ffe2a1","name":"Invalid Customer","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\"\n}","options":{"raw":{"language":"json"}}},"url":"https://app.paysecure.net/api/v1/customer"},"status":"Bad Request","code":400,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Customer with this information does not exist\",\n    \"code\": \"customer_does_not_exist\"\n}"}],"_postman_id":"9e2b13ba-635c-4dce-9b40-58ccb661c89c"},{"name":"Create PayOut","id":"0014bee0-7718-44fe-9a1b-6151a82c9e21","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"684fe5700eb6476b179037aa\",\r\n        \"email\": \"customer141@email.uk\",\r\n        \"phone\": \"1234567890\",\r\n        \"country\": \"SG\",\r\n        \"full_name\": \"Test Person-uk\"\r\n    },\r\n    \"payoutMethod\": \"Payout-virtual-cards\",\r\n    \"amount\": 10,\r\n    \"currency\": \"USD\",\r\n    \"purpose\": \"payout to test\",\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\",\r\n    \"extraParam\": {\r\n        \"productType\": \"WELFARE\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payout, the very first call to make is /payout/</p>\n<p>with the required data in the request body.</p>\n<p>To generate a Payout, you are required to provide the <code>API key</code> (in the header) can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"c97c753a-5d00-4906-ae7b-550aba404b1b","id":"c97c753a-5d00-4906-ae7b-550aba404b1b","name":"Virtual Cards Payout","type":"folder"}},"urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"0a31fc49-3229-428f-839e-2334e31c6b44","name":"success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"684fe5700eb6476b179037aa\",\r\n        \"email\": \"customer141@email.uk\",\r\n        \"phone\": \"1234567890\",\r\n        \"country\": \"SG\",\r\n        \"full_name\": \"Test Person-uk\"\r\n    },\r\n    \"payoutMethod\": \"Payout-virtual-cards\",\r\n    \"amount\": 10,\r\n    \"currency\": \"USD\",\r\n    \"purpose\": \"payout to test\",\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\",\r\n    \"extraParam\": {\r\n        \"productType\": \"WELFARE\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"685faaf0b93cc30dd78957c6\",\r\n    \"client\": {\r\n        \"customerId\": \"685fa7d7b93cc30dd78956c1\",\r\n        \"email\": \"rahul+7@paysecure.net\",\r\n        \"phone\": \"+918839471520\",\r\n        \"full_name\": \"Rahul Agarwal\",\r\n        \"street_address\": \"Vaishali Jaipur\",\r\n        \"country\": \"FR\",\r\n        \"city\": \"jaipur\",\r\n        \"zip_code\": \"202020\",\r\n        \"stateCode\": \"RA\"\r\n    },\r\n    \"updated_on\": 1751100145,\r\n    \"payoutMethod\": \"PAYOUT-VIRTUAL-CARDS\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 5.0,\r\n    \"errorMsg\": \"\",\r\n    \"purpose\": \"payout to test\",\r\n    \"created_on\": 1751100145,\r\n    \"merchantRef\": \"685faaf0b93cc30dd78957c6\",\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1751100145\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1751100145\r\n        }\r\n    ],\r\n    \"currency\": \"EUR\",\r\n    \"paymentOn\": 1751100145,\r\n    \"taxAmount\": 0.0,\r\n    \"taxPercent\": 0.0,\r\n    \"redirectType\": \"POST\",\r\n    \"extraParam\": {\r\n        \"productType\": \"HOTAC\"\r\n    },\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}"},{"id":"8e0fbb14-1ef1-4e54-a861-f76b5448827c","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"684fe5700eb6476b179037aa\",\r\n        \"email\": \"customer141@email.uk\",\r\n        \"phone\": \"1234567890\",\r\n        \"country\": \"SG\",\r\n        \"full_name\": \"Test Person-uk\"\r\n    },\r\n    \"payoutMethod\": \"Payout-virtual-cards\",\r\n    \"amount\": 10,\r\n    \"currency\": \"USD\",\r\n    \"purpose\": \"payout to test\",\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\",\r\n    \"extraParam\": {\r\n        \"productType\": \"WELFARE\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"status":"OK","code":200,"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"684fe6980696787075207f8d\",\r\n    \"client\": {\r\n        \"customerId\": \"684fe5700eb6476b179037aa\",\r\n        \"email\": \"customer141@email.uk\",\r\n        \"phone\": \"1234567890\",\r\n        \"country\": \"SG\",\r\n        \"full_name\": \"Test Person-uk\"\r\n    },\r\n    \"updated_on\": 1750066843,\r\n    \"payoutMethod\": \"PAYOUT-VIRTUAL-CARDS\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 100,\r\n    \"errorMsg\": \"Deep link was not able to create\",\r\n    \"purpose\": \"testing payout\",\r\n    \"created_on\": 1750066843,\r\n    \"merchantRef\": \"684fe6980696787075207f8d\",\r\n    \"status\": \"ERROR\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1750066843\r\n        },\r\n        {\r\n            \"status\": \"error\",\r\n            \"timestamp\": 1750067894\r\n        }\r\n    ],\r\n    \"currency\": \"USD\",\r\n    \"extraParam\": {\r\n\t\t      \"productType\" : \"Hotac\"\r\n    },\r\n    \"paymentOn\": 0,\r\n    \"taxAmount\": 0,\r\n    \"taxPercent\": 0,\r\n    \"redirectType\": \"POST\",\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}"}],"_postman_id":"0014bee0-7718-44fe-9a1b-6151a82c9e21"}],"id":"c97c753a-5d00-4906-ae7b-550aba404b1b","description":"<h2 id=\"overview\">Overview</h2>\n<p>The <strong>Virtual Card Payout</strong> solution is designed to modernize how merchants distribute funds to their users. Traditionally, payouts (winnings, compensation, or rewards) required collecting sensitive bank details, which added friction and delayed access to funds.</p>\n<p>With Paysecure's Swiipr integration, merchants can instantly issue <strong>Virtual Mastercards</strong> directly to a user's mobile device. These cards are immediately usable online or in-store via digital wallets (Apple Pay / Google Pay).</p>\n<h3 id=\"core-use-cases\">Core Use Cases</h3>\n<ul>\n<li><p><strong>Gaming &amp; Sweepstakes:</strong> Instantly pay out winnings to players without waiting for bank transfers.</p>\n</li>\n<li><p><strong>Airline Compensation:</strong> Issue immediate funds for delayed flights or lost luggage (e.g., for food/hotel vouchers).</p>\n</li>\n<li><p><strong>Welfare &amp; Relief:</strong> Distribute emergency funds securely and instantly.</p>\n</li>\n</ul>\n<h3 id=\"the-deeplink-user-journey\">The \"Deeplink\" User Journey</h3>\n<p>Unlike standard payouts that go <em>to</em> an account, this flow <em>delivers</em> a card to the user:</p>\n<ol>\n<li><p><strong>Merchant Request:</strong> You send a payout request to Paysecure with the user's mobile number and amount.</p>\n</li>\n<li><p><strong>Instant Notification:</strong> The user receives an SMS or Email containing a secure <strong>Deeplink</strong>.</p>\n</li>\n<li><p><strong>Activation:</strong></p>\n<ul>\n<li><p><strong>New Users:</strong> The link prompts them to download the <strong>Swiipr App</strong>.</p>\n</li>\n<li><p><strong>Existing Users:</strong> The link opens the app directly.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Claim &amp; Spend:</strong> The user validates their mobile number, claims the virtual card, and provisions it to their <strong>Apple Wallet</strong> or <strong>Google Pay</strong> in one tap.</p>\n</li>\n</ol>\n<h3 id=\"key-features\">Key Features</h3>\n<ul>\n<li><p><strong>Instant Issuance:</strong> Cards are generated in real-time.</p>\n</li>\n<li><p><strong>Mobile-First:</strong> The entire experience is handled via the user's smartphone.</p>\n</li>\n<li><p><strong>Secure:</strong> No sensitive bank data is exchanged; funds are loaded onto a prepaid Mastercard.</p>\n</li>\n<li><p><strong>Flexible Funding:</strong> Merchants pre-fund their account, ensuring 100% approval rates for valid requests.</p>\n</li>\n</ul>\n<img src=\"https://content.pstmn.io/252107a8-b7eb-42ab-80df-b6adb8a756ff/aW1hZ2UucG5n\" width=\"2073\" height=\"4140\" />","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"eafac4cc-7dd9-4c07-947e-dda8953e7949","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"2e6dedd3-599d-4813-b0c0-3b1c36373c6c","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"c97c753a-5d00-4906-ae7b-550aba404b1b"}],"id":"10b67acb-af4a-4488-921b-f4ac75967b59","_postman_id":"10b67acb-af4a-4488-921b-f4ac75967b59","description":""},{"name":"🏦 Bank Transfers","item":[{"name":"Concepts","item":[],"id":"ca0e9768-98bd-4652-9d0b-3eef2e7f8a4d","description":"<h2 id=\"payin-flows\">PayIn Flows</h2>\n<p><strong>How it works</strong></p>\n<p>Paysecure's A2A paying system, utilizes the powerful Virtual Accounts capabilities, enabling you to support a wide range of scenarios using the following methods.</p>\n<p><strong>Key Steps</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/XMBcrVkVU_Iak6-k1uzllUV3Lr6e_wVP_25CzedW8zYahgDiRS1KmuGMn8obKpQ8DnSrMuNvE4GvFEcoe3_0oeDNnAsGtfGf9EtQnNZpnoFNt9iAuoWtSjBDwXIAm6a3fdeY61GPtXbJUw0d_bGBRIU\" alt />\n\n<p><strong>Flow</strong></p>\n<ul>\n<li><p>The merchant platform retrieves the account details (Account number, IBAN, and SWIFT code) for the merchant-assigned currency account intended for the PayIn.</p>\n</li>\n<li><p>These account details are then provided to the payer, who is instructed to make the payment to this account.</p>\n</li>\n<li><p>The payer accesses their banking app and inputs the provided account details along with the transaction amount.</p>\n</li>\n<li><p>Upon receiving the money from the payer, Paysecure promptly receives an Inward Credit Notification (ICN) webhook from its banking partner, confirming that the funds have been deposited into the corresponding virtual account.</p>\n</li>\n<li><p>The ICN contains all relevant transaction details. Paysecure forwards this notification to the merchant to inform them of the transaction.</p>\n</li>\n</ul>\n<h2 id=\"payout-flows\"><strong>PayOut flows</strong></h2>\n<p><strong>How it works</strong><br />Paysecure offers the ability to make payments to customers', individuals', or businesses' bank accounts using various transfer methods via its dashboard or suite of APIs. The dashboard consolidates all available features accessible through APIs, allowing you to easily go live with minimal technical setup.\"</p>\n<p><strong>Key Steps</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/Zuu8ZB-0YkxC4jOKNmeEqwM6LMvLMxdTewRcU9AzcNQUOttY3aqan6-ojn2OOU7cF5B2npN8zrPPFnjbV90i2Uu0Ai05H-a730GMu52zK39fTEy0WWIEP3HC9UDTf4t78nagMG1-GannNAvqOXmD9vM\" alt />\n\n<p><strong>Flow</strong></p>\n<ul>\n<li><p>The merchant platform initiates the creation of a payout by passing beneficiary details, along with payout details.</p>\n</li>\n<li><p>Beneficiary details include</p>\n</li>\n<li><p>Beneficiary ID (email or phone)</p>\n</li>\n<li><p>Beneficiary's address (is mandatory but not validated. So if you have this data we recommend you send it, otherwise, use some random value.)</p>\n</li>\n<li><p>Beneficiary's bank details</p>\n</li>\n<li><p>Beneficiary's name</p>\n</li>\n<li><p>Upon completion of the payout, reaching either a Success or Failure state, Paysecure notifies the merchant’s platform via webhook, providing the final status of the transaction and additional details.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"20f183be-2b4c-4eda-a65a-98909ea2e1e6","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"d0f94d6e-254f-4144-97bf-26876fd4b254","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"ca0e9768-98bd-4652-9d0b-3eef2e7f8a4d"},{"name":"Status Code","item":[],"id":"84b9b272-2cf0-44a3-b9b7-dad3dd40a6eb","description":"<h1 id=\"http-response-code\">HTTP Response Code</h1>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Code</strong></th>\n<th><strong>Triggering Event</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>200</td>\n<td>Successful Response</td>\n</tr>\n<tr>\n<td>202</td>\n<td>successful / Accepted</td>\n</tr>\n<tr>\n<td>400</td>\n<td>Bad request, the given data is invalid, or data is required</td>\n</tr>\n<tr>\n<td>401</td>\n<td>unauthorized request</td>\n</tr>\n<tr>\n<td>404</td>\n<td>page not found</td>\n</tr>\n<tr>\n<td>405</td>\n<td>Method Not Allowed (GET/POST)</td>\n</tr>\n<tr>\n<td>415</td>\n<td>unsupported media type</td>\n</tr>\n<tr>\n<td>422</td>\n<td>Unprocessable content, data is required</td>\n</tr>\n<tr>\n<td>429</td>\n<td>Too many request attempt</td>\n</tr>\n<tr>\n<td>500</td>\n<td>Internal server error</td>\n</tr>\n</tbody>\n</table>\n</div><p>You will not get Error codes if HTTPS response code is 200 or 202.</p>\n<h2 id=\"error-codes-and-messages\">Error Codes and Messages</h2>\n<h3 id=\"with-http-code400404401415405\">with http code(400,404,401,415,405)</h3>\n<p>Below is the list of possible error codes and the corresponding messages from Paysecure System</p>\n<h2 id=\"format\">Format</h2>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Code</strong></th>\n<th><strong>Message</strong></th>\n<th><strong>APIs that could generate the error code</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Authentication_failed</td>\n<td>Authorization header missing</td>\n<td>All</td>\n</tr>\n<tr>\n<td>already_in_process</td>\n<td>Some Processing is running on this purchaseId</td>\n<td>All</td>\n</tr>\n<tr>\n<td>unsupported_media_type</td>\n<td>Unsupported media type \"text/plain; charset=ISO-8859-1\" in request.</td>\n<td>All</td>\n</tr>\n<tr>\n<td>authentication_failed</td>\n<td>Incorrect secret_key/Invalid Merchant Type</td>\n<td>All</td>\n</tr>\n<tr>\n<td>transaction_error</td>\n<td>See the table below</td>\n<td>See the table below</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"type":"text/javascript","exec":[""],"id":"5af90fb4-8ae2-4850-abb1-358ff7401f8e"}},{"listen":"test","script":{"type":"text/javascript","exec":[""],"id":"299ca791-48ad-4b21-a1d5-5b52f87a3690"}}],"_postman_id":"84b9b272-2cf0-44a3-b9b7-dad3dd40a6eb"},{"name":"PayIn API","item":[{"name":"Create Purchase","id":"b3953ca2-3fb6-478e-8356-b8bbf05350a9","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"Zurich\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"DE\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"product name\",\r\n                \"price\": \"16\"\r\n            }\r\n        ]\r\n    },\r\n    \"merchantRef\": \"your-order-id\",\r\n    \"paymentMethod\": \"BANKTRANSFER\",\r\n    \"brand_id\": \"your-brandid\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Fields</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>The customer's email.</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>purchase.products</td>\n<td>An object which contains the list of products which the customer is buying.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>The name of the product.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"digital-signature-optional-parameter-\">Digital Signature (Optional Parameter) :</h3>\n<p>To ensure authenticity and non-repudiation of the the pay in request, there is an option to digitally sign the pay in request by using the merchant's public key.</p>\n<p><strong>Public key generation :-</strong></p>\n<img src=\"https://content.pstmn.io/1e198415-45ef-49d9-9dbf-8270bb853dab/aW1hZ2UucG5n\" width=\"1570\" height=\"743\" />\n\n<p><strong>Signature generation :-</strong></p>\n<p>This digitial signature is generated by encrypting the following elements of the pay in request:<br />Plaintext= Client.email+purchase.currency+ purchase.products.price+brand_id</p>\n<p><strong>Example of encrypt plaintext with public key in java:-</strong></p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-java\">private String encryptData(String plaintext, PublicKey publicKey) throws Exception {\n    Cipher cipher = Cipher.getInstance(\"RSA\");\n    cipher.init(Cipher.ENCRYPT_MODE, publicKey);\n    byte[] encryptedbytes = cipher.doFinal(message.getBytes());\n    return new String(Base64.getEncoder * ().encode(encryptedbytes));\n}\n\n</code></pre>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td></td>\n</tr>\n<tr>\n<td>Enter Valid Email</td>\n<td></td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td></td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect/failure_redirect/brand_id is missing</td>\n<td></td>\n</tr>\n<tr>\n<td>brand_id cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>failure_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid failure_redirect: minimum 10 characters</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products[0].name/purchase.products[0].price are missing</td>\n<td></td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td></td>\n</tr>\n<tr>\n<td>Currency \"{curr_name}\" is Not Allowed</td>\n<td></td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong> For certain use cases, in addition to long format purchase Id, Paysecure also provides a 7 digit unique code for each purchase starting with digit 4, eg 4000001</p>\n<p><em>“purchaseIdShortCode”: “4000013\"</em></p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"acb10383-777a-4edf-9e65-3466df80ae85","id":"acb10383-777a-4edf-9e65-3466df80ae85","name":"PayIn API","type":"folder"}},"urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"3bf1a565-919e-49cb-93b2-f1d8390635e1","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"Zurich\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"DE\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"product name\",\r\n                \"price\": \"16\"\r\n            }\r\n        ]\r\n    },\r\n    \"merchantRef\": \"your-order-id\",\r\n    \"paymentMethod\": \"BANKTRANSFER\",\r\n    \"brand_id\": \"your-brandid\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"66334635a2cf2a7da7b192ab\",\r\n    \"client\": {\r\n        \"bank_account\": \"\",\r\n        \"bank_code\": \"\",\r\n        \"email\": \"test3@gmail.com\",\r\n        \"phone\": \"+447755564318\",\r\n        \"full_name\": \"\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"personal_code\": \"\",\r\n        \"street_address\": \"asdfsa\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"a\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"shipping_street_address\": \"\",\r\n        \"shipping_country\": \"\",\r\n        \"shipping_city\": \"\",\r\n        \"shipping_zip_code\": \"\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"legal_name\": \"\",\r\n        \"brand_name\": \"\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\",\r\n        \"documentId\": \"\",\r\n        \"documentType\": \"\",\r\n        \"bankAccountNumber\": \"\",\r\n        \"bankAccount\": \"\",\r\n        \"bankCode\": \"\",\r\n        \"description\": \"\",\r\n        \"stateCode\": \"QLD\"\r\n    },\r\n    \"updated_on\": 1714636341,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"BANKTRANSFER\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"redirectType\": \"GET\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1714636341,\r\n    \"merchantRef\": \"66334635a2cf2a7da7b192ab\",\r\n    \"merchantName\": \"merchant002\",\r\n    \"feesDeducted\": 0.3,\r\n    \"purchaseIdShortCode\": “4000013\",\r\n    \"purchase\": {\r\n        \"currency\": \"JPY\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 5000.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 5000.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"request_client_details\": [],\r\n        \"timezone\": \"MIT\",\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 5000.0,\r\n        \"currency\": \"JPY\",\r\n        \"net_amount\": 5000.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1714636341,\r\n        \"remote_paid_on\": 1714636341\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {\r\n                \"bank_account\": \"\",\r\n                \"bank_code\": \"\"\r\n            }\r\n        ],\r\n        \"legal_name\": \"gdhnb\",\r\n        \"brand_name\": \"gdhnb\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 5000.0,\r\n            \"masked_pan\": \"BANKTRANSFER\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"103.59.75.41\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"BANKTRANSFER\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"BANKTRANSFER\",\r\n                \"processing_time\": 1714636341,\r\n                \"extra\": {\r\n                    \"amount\": 5000.0,\r\n                    \"masked_pan\": \"BANKTRANSFER\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAYMENT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1714636341\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1714636341\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1714636341\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"76fad4ea-2ba2-4511-8989-3bed04e7d5bb\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS8937\",\r\n    \"issued\": \"2024-05-02\",\r\n    \"due\": 1714636341,\r\n    \"refund_upto\": 0,\r\n    \"cc_descriptor\": \"\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"payInBankDetails\": {\r\n        \"accountName\": \"ｴｱｰｳｵﾚﾂｸｽｼﾞｬﾊﾟﾝｶﾌﾞｼｷｶｲｼｬ\",\r\n        \"accountNumber\": \"3194368\",\r\n        \"bankName\": \"MUFG BANK, LTD. 三菱UFJ銀行\",\r\n        \"swiftCode\": \"BOTKJPJT\",\r\n        \"branchName\": \"ワカタケ\",\r\n        \"accountType\": \"CHECKING\",\r\n        \"payment_routing_parameters\": {\r\n            \"BANK_CODE\": \"0005\",\r\n            \"BRANCH_CODE\": \"809\"\r\n        }\r\n    },\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 0.0,\r\n    \"success_redirect\": \"https://test.com/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://test.com/getResponse.jsp?success=false\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://test1.com\",\r\n    \"failure_callback\": \"https://test2.com\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"103.59.75.41\",\r\n    \"checkout_url\": \"https://staging.paysecure.net/payments/66334635a2cf2a7da7b192ab/\"\r\n}"},{"id":"292943d8-91cb-4b8a-bdc0-36e285e0cf71","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"test@gmail.com\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"city\": \"Zurich\",\r\n        \"full_name\": \"Test test\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"country\": \"DE\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"stateCode\": \"QLD\",\r\n        \"phone\": \"+447755564318\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"EUR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"product name\",\r\n                \"price\": \"16\"\r\n            }\r\n        ]\r\n    },\r\n    \"merchantRef\": \"your-order-id\",\r\n    \"paymentMethod\": \"BANKTRANSFER\",\r\n    \"brand_id\": \"your-brandid\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}\r\n"}],"_postman_id":"b3953ca2-3fb6-478e-8356-b8bbf05350a9"},{"name":"Get Status","id":"ba5c46f3-e7c6-4b0a-9067-65ec6307aa7e","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<p><strong>Note:</strong> With respect to bank transfers, the purchase request is synonymous with the PayIn request.</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"acb10383-777a-4edf-9e65-3466df80ae85","id":"acb10383-777a-4edf-9e65-3466df80ae85","name":"PayIn API","type":"folder"}},"urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"51c2097c-0e71-4887-b7ce-35faa84eb727","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"purchaseId\": \"66c4667bb993c970367c288a\",\r\n    \"client\": {\r\n        \"email\": \"deepakdeepaksinghal@gmail.com\",\r\n        \"date_of_birth\": \"1970-07-10\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"country\": \"IN\",\r\n        \"city\": \"London\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"cc\": [],\r\n        \"bcc\": [],\r\n        \"stateCode\": \"QLD\"\r\n    },\r\n    \"updated_on\": 1724147324,\r\n    \"type\": \"purchase\",\r\n    \"paymentMethod\": \"BANKTRANSFER\",\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"errorMsg\": \"\",\r\n    \"redirectType\": \"POST\",\r\n    \"force_recurring\": false,\r\n    \"created_on\": 1724147324,\r\n    \"merchantRef\": \"66c4667bb993c970367c288a\",\r\n    \"merchantName\": \"merchant002\",\r\n    \"purchase\": {\r\n        \"currency\": \"INR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"quantity\": 1.0,\r\n                \"price\": 10.0,\r\n                \"discount\": 0,\r\n                \"tax_percent\": \"0.00\"\r\n            }\r\n        ],\r\n        \"total\": 10.0,\r\n        \"language\": \"en\",\r\n        \"notes\": \"\",\r\n        \"debt\": 0,\r\n        \"total_formatted\": 1.0,\r\n        \"expireInMin\": \"35\",\r\n        \"request_client_details\": [],\r\n        \"timezone\": \"MIT\",\r\n        \"email_message\": \"\"\r\n    },\r\n    \"payment\": {\r\n        \"is_outgoing\": false,\r\n        \"payment_type\": \"PURCHASE\",\r\n        \"amount\": 10.0,\r\n        \"currency\": \"INR\",\r\n        \"net_amount\": 10.0,\r\n        \"fee_amount\": 0.0,\r\n        \"pending_amount\": 0.0,\r\n        \"pending_unfreeze_on\": null,\r\n        \"description\": \"\",\r\n        \"paid_on\": 1724147324,\r\n        \"remote_paid_on\": 1724147324\r\n    },\r\n    \"issuer_details\": {\r\n        \"website\": \"\",\r\n        \"legal_street_address\": \"\",\r\n        \"legal_country\": \"\",\r\n        \"legal_city\": \"\",\r\n        \"legal_zip_code\": \"\",\r\n        \"bank_accounts\": [\r\n            {}\r\n        ],\r\n        \"legal_name\": \"test6\",\r\n        \"brand_name\": \"test6\",\r\n        \"registration_number\": \"\",\r\n        \"tax_number\": \"\"\r\n    },\r\n    \"transaction_data\": {\r\n        \"payment_method\": \"\",\r\n        \"flow\": \"payform\",\r\n        \"extra\": {\r\n            \"amount\": 10.0,\r\n            \"masked_pan\": \"BANKTRANSFER\"\r\n        },\r\n        \"country\": \"\",\r\n        \"attempts\": [\r\n            {\r\n                \"client_ip\": \"103.59.75.113\",\r\n                \"type\": \"execute\",\r\n                \"payment_method\": \"BANKTRANSFER\",\r\n                \"flow\": \"payform\",\r\n                \"successful\": true,\r\n                \"country\": \"BANKTRANSFER\",\r\n                \"processing_time\": 1724147324,\r\n                \"extra\": {\r\n                    \"amount\": 10.0,\r\n                    \"masked_pan\": \"BANKTRANSFER\"\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1724147324\r\n        },\r\n        {\r\n            \"status\": \"pending_execute\",\r\n            \"timestamp\": 1724147324\r\n        },\r\n        {\r\n            \"status\": \"payment_in_process\",\r\n            \"timestamp\": 1724147324\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1724147324\r\n        }\r\n    ],\r\n    \"is_test\": false,\r\n    \"brand_id\": \"c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636\",\r\n    \"send_receipt\": false,\r\n    \"is_recurring_token\": false,\r\n    \"skip_capture\": false,\r\n    \"reference_generated\": \"PS10907\",\r\n    \"issued\": \"2024-08-20\",\r\n    \"due\": 1724147324,\r\n    \"refund_upto\": 1725871728,\r\n    \"cc_descriptor\": \"test1\",\r\n    \"fraudScore\": \"NA\",\r\n    \"trustScore\": \"NA\",\r\n    \"refund_availability\": \"NONE\",\r\n    \"refundable_amount\": 10.0,\r\n    \"success_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=true\",\r\n    \"failure_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=false\",\r\n    \"cancel_redirect\": \"\",\r\n    \"success_callback\": \"https://staging.paysecure.net\",\r\n    \"failure_callback\": \"https://staging.paysecure.net\",\r\n    \"platform\": \"API\",\r\n    \"created_from_ip\": \"103.59.75.113\",\r\n    \"checkout_url\": \"https://staging.paysecure.net/payments/66c4667bb993c970367c288a/\",\r\n    \"payoutProcess\": false\r\n}"},{"id":"ad9f9087-c08f-4440-95ae-56f214d99211","name":"Failure","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}\r\n"}],"_postman_id":"ba5c46f3-e7c6-4b0a-9067-65ec6307aa7e"}],"id":"acb10383-777a-4edf-9e65-3466df80ae85","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/cfWw_RYZ9eZVEKzKjeRW4I_VwbBTyqH78LUrJG6ulp7FkE1pXVD6DZr9MnQXB9KH_oLFasJDb156naCsBc2bgotPaVY7LtGOJNifpTOb5uks3fjAKpgVhU4dsXQmQ7hFKNFIVhZEl2p8fCN1YufsRaA\" />\n\n<ol>\n<li><p>The merchant initiates the purchase via the create purchase API. If successful, they receive PayIn bank details along with a checkout URL in the response JSON</p>\n</li>\n<li><p>The merchant then has 2 options</p>\n<ol>\n<li><p>Use the PayIn bank details in the JSON to create a webpage within the merchant’s IT estate, and show to user the PayIn instruction</p>\n</li>\n<li><p>Or direct the end-user to our checkout URL, where the client sees bank details for payment.</p>\n</li>\n</ol>\n</li>\n<li><p>After a successful or failed payment by the end user, an appropriate webhook would be sent to the merchant. If option 2b was the method employed, the user would be redirected to the appropriate redirect URL.</p>\n</li>\n</ol>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"84efd741-f4f3-478f-bc1f-88ae026d9137","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"d45e65a1-e913-476f-894d-d857342cecdc","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"acb10383-777a-4edf-9e65-3466df80ae85"},{"name":"PayOut API","item":[{"name":"Create PayOut","id":"ef3cf2f8-8a76-408e-8d91-65cd4718d223","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahul@gmail.com\",\r\n        \"country\": \"DE\",\r\n        \"city\": \"Zurich\",\r\n        \"stateCode\": \"QLD\",\r\n        \"full_name\": \"Test test\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"phone\": \"+448839471521\",\r\n        \"gender\": \"M\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountName\": \"Rahul Agarwal\",\r\n        \"bankAccountNumber\": \"645101511808\",\r\n        \"bankCountryCode\": \"AT\"\r\n    },\r\n    \"purpose\": \"Testing payout\",\r\n    \"currency\": \"EUR\",\r\n    \"payoutMethod\": \"PAYOUT-BANKTRANSFER\",\r\n    \"amount\": 10.0,\r\n    \"brandId\": \"f2f689d5-ca86-4514-94b9-f41bcdf857d7\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payment, the very first call to make is /payout/ with the required data in the request body.</p>\n<p>To generate a Payout, you are required to provide the <code>API key</code> (in the header) can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a Payout request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.full_name</td>\n<td>Full name of the receiver. Minimum 2 words with atleast 1 character in each word.</td>\n</tr>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a receiver, should be a valid email.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. It must be upper case.</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>State of the receiver. Must be in upper case.</td>\n</tr>\n<tr>\n<td>client.street_address</td>\n<td>street address of the receiver.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>zip code of the receiver.</td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td>Phone number of the receiver. Country code is mandatory.  <br />Example: +234999999999</td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>Payout-MOBILEMONEY</td>\n</tr>\n<tr>\n<td>Amount</td>\n<td>Amount in currency upto 2 decimal points</td>\n</tr>\n<tr>\n<td>Currency</td>\n<td>Note this is currency account for which you have balance.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the payout is successful</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the payout is in progress</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the payout is unsuccessful.</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>Purpose of Payout</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"required-parameters-in-the-request-body-for-this-use-case\">Required parameters in the request body for this use case:</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>beneficiaryDetail.bankName</td>\n<td>The Bank Name in which the customer want's to credit the money.  <br />  <br />Optional Field.  <br />If passed, only use the mentioned bank names below. Anything else might lead to payout failures.  <br />If you don't want to pass, then you might need to open our checkout_url in the response and user can select the Bank from the dropdown.</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.bankAccountName</td>\n<td>Mandatory Field.  <br />Account Holder's Full Name.  <br />It is advised to have atleast 2 words in the name.</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.bankAccountCurrency</td>\n<td>Optional Field.  <br />The Currency in which the money will be credited. Generally the same as the currency field mentioned above.</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.bankAccountNumber</td>\n<td>Mandatory Field.  <br />Account Holder's Account Number.  <br />This is the account in which the money will be credited.</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.bankCountryCode</td>\n<td>Optional Field.  <br />The country code in which the account exist. Generally the same as the country field mentioned above.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"ce79c05a-e657-4ead-af25-56db5e2e6ed5","id":"ce79c05a-e657-4ead-af25-56db5e2e6ed5","name":"PayOut API","type":"folder"}},"urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"3a695858-b127-466b-b747-1f9c4145e6d6","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahul@gmail.com\",\r\n        \"country\": \"AT\",\r\n        \"city\": \"Zurich\",\r\n        \"stateCode\": \"QLD\",\r\n        \"full_name\": \"Test test\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"phone\": \"+448839471521\",\r\n        \"gender\": \"M\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountName\": \"Rahul Agarwal\",\r\n        \"bankAccountNumber\": \"645101511808\",\r\n        \"bankCountryCode\": \"AT\"\r\n    },\r\n    \"purpose\": \"Testing payout\",\r\n    \"currency\": \"EUR\",\r\n    \"payoutMethod\": \"PAYOUT-BANKTRANSFER\",\r\n    \"amount\": 10.0,\r\n    \"brandId\": \"f2f689d5-ca86-4514-94b9-f41bcdf857d7\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"status":"Accepted","code":202,"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"65ffadb4c1c83822903a9205\",\r\n     \"client\": {\r\n        \"email\": \"rahul@gmail.com\",\r\n        \"country\": \"DE\",\r\n        \"city\": \"Zurich\",\r\n        \"stateCode\": \"QLD\",\r\n        \"full_name\": \"Test test\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"phone\": \"+448839471521\",\r\n        \"gender\": \"M\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"updated_on\": 1711254964,\r\n    \"payoutMethod\": \"Payout-BANKTRANSFER\",\r\n\t\"beneficiaryDetail\":{\r\n        \"bankAccountName\": \"Rahul Agarwal\",\r\n        \"bankAccountNumber\": \"645101511808\",\r\n        \"bankName\": \"ICICI Bank\"\r\n     },\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 10.0,\r\n    \"errorMsg\": \"Currency Account has insufficient balance.\",\r\n    \"purpose\": \"test payout\",\r\n    \"created_on\": 1711254972,\r\n    \"merchantRef\": \"65ffadb4c1c83822903a9205\",\r\n    \"status\": \"PAID\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1711254964\r\n        },\r\n        {\r\n            \"status\": \"paid\",\r\n            \"timestamp\": 1711254972\r\n        }\r\n    ],\r\n    \"currency\": \"EUR\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}\r\n"},{"id":"c168f1cb-8b50-4b3b-9061-c70c5642589f","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"rahul@gmail.com\",\r\n        \"country\": \"DE\",\r\n        \"city\": \"Zurich\",\r\n        \"stateCode\": \"QLD\",\r\n        \"full_name\": \"Test test\",\r\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\r\n        \"zip_code\": \"W1S 3BE\",\r\n        \"phone\": \"+448839471521\",\r\n        \"gender\": \"M\",\r\n        \"date_of_birth\": \"1970-07-10\"\r\n    },\r\n    \"beneficiaryDetail\": {\r\n        \"bankAccountName\": \"Rahul Agarwal\",\r\n        \"bankAccountNumber\": \"645101511808\",\r\n        \"bankName\": \"ICICI Bank\"\r\n    },\r\n    \"purpose\": \"Testing payout\",\r\n    \"currency\": \"EUR\",\r\n    \"payoutMethod\": \"PAYOUT-BANKTRANSFER\",\r\n    \"amount\": 10.0,\r\n    \"brandId\": \"f2f689d5-ca86-4514-94b9-f41bcdf857d7\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"status":"Bad Request","code":400,"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":" {\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"ef3cf2f8-8a76-408e-8d91-65cd4718d223"},{"name":"Get Status","id":"baa9dba7-bdd1-422d-a687-885285255028","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/","description":"<p>This API tells you about all the details of a Payout, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the payoutId in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payout_in_process</td>\n<td>payout is under Processing.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><p>The webhook will only be triggered for paid transactions or errors.</p>\n<p>Paid: \"success_callback\": \"<a href=\"https://success.com\">https://success.com</a>\",</p>\n<p>Error: \"failure_callback\": “<a href=\"https://failure.com%E2%80%9D\">https://failure.com”</a></p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"ce79c05a-e657-4ead-af25-56db5e2e6ed5","id":"ce79c05a-e657-4ead-af25-56db5e2e6ed5","name":"PayOut API","type":"folder"}},"urlObject":{"path":["getpayout","{payoutId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"075aa7f7-5e18-49eb-8d0c-7a5af30586b5","name":"Get Status","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"65ffadb4c1c83822903a9205\",\r\n    \"client\": {\r\n        \"email\": \"customer141@email.uk\",\r\n        \"full_name\": \"Test Person-uk\",\r\n        \"street_address\": \"Random city address\",\r\n        \"country\": \"SG\",\r\n        \"city\": \"Singapore\",\r\n        \"zip_code\": \"123456\",\r\n        \"stateCode\": \"test\"\r\n    },\r\n    \"updated_on\": 1711254964,\r\n    \"payoutMethod\": \"Payout-BANKTRANSFER\",\r\n    \"beneficiaryDetail\":{\r\n    \"bankName\": \"DBS Bank\",      \r\n    \"bankAccountName\": \"test test\",\r\n    \"bankAccountCurrency\": \"SGD\",\r\n    \"bankAccountNumber\": \"12345640\",\r\n    \"bankCountryCode\" : \"SG\",\r\n    \"swiftCode\": \"DBSSSGSG\",\r\n    \"routing_param\" :\r\n    {\r\n        \"bankCode\": \"897678\",\r\n        \"bankBranchCode\" : \"888\"\r\n           \r\n    }\r\n     },\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 1000.0,\r\n    \"errorMsg\": \"Currency Account has insufficient balance.\",\r\n    \"purpose\": \"test payout\",\r\n    \"created_on\": 1711254972,\r\n    \"merchantRef\": \"65ffadb4c1c83822903a9205\",\r\n    \"status\": \"ERROR\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1711254964\r\n        },\r\n        {\r\n            \"status\": \"error\",\r\n            \"timestamp\": 1711254972\r\n        }\r\n    ],\r\n    \"currency\": \"USD\",\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}\r\n"},{"id":"fdb5f241-5084-4bae-8aaf-20297563889e","name":"Get Status-error","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"baa9dba7-bdd1-422d-a687-885285255028"}],"id":"ce79c05a-e657-4ead-af25-56db5e2e6ed5","description":"<p><strong>API Flow</strong></p>\n<img src=\"https://lh7-us.googleusercontent.com/Uxy8jmp5RP-c360-oIMAZy2As8naqJdARgKsWU0x_BtszfJlwdRVM6-obffbtjTABfI9V0hxH4Ad-Ns96We42lIMdL434tTzLJ6aEQBt0dzX_ZXeM4RtG_kmEeem7WIsN520Zh5PS3xTFYNzOmks0ak\" />\n\n<p>At the time of onboarding, the merchant will be given the option of currency accounts. Typically, a merchant will have one currency account in one jurisdiction, but our platform allows for multiple currency accounts for merchants. Please contact your account manager if you need multicurrency accounts. Please note that there may be some restrictions on multicurrency accounts depending on the jurisdictions and commercials.</p>\n<p>Our system also caters to multiple business accounts within one merchant account for better financial risk management. If more than one business is onboarded for a merchant (each needing its own KYB), then our system would handle the complexity of balance distribution among the accounts in the backend and give simple easy-to-use APIs for merchants.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"ae71a942-2749-49ef-9783-b595f71b08c4","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"3af63fb2-0168-4456-83ef-39ad60d80cf7","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"ce79c05a-e657-4ead-af25-56db5e2e6ed5"},{"name":"Get Balance API","item":[{"name":"Checking Balance","id":"b619baf8-78ec-4215-bade-8dfbeb7c0758","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"paymentMethod\": \"BANKTRANSFER\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance","description":"<h2 id=\"api-for-checking-balance-payout\"><strong>API for Checking Balance payout</strong></h2>\n<ol>\n<li><p>URL :- /getBalance/</p>\n</li>\n<li><p>RequestType: POST</p>\n</li>\n<li><p>Request Body</p>\n</li>\n</ol>\n<p>Note: Currency is not a mandatory parameter. If no parameter is specified then all respective currency balances would be provided, if any specific currency parameter is provided then only that currency balance would be provided.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"e9d3740f-4a2e-408f-8c3e-b55fb602f330","id":"e9d3740f-4a2e-408f-8c3e-b55fb602f330","name":"Get Balance API","type":"folder"}},"urlObject":{"path":["getBalance"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"a49d512b-fd0c-4180-a8ef-b667cd9170f1","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{\r\n    \"paymentMethod\": \"BANKTRANSFER\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance"},"status":"OK","code":200,"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"paymentMethod\": \"BANKTRANSFER\",\r\n    \"status\": \"success\",\r\n    \"data\": [\r\n        {\r\n            \"currency\": \"AUD\",\r\n            \"balance\": \"0.00\"\r\n        },\r\n        {\r\n            \"currency\": \"USD\",\r\n            \"balance\": \"46813.79\"\r\n        },\r\n        {\r\n            \"currency\": \"JPY\",\r\n            \"balance\": \"1012.00\"\r\n        }\r\n    ]\r\n}\r\n"},{"id":"b76970ed-b13e-44e3-bd55-70d8b594d901","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{\r\n    \"paymentMethod\": \"BANKTRANSFER\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/getBalance"},"status":"Bad Request","code":400,"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"No currency account found\"\r\n}\r\n"}],"_postman_id":"b619baf8-78ec-4215-bade-8dfbeb7c0758"}],"id":"e9d3740f-4a2e-408f-8c3e-b55fb602f330","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"30376090-c3be-4a4f-8966-111ec4f2a6b4","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"a1c6dfa6-5da4-4178-88bd-8c49bb769b85","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"e9d3740f-4a2e-408f-8c3e-b55fb602f330","description":""}],"id":"781ccd8d-5dab-481f-b281-8fe9ce8a1ece","_postman_id":"781ccd8d-5dab-481f-b281-8fe9ce8a1ece","description":""},{"name":"🌐 Open Banking","item":[{"name":"Concepts - OpenBanking - EUR 🇪🇺 & UK 🇬🇧","item":[],"id":"fc12767d-d62e-47b5-a121-ddb1c9d51f72","description":"<p>Paysecure leverages its OpenBanking network across Europe and UK to make secure and fast payments, making top choice for customers in respective regions. It allows customers to pay in EUR or GBP via Paysecure Gateway, directly through their bank account.</p>\n<p>Paysecure Gateway is a web page that handles all the user interaction during a payment initiation process:</p>\n<ul>\n<li><p>user credentials input</p>\n</li>\n<li><p>interactive confirmation</p>\n</li>\n<li><p>progress reporting</p>\n</li>\n<li><p>error reporting</p>\n</li>\n</ul>\n<p>After your application has received an URL for executing a payment using Paysecure, you can redirect your end-user to it. There, they will see a screen that lets them pick a provider to execute a payment.</p>\n<p>Your user will also be asked to input credentials and, if needed, any of the interactive credentials. After the process is done, the user will be redirected back to your application URL</p>\n<h3 id=\"payin-user-flow\"><strong>PayIn User Flow</strong></h3>\n<p><strong>Step 1: Initiating the Payment</strong></p>\n<ul>\n<li><strong>Customer Selects 'OPEN BANKING' Payment Option</strong>: At the checkout page, the customer selects 'Open Banking' as their preferred payment method.</li>\n</ul>\n<p><strong>Step 2: Redirect to Bank Login</strong></p>\n<ul>\n<li><p><strong>Customer Selects Their Bank</strong>: The customer selects the provider/bank from the list of supported providers/banks on the Paysecure Gateway.</p>\n</li>\n<li><p><strong>Customer is Redirected to Bank Login Page</strong>: Platform securely redirects customers to their bank’s online banking login page.</p>\n</li>\n</ul>\n<p><strong>Step 3: Logging into Online Banking</strong></p>\n<ul>\n<li><p><strong>Customer Logs In</strong> The customer logs into their online banking account using their credentials.</p>\n</li>\n<li><p><strong>Secure Session</strong>: The login session is safe, and the customer’s banking credentials are not shared with any third party or any merchant.</p>\n</li>\n</ul>\n<p><strong>Step 4: Confirming the Payment</strong></p>\n<ul>\n<li><p><strong>Payment Details</strong>: The customer reviews the pre-filled payment details, including the amount and beneficiary information.</p>\n</li>\n<li><p><strong>Authorise Payment</strong>: The customer authorises the payment using their bank’s authentication method (e.g., OTP, password).</p>\n</li>\n</ul>\n<p><strong>Step 5: Payment Processing and Confirmation</strong></p>\n<ul>\n<li><p><strong>Bank Processes Payment</strong>: The customer’s bank processes the payment and debits the amount from the customer’s account.</p>\n</li>\n<li><p><strong>Instant Confirmation to the Paysecure gateway</strong>: Once the payment is processed, payment confirmation is received through a webhook url.</p>\n</li>\n</ul>\n<p><strong>Step 6: Notification to Merchant</strong></p>\n<ul>\n<li><p><strong>Paysecure Confirms Payment to Merchant</strong>: Paysecure gateway immediately notifies the merchant of the successful payment.</p>\n</li>\n<li><p><strong>Order Completion</strong>: The merchant completes and confirms the order to the customer.</p>\n</li>\n</ul>\n<p><strong>Step 7: Customer Redirect</strong></p>\n<ul>\n<li><p><strong>Redirect to Merchant’s Site</strong>: After confirming the payment, the customer is redirected back to the merchant’s website.</p>\n</li>\n<li><p><strong>Payment Confirmation Page</strong>: The merchant’s website displays a payment confirmation page to the customer.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"372e5a03-6810-466f-94d5-df30385221fe","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"cf4065f3-e1ef-4f7c-a968-ca67b8f61fca","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"fc12767d-d62e-47b5-a121-ddb1c9d51f72"},{"name":"APIs","item":[{"name":"Purchase","id":"d0d25e09-6113-4d99-bc76-36a7804c6080","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"alpha7.bravo@bravapay.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"LND\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"zip_code\": \"SW1A0AA\",\r\n        \"full_name\": \"shiba sharma\",\r\n        \"date_of_birth\": \"2004-04-31\",\r\n        \"phone\": \"+447755564318\",\r\n        \"gender\": \"male\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"GBP\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"price\": \"10\"\r\n            },\r\n            {\r\n                \"name\": \"retail\",\r\n                \"price\": \"11\"\r\n            }\r\n        ],\r\n        \"total\": 21\r\n    },\r\n    \"paymentMethod\": \"OPEN-BANKING\",\r\n    \"brand_id\": \"{{Your.brandID}}\",\r\n    \"merchantRef\": \"<your_transactionId>\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>The customer's email.</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>purchase.products</td>\n<td>An object which contains the list of products which the customer is buying.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>The name of the product.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"essential-optional-parameters\">Essential Optional Parameters</h2>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<p>Upon successul create on a Purchase you'd get a <code>\"purchaseId\"</code> . Use this ID for the next step in Server to server call by calling <code>p/{purchaseId}/?s2s=true .</code></p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n</tr>\n<tr>\n<td>some Mandatory Parameter are missing</td>\n</tr>\n<tr>\n<td>Invalid format of Date_of_Birth [allowed format: yyyy-mm-dd]</td>\n</tr>\n<tr>\n<td>Invalid Email Format</td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n</tr>\n<tr>\n<td>Merchant Limit is not set</td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n</tr>\n<tr>\n<td>Brand not found !</td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n</tr>\n<tr>\n<td>Only {{currencyCode}} currency is allowed.</td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n</tr>\n<tr>\n<td>Invalid_Parameter  <br />You'd usually get it when one or more mandatory parameters are not present in the request.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"54f3816d-6b35-4562-9f52-173372acb6ca","id":"54f3816d-6b35-4562-9f52-173372acb6ca","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"c3f21d6e-4cde-44ec-a18c-c8de7d985627","name":"Open Banking EU & UK","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"alpha7.bravo@bravapay.com\",\r\n        \"country\": \"GB\",\r\n        \"city\": \"London\",\r\n        \"stateCode\": \"LND\",\r\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\r\n        \"zip_code\": \"SW1A0AA\",\r\n        \"full_name\": \"shiba sharma\",\r\n        \"date_of_birth\": \"2004-04-31\",\r\n        \"phone\": \"+447755564318\",\r\n        \"gender\": \"male\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"GBP\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"e-commerce\",\r\n                \"price\": \"10\"\r\n            },\r\n            {\r\n                \"name\": \"retail\",\r\n                \"price\": \"11\"\r\n            }\r\n        ],\r\n        \"total\": 21\r\n    },\r\n    \"paymentMethod\": \"OPEN-BANKING\",\r\n    \"brand_id\": \"{{Your.brandID}}\",\r\n    \"merchantRef\": \"<your_transactionId>\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Thu, 13 Jul 2023 17:22:14 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"68c3a4a031ee334ef2c02b2a\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"alpha7.bravo@bravapay.com\",\n        \"date_of_birth\": \"2004-04-31\",\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\n        \"country\": \"GB\",\n        \"city\": \"London\",\n        \"zip_code\": \"SW1A0AA\",\n        \"full_name\": \"shiba sharma\",\n        \"phone\": \"+447755564318\",\n        \"gender\": \"male\",\n        \"stateCode\": \"LND\"\n    },\n    \"updated_on\": 1757652134,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"OPEN-BANKING\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"errorCode\": \"NA\",\n    \"redirectType\": \"POST\",\n    \"force_recurring\": false,\n    \"created_on\": 1757652128,\n    \"merchantRef\": \"68c3a4a031ee334ef2c02b2a\",\n    \"merchantName\": \"merchantName\",\n    \"purchase\": {\n        \"currency\": \"GBP\",\n        \"products\": [\n            {\n                \"name\": \"e-commerce\",\n                \"quantity\": 1.0,\n                \"price\": 10.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            },\n            {\n                \"name\": \"retail\",\n                \"quantity\": 1.0,\n                \"price\": 11.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 21.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 21.0,\n        \"currency\": \"INR\",\n        \"net_amount\": 21.0,\n        \"fee_amount\": 0.0,\n        \"pending_amount\": 0.0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1757652129,\n        \"remote_paid_on\": 1757652129\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"Testing\",\n        \"brand_name\": \"Testing\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"amount\": 100.0,\n            \"masked_pan\": \"OPEN-BANKING\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"183.83.55.235, 162.158.91.128, 18.68.47.183\",\n                \"type\": \"execute\",\n                \"payment_method\": \"OPEN-BANKING\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"OPEN-BANKING\",\n                \"processing_time\": 1757652129,\n                \"extra\": {\n                    \"amount\": 100.0,\n                    \"masked_pan\": \"OPEN-BANKING\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAYMENT_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1757652128\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1757652129\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1757652134\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"59c5ed48-caf9-464a-ba54-26e1e02bc1bc\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS93\",\n    \"issued\": \"2025-09-12\",\n    \"due\": 1757652128,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"0\",\n    \"trustScore\": \"0\",\n    \"paidOn\": 0,\n    \"taxAmount\": 0.0,\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"sessionId\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0.0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"183.83.55.235, 162.158.91.128, 18.68.47.183\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/63cddfa1a4948aba8e8ee9f319e3428f/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"d0d25e09-6113-4d99-bc76-36a7804c6080"},{"name":"Get Status","id":"29d22f47-5c14-4f91-a3fe-81af282b6e0b","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/64bff12bf63e36669499e97d/","description":"<p>This API tells you about all the details of a purchase, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>created</td>\n<td>When Purchase order is created.</td>\n</tr>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>chargeback</td>\n<td>Payment is chargeback state</td>\n</tr>\n<tr>\n<td>refund_in_process</td>\n<td>Refund is under Processing.</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>overdue</td>\n<td>Purchase is Overdued.</td>\n</tr>\n<tr>\n<td>cancelled</td>\n<td>Purchase is cancelled.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n<tr>\n<td>refunded</td>\n<td>Payment is refunded</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"54f3816d-6b35-4562-9f52-173372acb6ca","id":"54f3816d-6b35-4562-9f52-173372acb6ca","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","64bff12bf63e36669499e97d",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"037a934f-ec94-436a-a44d-64d0db734ced","name":"Purchases - success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/64bfdb7df63e36669499e82f/"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 15:45:29 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfdb7df63e36669499e82f\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690296521,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690295168,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 9,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 9,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 9,\n        \"currency\": \"USD\",\n        \"net_amount\": 9,\n        \"fee_amount\": 10.2591,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1690295205,\n        \"remote_paid_on\": 1690295205\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 9,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"US\",\n                \"processing_time\": 1690295205,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 9,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1690295168\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1690295193\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1690295205\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1690296521\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1690299929\n        }\n    ],\n    \"viewedOn\": 1690299929,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"merchantRef\":\"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS192\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690295168,\n    \"refund_upto\": 1705843623,\n    \"cc_descriptor\": \"test-cardeye\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 9,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfdb7df63e36669499e82f/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfdb7df63e36669499e82f/\"\n}"},{"id":"bcd59586-8036-49c0-80d1-5f67adedf79a","name":"Purchases-error","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/64bfd7c9f63e36669499e779/"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 15:44:06 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfd7c9f63e36669499e779\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690294251,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690294220,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 100,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 100,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 100,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": false,\n                \"country\": \"US\",\n                \"processing_time\": 1690294279,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 100,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                },\n                \"error\": {\n                    \"message\": \"Transaction Failed\",\n                    \"code\": \"transaction_error\"\n                }\n            }\n        ]\n    },\n    \"status\": \"ERROR\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1690294220\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1690294251\n        },\n        {\n            \"status\": \"error\",\n            \"timestamp\": 1690294299\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1690294382\n        }\n    ],\n    \"viewedOn\": 1690299845,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS188\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690294220,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfd7c9f63e36669499e779/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfd7c9f63e36669499e779/\"\n}"}],"_postman_id":"29d22f47-5c14-4f91-a3fe-81af282b6e0b"},{"name":"Refund","id":"437c9e85-8b8a-4f98-9781-009872fc252c","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund","description":"<p>This API is used to initate refund of the purchases that have status as <code>PAID</code> can be initiated for refund</p>\n<p>Once the refund has been initiated, the status of the purchase would become <code>REFUND_IN_PROCESS</code> and once the refund has been approved by the bank, the status woud become <code>REFUNDED</code></p>\n<p>Purchase ID is <strong>mandatory</strong> for this API.</p>\n<p>Currently we don't support partial refunds.</p>\n<h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>successful</code> and <code>unsuccessful</code> in refund of purchases.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"54f3816d-6b35-4562-9f52-173372acb6ca","id":"54f3816d-6b35-4562-9f52-173372acb6ca","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","657af976c3fceb7beb30eeb4","refund"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"afd7a437-921b-408c-aa4a-68768ce9dcc2","name":"Refund - Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 16:33:43 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfdb7df63e36669499e82f\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690302819,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690295168,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 9,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 9,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 9,\n        \"currency\": \"USD\",\n        \"net_amount\": 9,\n        \"fee_amount\": 10.2591,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1690295205,\n        \"remote_paid_on\": 1690295205\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 9,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"US\",\n                \"processing_time\": 1690295205,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 9,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                }\n            },\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"refund\",\n                \"successful\": true,\n                \"processing_time\": 1690302819,\n                \"extra\": {\n                    \"amount\": 9\n                }\n            }\n        ]\n    },\n    \"status\": \"REFUNDED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1765294731\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1765294744\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1765294754\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1765297331\n        },\n        {\n            \"status\": \"refunded\",\n            \"timestamp\": 1765624009\n        }\n    ],\n    \"viewedOn\": 1690299929,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS192\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690295168,\n    \"refund_upto\": 1705843623,\n    \"cc_descriptor\": \"test-cardeye\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfdb7df63e36669499e82f/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfdb7df63e36669499e82f/\"\n}"},{"id":"d3182c90-32f5-4696-99b6-fb6f9e64e551","name":"Refund - Pending","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Tue, 25 Jul 2023 16:33:43 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64bfdb7df63e36669499e82f\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"example@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1690302819,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1690295168,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 9,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 9,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 9,\n        \"currency\": \"USD\",\n        \"net_amount\": 9,\n        \"fee_amount\": 10.2591,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1690295205,\n        \"remote_paid_on\": 1690295205\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"10\",\n            \"amount\": 9,\n            \"card_issuer\": \"1-800-432-3117\",\n            \"masked_pan\": \"411111XXXXXX1111\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"cardholder_name\": \"dk\",\n            \"expiry_year\": \"23\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"US\",\n                \"processing_time\": 1690295205,\n                \"extra\": {\n                    \"expiry_month\": \"10\",\n                    \"amount\": 9,\n                    \"card_issuer\": \"1-800-432-3117\",\n                    \"masked_pan\": \"411111XXXXXX1111\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"cardholder_name\": \"dk\",\n                    \"expiry_year\": \"23\"\n                }\n            },\n            {\n                \"client_ip\": \"149.86.53.48\",\n                \"type\": \"refund\",\n                \"successful\": true,\n                \"processing_time\": 1690302819,\n                \"extra\": {\n                    \"amount\": 9\n                }\n            }\n        ]\n    },\n    \"status\": \"REFUND_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1690295168\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1690295193\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1690295205\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1690296521\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1690299929\n        },\n        {\n            \"status\": \"refund_in_process\",\n            \"timestamp\": 1690302819\n        }\n    ],\n    \"viewedOn\": 1690299929,\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS192\",\n    \"issued\": \"2023-07-25\",\n    \"due\": 1690295168,\n    \"refund_upto\": 1705843623,\n    \"cc_descriptor\": \"test-cardeye\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64bfdb7df63e36669499e82f/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64bfdb7df63e36669499e82f/\"\n}"},{"id":"6fb02108-1259-41bd-a526-c19dc3814e48","name":"Refund - Error","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/657af976c3fceb7beb30eeb4/refund"},"status":"Bad Request","code":400,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Thu, 13 Jul 2023 17:49:58 GMT"},{"key":"Connection","value":"close"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Only Purchases with `status == (paid)` can be refunded.\",\n    \"code\": \"transaction_error\"\n}"}],"_postman_id":"437c9e85-8b8a-4f98-9781-009872fc252c"}],"id":"54f3816d-6b35-4562-9f52-173372acb6ca","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"6622a1d6-bee5-4329-aad8-e979b4f9628d","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"ec58404a-4748-43ee-9385-daf1920fc17e","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"54f3816d-6b35-4562-9f52-173372acb6ca","description":""}],"id":"530085f8-be2d-454b-9b38-f4eadbdc5771","description":"<h3 id=\"overview\"><strong>Overview</strong></h3>\n<p><strong>Open Banking</strong> refers to the integration with local bank transfer systems in specific countries, enabling users to make payments directly from their bank accounts through a secure and trusted interface. This is particularly useful for regions where direct bank transfers are a preferred payment method over cards or other APMs.</p>\n<p>Paysecure leverages Open Banking to facilitate transactions for different regions, enabling businesses to access localized payment options without the complexity of managing individual bank integrations. Each third-party service is tailored to the specific financial infrastructure of the country or region, ensuring compliance, security, and ease of use.</p>\n<h3 id=\"key-benefits-of-open-banking\"><strong>Key Benefits of Open Banking</strong>:</h3>\n<ul>\n<li><p><strong>Localized Payment Options</strong>: Supports region-specific payment methods, giving customers familiar and trusted ways to pay.</p>\n</li>\n<li><p><strong>Secure Transactions</strong>: Payments are processed directly through the customer’s bank, enhancing trust and security.</p>\n</li>\n<li><p><strong>Real-Time Verification</strong>: Enables real-time confirmation of payments, reducing risks and improving cash flow.</p>\n</li>\n<li><p><strong>Compliance</strong>: Adheres to local and international regulatory standards like PSD2 for Europe, ensuring that payments are secure and compliant.</p>\n</li>\n</ul>\n<p>This setup allows Paysecure to offer a diverse range of bank transfer options to its global clientele, catering to the specific needs of different regions while maintaining a consistent and secure payment experience.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"type":"text/javascript","packages":{},"exec":[""],"id":"e8a74862-a410-4357-bcf9-5b53a60615f9"}},{"listen":"test","script":{"type":"text/javascript","packages":{},"exec":[""],"id":"69a2cb71-17fd-494c-a773-449c5d656c88"}}],"_postman_id":"530085f8-be2d-454b-9b38-f4eadbdc5771"},{"name":"🪙 On Ramp","item":[],"id":"a8c38c29-0e96-4de4-af92-fcd12c5acd63","description":"<h2 id=\"overview\">Overview</h2>\n<p>Paysecure provides a user-friendly, direct integration with Quickbit wallet where users can purchase and manage their crypto funds easily. Integrating this interface into your payment process is a straightforward process, requiring just a few simple steps.</p>\n<p>We continuously work on improving the integration flow, and as we roll out updates, both customers and merchants can look forward to an enhanced and improved payment experience.</p>\n<h2 id=\"integration-flow\">Integration Flow</h2>\n<p><strong>Step 1</strong></p>\n<p>The first call to the PaySecure API is POST /purchases initiated by the merchant's backend when they receive a request from the user to make a QuickBit purchase.</p>\n<p>It's essential to ensure that the request body includes:</p>\n<ul>\n<li><p>success_redirect - URL where the user will be redirected from Quickbit after completing the purchase</p>\n</li>\n<li><p>failure_redirect - URL where the user will be redirected from Quickbit if the purchase fails</p>\n</li>\n<li><p>paymentMethod - Payment method requested. It must specify QBPAYFTOPUP.</p>\n</li>\n</ul>\n<blockquote>\n<p>It is important to note that paymentMethod is not a mandatory parameter. If it is not provided, the redirect URL will point to Paysecure Cashier. It must be provided for direct payment with Quickbit. </p>\n</blockquote>\n<p>Here's a sample body of the request:</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"client\": {\n        \"email\": \"john.doe@paysecure.net\",\n        \"country\":\"GB\",\n        \"city\":\"London\",\n        \"stateCode\":\"Marleybone\",\n        \"street_address\":\"221B Baker Street\",\n        \"zip_code\":\"NW1 6XE\",\n        \"phone\":\"9999999999\"\n    },\n    \"purchase\": {\n        \"products\": [\n            {\n                \"name\": \"QBit Payment\",\n                \"price\": \"10\"\n            }\n        ]\n    },\n    \"status\": \"created\",\n    \"brand_id\": \"brand_id_from_the_portal\",\n    \"paymentMethod\":\"QBPAYFTOPUP\",\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\"\n}```\nIf the request is successful the response will include a parameter called CheckOutURL. That is the QBit payment URL that should be loaded to the customer to proceed with the payment. Here is an example of what a successful response looks like:\n```{\n    \"purchaseId\": \"657a10b3c0daf365fa98cdf9\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"john.doe@paysecure.net\",\n        \"phone\": \"9999999999\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"221B Baker Street\",\n        \"country\": \"GB\",\n        \"city\": \"London\",\n        \"zip_code\": \"NW1 6XE\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"Marleybone\"\n    },\n    \"updated_on\": 1702498483,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"QBPAYFTOPUP\",\n    \"amountUnit\": \"MINOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"POST\",\n    \"force_recurring\": false,\n    \"created_on\": 1702498483,\n    \"merchantRef\": \"657a10b3c0daf365fa98cdf9\",\n    \"merchantName\": \"merchant002\",\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"QBit Payment\",\n                \"quantity\": 1.0,\n                \"price\": 1000.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 10.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"brand1\",\n        \"brand_name\": \"brand1\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1702498483\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"brand_id_from_the_portal\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS185\",\n    \"issued\": \"2023-12-13\",\n    \"due\": 1702498483,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0.0,\n    \"success_redirect\": \"https://google.com\",\n    \"failure_redirect\": \"https://yahoo.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"135.129.121.137\",\n    \"checkout_url\": \"https://staging.paysecure.net/payments/657a10b3casd23123122/\",\n    \"merchantIp\": \"10.10.10.10\"\n}\n\n</code></pre>\n<h2 id=\"step-2\">Step 2</h2>\n<p>Once the customer is redirected to the <code>CheckOutURL</code> page they will see will depend on the user's country. For the users in Sweden, the page will look like this:</p>\n<img src=\"https://content.pstmn.io/9e0fe1c4-e8c6-49fd-8bc1-fb048e5f2278/aW1hZ2UucG5n\" width=\"792\" height=\"558\" />\n\n<p>For user's in other countries, the page will look following:</p>\n<img src=\"https://content.pstmn.io/20e4e789-4df1-4dd2-917f-7281db5dc09c/aW1hZ2UucG5n\" width=\"599\" height=\"602\" />\n\n<p>On this page, new users will have to verify their identity and existing users will be prompted to log in.</p>\n<h2 id=\"step-3\">Step 3</h2>\n<p>In the Quickbit app, the user will be requested to provide their payment details:</p>\n<img src=\"https://content.pstmn.io/bc760861-a7af-4cca-a6a4-9c8e6a80db28/aW1hZ2UucG5n\" width=\"1341\" height=\"666\" />\n\n<p>Once the payment goes through, the user has to confirm sending the transaction to complete the process:</p>\n<img src=\"https://content.pstmn.io/ddc57da0-d77d-4819-a059-0eb1def02593/aW1hZ2UucG5n\" width=\"1340\" height=\"662\" />\n\n<h2 id=\"step-4\">Step 4</h2>\n<p>Depending on the outcome of the payment at Quickbit, the customer will be directed to the:</p>\n<ol>\n<li><p>If the payment is successful - the URL specified in <code>success_redirect</code> that was provided in the initial <code>POST /purchases</code> request</p>\n</li>\n<li><p>If the payment is unsuccessful - the URL specified in <code>failure_redirect</code> that was provided in the initial <code>POST /purchases</code> request</p>\n</li>\n</ol>\n","_postman_id":"a8c38c29-0e96-4de4-af92-fcd12c5acd63"},{"name":"3rd Party Cashiers","item":[{"name":"ThirdParty UPI","item":[{"name":"Concepts","item":[],"id":"dc3758e7-8e23-4e12-84e8-43909420bb5c","description":"<h2 id=\"concepts\">Concepts</h2>\n<ul>\n<li><p><strong>APM Integration:</strong> Merchants integrate with set of Paysecure APIs to manage both incoming (pay-ins) and outgoing (payouts) funds.</p>\n</li>\n<li><p><strong>Asynchronous Communication:</strong> Both payin and payout flows use callback URLs and webhooks to confirm transaction statuses, ensuring the merchant system stays updated.</p>\n</li>\n<li><p><strong>Secure Redirection:</strong> Customers are securely redirected from the merchant site to the 3rd-party's cashier page for payments and back to the merchant site upon completion.</p>\n</li>\n<li><p><strong>UPI Payment Options:</strong> The integration supports UPI-based payments, presenting customers with choices, like UPI Dynamic QR and UPI intevent via VPA, during the checkout process.</p>\n</li>\n<li><p><strong>Beneficiary Details:</strong> For payouts, essential beneficiary details, including the Virtual Payment Address (VPA), must be provided to correctly route funds.</p>\n</li>\n</ul>\n<hr />\n<h2 id=\"key-steps-in-the-integration-process\">Key Steps in the Integration Process</h2>\n<h3 id=\"payin-flow\">PayIn Flow</h3>\n<ol>\n<li><p><strong>Customer Selection:</strong><br /> The customer selects UPI as the payment method on the merchant’s website.</p>\n</li>\n<li><p><strong>API Call to Create Purchase:</strong><br /> The merchant system calls the Paysecure <code>createPurchase</code> API to initiate the transaction.</p>\n</li>\n<li><p><strong>Redirection to Third-Party Cashier Page:</strong><br /> The customer is redirected to 3rd-party's cashier page using the provided checkout URL.</p>\n</li>\n<li><p><strong>Payment Options Display:</strong><br /> On the cashier page, the customer is presented with multiple UPI payment options, such as:</p>\n<ul>\n<li><p>UPI Dynamic QR</p>\n</li>\n<li><p>UPI Intent (via VPA)</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Transaction Execution:</strong><br /> The customer completes the payment using their UPI app.</p>\n</li>\n<li><p><strong>Callback &amp; Confirmation:</strong><br /> Upon a successful payment, success callback is sent to the merchant’s designated URL. The customer is then redirected back to the merchant’s checkout page, where they see confirmation of a successful payment and an updated balance.</p>\n</li>\n</ol>\n<h3 id=\"payout-flow\">Payout Flow</h3>\n<ol>\n<li><p><strong>Payout Request Initiation:</strong><br /> The customer initiates a payout request directly on the merchant’s website.</p>\n</li>\n<li><p><strong>Beneficiary Details Entry:</strong><br /> The customer enters the Virtual Payment Address (VPA) where they wish to receive the payout.</p>\n</li>\n<li><p><strong>API Call to Process Payout:</strong><br /> The merchant calls the payout API to process the request.</p>\n<ul>\n<li><p><strong>Input:</strong> Payout amount, beneficiary details (including VPA), and other required parameters.</p>\n</li>\n<li><p><strong>Callback:</strong> A callback URL is set up to receive asynchronous updates.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Payout Execution:</strong><br /> Payout is processed to the customer’s specified VPA.</p>\n</li>\n<li><p><strong>Webhook Notification:</strong><br /> A success webhook is triggered upon the successful completion of the payout.</p>\n</li>\n<li><p><strong>Balance Update:</strong><br /> Both the customer’s and merchant’s account balances are updated to reflect the transaction.</p>\n</li>\n</ol>\n","_postman_id":"dc3758e7-8e23-4e12-84e8-43909420bb5c"},{"name":"Payin","item":[{"name":"Create Purchase","id":"2fd6ee71-2fac-4d79-aee3-480cdb9f7b89","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"ziangani@outlook.com\",\r\n        \"street_address\": \"Mansarovar, Jaipur\",\r\n        \"city\": \"Jaipur\",\r\n        \"full_name\": \"Adarsh Saini\",\r\n        \"zip_code\": \"101100\",\r\n        \"country\": \"IN\",\r\n        \"date_of_birth\": \"1977-05-10\",\r\n        \"stateCode\": \"NA\",\r\n        \"phone\": \"0964926646\"\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"INR\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"price\": 1\r\n            }\r\n        ]\r\n    },\r\n    \"paymentMethod\": \"THIRDPARTY-UPI\",\r\n    \"brand_id\": \"{brand_id}\",\r\n    \"success_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=true\",\r\n    \"pending_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=pending\",\r\n    \"failure_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=false\",\r\n    \"success_callback\": \"https://staging.paysecure.net\",\r\n    \"failure_callback\": \"https://staging.paysecure.net\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/","description":"<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td></td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. It must be upper case.  <br />This should be \"IN\" for India</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”.. Must be in upper case.</td>\n</tr>\n<tr>\n<td>client.street_address</td>\n<td></td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td></td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />INR 5 , should be sent as 10.00</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is UNSUCCESSFUL</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"optional-parameters\">Optional Parameters</h2>\n<h3 id=\"expireinmin\">expireInMin</h3>\n<p>This parameter, when passed in the PayIn request, sets the time window within which a customer should make the Interac payment through their bank's app. If a customer doesn't complete the payment within the configured time window, the status of the payment will be marked as 'EXPIRED' in Paysecure.</p>\n<p>However, in certain cases, a payment made outside of this window could still be successful i.e. customer's account may be debited which would result in inconsistencies among Paysecure's, merchant's and customer's status of the transaction. To avoid such cases it is advised to set the expiry time limit appropriately and advise the customers to make payment within this window. However, if there is an inconsistency between the status at Paysecure and at customer's Bank, the merchant and Paysecure will reconcile the amounts during the settlement.</p>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Invalid format of Date_of_Birth[allowed format: yyyy-mm-dd]</td>\n<td></td>\n</tr>\n<tr>\n<td>Enter Valid Email</td>\n<td></td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n<td></td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n<td></td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect/failure_redirect/brand_id is missing</td>\n<td></td>\n</tr>\n<tr>\n<td>brand_id cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>success_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>failure_redirect cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>Invalid failure_redirect: minimum 10 characters</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products.price cannot be null</td>\n<td></td>\n</tr>\n<tr>\n<td>purchase.products[0].name/purchase.products[0].price are missing</td>\n<td></td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n<td></td>\n</tr>\n<tr>\n<td>Currency \"{curr_name}\" is Not Allowed</td>\n<td></td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n<td></td>\n</tr>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n<td></td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong> For certain use cases, in addition to long format purchase Id, Paysecure also provides a 7 digit unique code for each purchase starting with digit 4, eg 4000001</p>\n<p><em>“purchaseIdShortCode”: “4000013\"</em></p>\n","urlObject":{"path":["purchases",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[],"_postman_id":"2fd6ee71-2fac-4d79-aee3-480cdb9f7b89"},{"name":"Get Status","id":"bc90df10-0abd-4141-ab96-11d50ac29397","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a purchase (PayIn), including its history</p>\n<p><strong>Note:</strong> With respect to bank transfers, the purchase request is synonymous with the PayIn request.</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payment_in_process</td>\n<td>Payment is under Processing</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"5db195bb-9c71-4677-88a8-d071584a9b97","name":"Purchases-success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"66c4667bb993c970367c288a\",\n    \"client\": {\n        \"email\": \"deepakdeepaksinghal@gmail.com\",\n        \"date_of_birth\": \"1970-07-10\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"country\": \"IN\",\n        \"city\": \"London\",\n        \"zip_code\": \"W1S 3BE\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"QLD\"\n    },\n    \"updated_on\": 1724147324,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"UPI\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"redirectType\": \"POST\",\n    \"force_recurring\": false,\n    \"created_on\": 1724147324,\n    \"merchantRef\": \"66c4667bb993c970367c288a\",\n    \"merchantName\": \"merchant002\",\n    \"purchase\": {\n        \"currency\": \"INR\",\n        \"products\": [\n            {\n                \"name\": \"test\",\n                \"quantity\": 1,\n                \"price\": 10,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 10,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"expireInMin\": \"35\",\n        \"request_client_details\": [],\n        \"timezone\": \"MIT\",\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 10,\n        \"currency\": \"INR\",\n        \"net_amount\": 10,\n        \"fee_amount\": 0,\n        \"pending_amount\": 0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1724147324,\n        \"remote_paid_on\": 1724147324\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"test6\",\n        \"brand_name\": \"test6\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"amount\": 10,\n            \"masked_pan\": \"UPI\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"103.59.75.113\",\n                \"type\": \"execute\",\n                \"payment_method\": \"UPI\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"UPI\",\n                \"processing_time\": 1724147324,\n                \"extra\": {\n                    \"amount\": 10,\n                    \"masked_pan\": \"UPI\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAYMENT_IN_PROCESS\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1724147324\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1724147324\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1724147324\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"c4003b2c-22d4-4dc1-ad0c-c6b54f8c9636\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS10907\",\n    \"issued\": \"2024-08-20\",\n    \"due\": 1724147324,\n    \"refund_upto\": 1725871728,\n    \"cc_descriptor\": \"test1\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"payInDetails\": {\n        \"qrCode\": \"iVBORw0KGgoAAAANSUhEUgAAAb0AAAG9AQAAAACpVZXpAAAH7UlEQVR4nO1cQY7qSgw0yiJLjpCbJBdDIhIXg5vkCCyzQPi7qtwkM2/zNcsYpIfeQFcvTNtdLtsx/9trtS/wC/wCv8A/AZ9mdnpevb9bt6zj+TWso3Uen17i33nGkgverotN/orP7FoHeHV/AG1nfnoZ+kfYrcdKv8ei/gEMvljxRkQZ4MVi5Ww2nm9LbBF/xnLYd7YVVu3dZ262hPUvA3+CUsCnDesJ39/PHhidtlg5cRFek9+WtSgwPO595ldGI4dTAohX/8ZpG2Hp8MdiQPnjEL7XIWJdEae6BfvgC0SxCGCx2Q2fvf5x5GMDGckRov7X2+8r4NhAvW6O82QrHBBeuGBHHjSHK7rDtDxtv8jD0YERv8PPwAHcRjogbv43/BF/wuZwytgHO9r4serxgbIg7vvzPNALY1GHzXDrwYJji2JgTsvOkY8PxGnDDYeVsPHcYjWoUtx6jF04cjPsa8PmjxWAroMWUbtbdPPHPuGZsOqdX8SfOJXGu26zagVgLILHraTWvOUDjRuuU4jq4a2xj8y9hLd6HaArFcMtD997gVoHJYCRwa8H2HzgWVxBDkoBxR5lraVHxIpgdWXEcjJKHrmw+S2Z071F8gLA+JSGCkwEbISoOFnJHiNtvSAhgc0RpyKmw/BeBqgUFUcJGIPWAZnjY1VXis+bUMdw93McHph0kXedfA/pBfMx5CKLlJCJ9n3+FEkOD1QSiuUyrSWaQfyuc0eS3UElm+m8ZYDNqrCbkQMgMMGWEcCQhdEB6a1Jsps/VgCGybASWTtOFu1Lz8SlD/lsgheepBXFupaUFQEiC4MXzozaRjYQrnhRAksioORDbx8doAAQkfwM3qzrP4MVI3lwRqeEOEgTgc37eyVg5zxFZNAuboR0HlkY5VZdbszbELtk6SpAk/DV44yBB2H5zFSWgR3KPAkSKIHZT3nt6EA4INgPmKJRim/1L1MljKI8zS0NbSwElG5qrX6DwsQkDQh5Kr91prI3V4jfqHUBYKfKH9jPQPbDCpchTkmop/xzgiYi9dULASm2863TQeuxGYuDYVUzmtFOm3tuxaDjA+Fi0AehAZFB0zOpfxikD4Uo7YOw9SFIBYAqkN4UyRnY4ZnNFWnfVlpX7WeTEI8PBGWepDvLZCDPopBZOQVVgj+CCNwaaaoBxP8p/zDloN5jZI/sQABGeYe7ctftyBUAPpmmozqBpAyZ/ArxmXmqfJTqIZVWbLGJJBWAtCXqN8rCqIN1rqh9N0qIs84dGzU2raMAkPEbJjMWt85atJg1fZXZhm7CURyqDvCpWpejnUci4QrxmWSSVQwqRGwT47qdEFQBOPCWpxeCPBulsl55KiyIOM96hiLWw+sAndSQB+1KqQxnjEBmIC+xb2NNjFnJp95RASjimEViKtAiTWoEM1bf1YHK2vKOPR4fiJuLyrIZuk0hNOP6Z9McsxJk8gsJEm44sYEqQHaghvF4fQk9ch+9MXR3aOdRJA9KsJVKDw9k1FbDE1WyiOkUghiwSQlQycmyz5mCRyWgZxAyFU2dJJvxm59RsgerlmS/XXMFgOzfYU3H1OFuSlaRnq288JyuyL5dhLJPB0IBIBa9mbCrOYxaqkqlqPwhlcU1B89Ud/wnklcABjdCmi4dEcoyo1Nrt2yVsDGrGGpqrgNUqY8siQblQXMeOcZv6Ijr1LpYdjWd4wM9h2yYcanE02gRxY3WmSHSxBKP1wFK4NFVz0i0jZUwO2Viz3PHA7nrfD4+8MlRLCRl4NITs42WxPdZxKGQdpXSah/aWQDo5IcJVB2ZhBrHi0UcmjY7eH/8HAWAraaTxMfSAU1ah9E9L8pAVD6tBGQnt/h1bMFGg3fLMdjUwvaMNfMOzCJtR+7wQPWucKBmZjjnV61DjJtxXkJpiO1qOhWAOV/TYhKcUpM2F91rxqGJVrHYdXcXAPIA5dDsIPXwnUZWOxRpgrMjEzORW8GrAnDO4tbE8QnORrCfBeeOMvSk3h/LLR6FgNtIIyui1OglaTAhYXNYamicufGdIx8eqFz9ZTkMYWy8dA1vqRp4Ir/2WcLINlBQAPgkIWQQz0c8OFvlkl8zA5lzGAeHz9+FgO6ii+y9QCRSowHdTtH9xOZTjWBn6asKUK2VvtBaUuFH+R62oAZkObLfKzM71wHCqhyVaFPpIs/emndV+mLfBmtivv85Dg9kAwajE+K3kg8lpq3YA0dlY48GAM+FgDklq7wDoVtUaVT/e/YdJDdiUcPrAHmeFJhemkBKMunZ/y6nZDeYGMKmzB8eCBshHW1T6VhuqdabzmI+P2Tpm1OWAWoei88uSBV+o9G7eimfN4O0f9e/enyg9PgL5Xk9tqDP9OKmKilbCNU0dxL6Wgr4aOlo/yGOagQ7yeZqwYRnXndlxArAnNHfRvbzXlML5ktJmWdij2rgsxAQVlVJMF2xaUCcGuUH6n9SpX3f9XR8IF7qQIiTlUWcznXf5/CRZfflqIGuaxkgDEVqaOyX4+VmnNvic2SyTCi5VRWfdgVUAF5dUVtj6KrpwL545dMX7TNg/LMaeHygnr7YxNM2JcEvVOLJrISKolk9oPpxW7ep+JJodLJqnkpN9Vs1IFxsarqzpLKHsrUXGaW1+vrFfj3w8+BA+iOHA1omrxbCJ9F67IP2oUK04+QFgC2Sq8U7x5CGTyVsaL3LLjIp9ywC/NPrC/wCv8Av8C/A/wCpreUSrYyOqQAAAABJRU5ErkJggg==\",\n        \"gpayUri\": \"gpay://upi/pay?ver=01&mode=15&am=5.00&mam=1.00&cu=INR&pa=npstpay@timecosmos&pn=NPST%20PAY&mc=6012&tr=NPST040120220010&tn=QR%20SIT%20testing&mid=NPSTPAY001&msid=NPSTPAY001-001&mtid=NPSTPAY001-001&category=02&url=http://google.com\",\n        \"phonepeUri\": \"phonepe://pay?ver=01&mode=15&am=5.00&mam=1.00&cu=INR&pa=npstpay@timecosmos&pn=NPST%20PAY&mc=6012&tr=NPST040120220010&tn=QR%20SIT%20testing&mid=NPSTPAY001&msid=NPSTPAY001-001&mtid=NPSTPAY001-001&category=02&url=http://google.com\",\n        \"paytmUri\": \"paytmmp://pay?ver=01&mode=15&am=5.00&mam=1.00&cu=INR&pa=npstpay@timecosmos&pn=NPST%20PAY&mc=6012&tr=NPST040120220010&tn=QR%20SIT%20testing&mid=NPSTPAY001&msid=NPSTPAY001-001&mtid=NPSTPAY001-001&category=02&url=http://google.com\",\n        \"generatedLink\": \"https://staging.decf.in/pay/514o5z3m9z\"\n    },\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 10,\n    \"success_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=true\",\n    \"failure_redirect\": \"https://staging.paysecure.net/getResponse.jsp?success=false\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://staging.paysecure.net\",\n    \"failure_callback\": \"https://staging.paysecure.net\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"103.59.75.113\",\n    \"checkout_url\": \"https://staging.paysecure.net/payments/66c4667bb993c970367c288a/\",\n    \"payoutProcess\": false\n}"},{"id":"40b063cd-4299-4d6a-a073-a81e6063c918","name":"Purchases","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Error Message\",\n    \"code\": \"error_code\"\n}"}],"_postman_id":"bc90df10-0abd-4141-ab96-11d50ac29397"}],"id":"0400d8ef-9edf-42c4-86c6-104dad3fe7ec","description":"<h3 id=\"payin-api-flow\">PayIn API Flow</h3>\n<ol>\n<li><p><strong>Initiation:</strong></p>\n<ol>\n<li><p>Merchant system calls paysecure <code>Purchases</code> API.</p>\n</li>\n<li><p><strong>Response:</strong> Returns a checkout URL and initiates a callback URL.</p>\n</li>\n</ol>\n</li>\n<li><p><strong>Redirection:</strong></p>\n<ol>\n<li>Customer is redirected to the cashier page.</li>\n</ol>\n</li>\n<li><p><strong>Payment Method Selection:</strong></p>\n<ol>\n<li>The cashier page displays options such as UPI Dynamic QR and UPI ID.</li>\n</ol>\n</li>\n<li><p><strong>Transaction Processing:</strong></p>\n<ol>\n<li>Customer completes the payment using a UPI app.</li>\n</ol>\n</li>\n<li><p><strong>Success Callback:</strong></p>\n<ol>\n<li>On successful payment, a scuccess wehook is triggered</li>\n</ol>\n</li>\n<li><p><strong>Finalization:</strong></p>\n<ol>\n<li>Customer is redirected back to the merchant site where the transaction status is displayed and the balance is updated.</li>\n</ol>\n</li>\n</ol>\n","_postman_id":"0400d8ef-9edf-42c4-86c6-104dad3fe7ec"},{"name":"Payout","item":[{"name":"Create PayOut","id":"a59f629c-ed9c-4879-a15f-417d33703f4c","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"yogesh@gmail.com\",\r\n        \"country\": \"CA\",\r\n        \"phone\": \"766225230591\",\r\n        \"full_name\": \"Test Person-uk\"\r\n    },\r\n    \"beneficiaryDetail\": {\r\n        \"upi\": \"alpha@bravo\"\r\n    },\r\n    \"purpose\": \"test payout\",\r\n    \"currency\": \"INR\",\r\n    \"payoutMethod\": \"PAYOUT-THIRDPARTY-UPI\",\r\n    \"amount\": 10,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<p>To Initiate a payment, the very first call to make is <code>/payout/</code> with the required data in the request body.</p>\n<p>To generate a Payout, you are required to provide the <code>API key</code> (in the header) can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a Payout request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.full_name</td>\n<td>An Identifier for a user</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td></td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>PAYOUT-THIRDPARTY-UPI</td>\n</tr>\n<tr>\n<td>beneficiaryDetail.upi</td>\n<td>VPA (UPI ID)</td>\n</tr>\n<tr>\n<td>Currency</td>\n<td>Note this is currency account for which you have balance</td>\n</tr>\n<tr>\n<td>Amount</td>\n<td>Amount in Currency</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>Purpose of the payment</td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[{"disabled":true,"key":"","value":null},{"disabled":true,"key":null,"value":""}],"variable":[]}},"response":[],"_postman_id":"a59f629c-ed9c-4879-a15f-417d33703f4c"},{"name":"Get Status","id":"59071608-6b3c-4c21-8157-3dad60b3a776","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/","description":"<p>This API tells you about all the details of a Payout, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the payoutId in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payout_in_process</td>\n<td>payout is under Processing.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><p>The webhook will only be triggered for paid transactions or errors.</p>\n<p>Paid: \"success_callback\": \"<a href=\"https://success.com\">https://success.com</a>\",</p>\n<p>Error: \"failure_callback\": “<a href=\"https://failure.com%E2%80%9D\">https://failure.com”</a></p>\n","urlObject":{"path":["getpayout","{payoutId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"1fad7407-d8b4-48ed-b46b-8955b50bb570","name":"Get success Status","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"payoutId\": \"66838ae86d41e41c10a8656d\",\r\n    \"client\": {\r\n        \"email\": \"Yogesh@gmail.com\",\r\n        \"phone\": \"766533230591\",\r\n        \"full_name\": \"Test Person-uk\",\r\n        \"country\": \"CA\"\r\n    },\r\n    \"updated_on\": 1719896808,\r\n    \"payoutMethod\": \"PAYOUT-UPI\",\r\n    \"beneficiaryDetail\": {\r\n        \"upi\": \"charles.babbage@okhdfc\",\r\n        \"transferType\": \"UPI\"\r\n    },\r\n    \"amountUnit\": \"MAJOR\",\r\n    \"amount\": 10.0,\r\n    \"errorMsg\": \"\",\r\n    \"purpose\": \"test payout\",\r\n    \"created_on\": 1719896808,\r\n    \"merchantRef\": \"66838ae86d41e41c10a8656d\",\r\n    \"merchantName\": \"newMerchant777\",\r\n    \"status\": \"PAYOUT_IN_PROCESS\",\r\n    \"status_history\": [\r\n        {\r\n            \"status\": \"created\",\r\n            \"timestamp\": 1719896808\r\n        },\r\n        {\r\n            \"status\": \"payout_in_process\",\r\n            \"timestamp\": 1719896810\r\n        },\r\n        {\r\n            \"status\": \"viewed\",\r\n            \"timestamp\": 1719900796\r\n        }\r\n    ],\r\n    \"viewedOn\": 1719900796,\r\n    \"currency\": \"INR\",\r\n    \"paymentOn\": 0,\r\n    \"success_callback\": \"https://success.com\",\r\n    \"failure_callback\": \"https://failure.com\"\r\n}\r\n"},{"id":"315f78c8-ca23-4fa1-893e-11f047382428","name":"Get Error Status","originalRequest":{"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/getpayout/{payoutId}/"},"_postman_previewlanguage":"Text","header":[],"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Error Message\",\r\n    \"code\": \"error_code\"\r\n}"}],"_postman_id":"59071608-6b3c-4c21-8157-3dad60b3a776"}],"id":"931819da-077a-4579-8888-95934b1edf80","description":"<h3 id=\"payout-api-flow\">Payout API Flow</h3>\n<ol>\n<li><p><strong>Customer Action:</strong></p>\n<ul>\n<li>Customer initiates a payout request on the merchant site and inputs their VPA.</li>\n</ul>\n</li>\n<li><p><strong>Initiation:</strong></p>\n<ul>\n<li><p>Merchant system calls its payout API.</p>\n</li>\n<li><p><strong>Input Data:</strong> Includes payout amount, beneficiary details (with VPA), and callback URL.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Processing:</strong></p>\n<ul>\n<li>The payout request is processed.</li>\n</ul>\n</li>\n<li><p><strong>Webhook Notification:</strong></p>\n<ul>\n<li>Upon successful payout, merchant receives a success webhook.</li>\n</ul>\n</li>\n<li><p><strong>Finalization:</strong></p>\n<ul>\n<li>Merchant system updates both customer and merchant balances accordingly.</li>\n</ul>\n</li>\n</ol>\n","_postman_id":"931819da-077a-4579-8888-95934b1edf80"}],"id":"9b80d8e4-0c86-4bfc-a301-ad7c1edd01b3","description":"<p>This is a versatile payment solution that supports both pay-ins (customer payments) and payouts (customer withdrawals) primarily using UPI-based transactions. This integration enables merchants to provide seamless payment experiences on their platforms, offering multiple UPI payment options such as UPI Dynamic QR and UPI Intent (via VPA) payments. The integration leverages asynchronous callbacks and webhooks to ensure real-time transaction status updates and balance synchronization.</p>\n","_postman_id":"9b80d8e4-0c86-4bfc-a301-ad7c1edd01b3"}],"id":"15b03d02-3041-4381-b1d6-6a8c16352419","_postman_id":"15b03d02-3041-4381-b1d6-6a8c16352419","description":""}],"id":"0fe88ad2-34f9-4ff4-9ad7-55c35e39e514","_postman_id":"0fe88ad2-34f9-4ff4-9ad7-55c35e39e514","description":""},{"name":"Trust Score","item":[{"name":"TrustScore Detailed","id":"35ab4812-eb0b-466a-a362-8f3457c13353","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n    \"requiredinput\": {\r\n        \"ip\": \"111.11.11.11\",\r\n        \"email\": \"test@gmail.com\",\r\n        \"url\": \"https://www.asos.com/\"\r\n    },\r\n    \"optionalInput\": {\r\n        \"last_bets\": null,\r\n        \"last_wins\": \"\",\r\n        \"total_bonuses\": \"\",\r\n        \"last_real_bets\": \"\",\r\n        \"last_real_wins\": \"\",\r\n        \"total_deposits\": \"\",\r\n        \"last_bonus_bets\": \"\",\r\n        \"last_bonus_wins\": \"\",\r\n        \"average_real_bet\": \"\",\r\n        \"last_bets_amount\": \"\",\r\n        \"last_wins_amount\": \"\",\r\n        \"average_bonus_bet\": \"\",\r\n        \"bonus_to_deposits\": \"\",\r\n        \"last_deposit_date\": \"\",\r\n        \"total_withdrawals\": \"\",\r\n        \"is_phone_confirmed\": \"\",\r\n        \"money_in_money_out\": \"\",\r\n        \"last_deposit_amount\": \"\",\r\n        \"last_freespins_date\": \"\",\r\n        \"last_freespins_name\": \"\",\r\n        \"last_free_bonus_date\": \"\",\r\n        \"last_free_bonus_name\": \"\",\r\n        \"total_bonuses_amount\": \"\",\r\n        \"last_freespins_amount\": \"\",\r\n        \"last_freespins_status\": \"\",\r\n        \"last_real_bets_amount\": \"\",\r\n        \"last_real_wins_amount\": \"\",\r\n        \"total_deposits_amount\": \"\",\r\n        \"last_bonus_bets_amount\": \"\",\r\n        \"last_bonus_wins_amount\": \"\",\r\n        \"last_free_bonus_amount\": \"\",\r\n        \"last_free_bonus_status\": \"\",\r\n        \"last_deposit_bonus_date\": \"\",\r\n        \"last_deposit_bonus_name\": \"\",\r\n        \"last_freespins_currency\": \"\",\r\n        \"last_freespins_wagering\": \"\",\r\n        \"withdrawals_to_deposits\": \"\",\r\n        \"last_free_bonus_currency\": \"\",\r\n        \"last_free_bonus_wagering\": \"\",\r\n        \"total_withdrawals_amount\": \"\",\r\n        \"withdrawal_ewallet_email\": \"\",\r\n        \"last_deposit_bonus_amount\": \"\",\r\n        \"last_deposit_bonus_status\": \"\",\r\n        \"last_deposit_bonus_currency\": \"\",\r\n        \"last_deposit_bonus_wagering\": \"\",\r\n        \"session\": \"\",\r\n        \"payment_mode\": \"\",\r\n        \"card_fullname\": \"\",\r\n        \"card_bin\": \"\",\r\n        \"card_hash\": \"\",\r\n        \"card_last\": \"\",\r\n        \"card_expire\": \"\",\r\n        \"avs_result\": \"\",\r\n        \"cvv_result\": \"\",\r\n        \"sca_method\": \"\",\r\n        \"user_bank_account\": \"\",\r\n        \"user_bank_name\": \"\",\r\n        \"user_balance\": \"\",\r\n        \"user_verification_level\": \"\",\r\n        \"status_3d\": \"\",\r\n        \"regulation\": \"\",\r\n        \"payment_provider\": \"\",\r\n        \"phone_number\": \"\",\r\n        \"transaction_type\": \"\",\r\n        \"transaction_amount\": \"\",\r\n        \"transaction_currency\": \"\",\r\n        \"merchant_id\": \"\",\r\n        \"details_url\": \"\",\r\n        \"name\": \"\",\r\n        \"person_type\": \"\",\r\n        \"gender\": \"\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/trustScore","description":"<h3 id=\"overview\">Overview</h3>\n<p>Paysecure TrustScore's proprietary API combines email, phone number, IP and URL so that you can request and receive a user trust score from our enriched data, rules, and scoring in a single API call.</p>\n<p>Our take on Trust is different from the usual approach to fraud. This API tells you how much you can trust this user. It’s based on 100+ data points to which we have access. We use complex algorithms based on data sanity and customer behaviour in our partner network.</p>\n<p>Also, the additional optional parameter would be used to boost the accuracy of our response. So the more data we get the better we can ascertain the users' trust. So please endeavour to send as much information about the user as possible.</p>\n<h3 id=\"trust-score--usage\"><strong>Trust Score &amp; Usage</strong></h3>\n<p>TrustScore offers two distinct endpoints: <code>General</code> and <code>Detailed</code>.</p>\n<p>The General endpoint provides basic information by indicating whether a transaction is permitted or not. It gives a simple 'yes' or 'no' response regarding whether the transaction can proceed.</p>\n<p>On the other hand, the Detailed endpoint offers a more comprehensive evaluation. It furnishes an in-depth analysis of the transaction's authenticity, providing a detailed assessment beyond a simple allowance or denial, offering nuanced insights and information about the transaction's legitimacy.</p>\n<h3 id=\"detailed-trustscore\">Detailed TrustScore</h3>\n<p>Trust scores range from 0 to 5. A trust score of 0 indicates that we have limited information about the user, and it corresponds to the lowest level of trust. In addition to the TrustScore, we offer eight other flags to help assess the user's overall profile and determine appropriate actions to take. We suggest flagging or blocking users, transactions, or clicks as high risk based on a combination of the following factors: email deliverability, proxy usage, VPN usage, Tor usage, and recent abusive behavior.</p>\n<p>Every company has a unique target audience, so you might achieve better results by only flagging or blocking entities with low trust scores and recent instances of abuse. Keep in mind that mobile IP addresses are frequently misused and recycled by mobile carriers. Therefore, for mobile lookups, we advise giving more weight to the trust score, VPN usage, and Tor usage, as opposed to proxy usage.</p>\n<h3 id=\"permission\"><strong>Permission</strong></h3>\n<p>Access to this API has to be given to you by the admin. So please contact your sales representative at PaySecure to get access to this API, if you get a 401 error of \"You are not allowed to call this API service\".</p>\n<h3 id=\"mandatory-parameters-in-body\">Mandatory Parameters (in body)</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameters</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>ip</td>\n<td>IP of the user. Both IP4 and IP6 are valid</td>\n</tr>\n<tr>\n<td>email</td>\n<td>The email id of the user you want to trust score on</td>\n</tr>\n<tr>\n<td>url</td>\n<td>The URL on which the user is trying to purchase or consume a product, service or data.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"other-optional-paramters\">Other optional paramters:</h3>\n<p>The optional parameters are self-explanatory and appropriate values can be given in string format.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameters</strong></th>\n<th><strong>Values</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>last_bets</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_wins</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_bonuses</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_real_bets</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_real_wins</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_deposits</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bonus_bets</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bonus_wins</td>\n<td>String</td>\n</tr>\n<tr>\n<td>average_real_bet</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bets_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_wins_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>average_bonus_bet</td>\n<td>String</td>\n</tr>\n<tr>\n<td>bonus_to_deposits</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_date</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_withdrawals</td>\n<td>String</td>\n</tr>\n<tr>\n<td>is_phone_confirmed</td>\n<td>String</td>\n</tr>\n<tr>\n<td>money_in_money_out</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_date</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_date</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_bonuses_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_status</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_real_bets_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_real_wins_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_deposits_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bonus_bets_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bonus_wins_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_status</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_date</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_currency</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_wagering</td>\n<td>String</td>\n</tr>\n<tr>\n<td>withdrawals_to_deposits</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_currency</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_wagering</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_withdrawals_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>withdrawal_ewallet_email</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_status</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_currency</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_wagering</td>\n<td>String</td>\n</tr>\n<tr>\n<td>session</td>\n<td>String</td>\n</tr>\n<tr>\n<td>payment_mode</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_fullname</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_bin</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_hash</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_last</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_expire</td>\n<td>String</td>\n</tr>\n<tr>\n<td>avs_result</td>\n<td>String</td>\n</tr>\n<tr>\n<td>cvv_result</td>\n<td>String</td>\n</tr>\n<tr>\n<td>sca_method</td>\n<td>String</td>\n</tr>\n<tr>\n<td>user_bank_account</td>\n<td>String</td>\n</tr>\n<tr>\n<td>user_bank_name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>user_balance</td>\n<td>String</td>\n</tr>\n<tr>\n<td>user_verification_level</td>\n<td>String</td>\n</tr>\n<tr>\n<td>status_3d</td>\n<td>String</td>\n</tr>\n<tr>\n<td>regulation</td>\n<td>String</td>\n</tr>\n<tr>\n<td>payment_provider</td>\n<td>String</td>\n</tr>\n<tr>\n<td>phone_number</td>\n<td>String</td>\n</tr>\n<tr>\n<td>transaction_type</td>\n<td>String</td>\n</tr>\n<tr>\n<td>transaction_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>transaction_currency</td>\n<td>String</td>\n</tr>\n<tr>\n<td>merchant_id</td>\n<td>String</td>\n</tr>\n<tr>\n<td>details_url</td>\n<td>String</td>\n</tr>\n<tr>\n<td>name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>person_type</td>\n<td>String</td>\n</tr>\n<tr>\n<td>gender</td>\n<td>String</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response\">Response</h3>\n<p>In the response examples, you can observe both instances of a successful TrustScore response and an unsuccessful one.</p>\n<p>Please note that there are a lot of parameters to determine the trust level and give you some additional details on the email and IP of the user.</p>\n<p>in a successful trust score call the following data would be provided:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Response Item</strong></th>\n<th><strong>Description</strong></th>\n<th><strong>Possible Values</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>trustScore</td>\n<td>The trust score attributed to the user by our algorithms</td>\n<td>Integer 0 to 5</td>\n</tr>\n<tr>\n<td>deliverable</td>\n<td>Whether the email is deliverable, usually false means it wouldn't be a trustable user.</td>\n<td><strong>Boolean</strong></td>\n</tr>\n<tr>\n<td>proxy</td>\n<td>Is this IP address suspected to be a proxy? (SOCKS, Elite, Anonymous, VPN, Tor, etc.)</td>\n<td><strong>Boolean</strong></td>\n</tr>\n<tr>\n<td>vpn</td>\n<td>Is this IP suspected of being a VPN connection? This can include data center ranges which can become active VPNs at any time. The \"proxy\" status will always be true when this value is true.</td>\n<td><strong>Boolean</strong></td>\n</tr>\n<tr>\n<td>tor</td>\n<td>Is this IP suspected of being a TOR connection? This can include previously active TOR nodes and exits which can become active TOR exits at any time. The \"proxy\" status will always be true when this value is true.</td>\n<td><strong>Boolean</strong></td>\n</tr>\n<tr>\n<td>active_vpn</td>\n<td>Identifies active VPN connections used by popular VPN services and private VPN servers.</td>\n<td><strong>Boolean</strong></td>\n</tr>\n<tr>\n<td>active_tor</td>\n<td>Identifies active TOR exits on the TOR network.</td>\n<td><strong>Boolean</strong></td>\n</tr>\n<tr>\n<td>recent_abuse</td>\n<td>This value indicates whether the IP address has been associated with any recently verified abuse on our network, such as a confirmed chargeback, compromised device, or fake app install.</td>\n<td><strong>Boolean</strong></td>\n</tr>\n<tr>\n<td>bot_status</td>\n<td>Shows whether bots or non-human traffic recently used this IP address to engage in automated fraud. This provides strong evidence that the IP address is suspicious.</td>\n<td><strong>Boolean</strong></td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<p>the possible error codes one can get on calling this APIs are:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Code</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>400, 404, 401, 415, 405</td>\n</tr>\n</tbody>\n</table>\n</div><p>for example:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Code</strong></th>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>401</td>\n<td>Incorrect secret_key</td>\n</tr>\n<tr>\n<td>401</td>\n<td>You are not Allowed to call this API service</td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"path":["trustScore"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"fb8d87ea-5a7d-44d1-a881-f09e32d796de","name":"TrustScoreExists","originalRequest":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n    \"requiredinput\": {\r\n        \"ip\": \"2001:8004:cc2:fadb:9958:4523:6c42:e3f2\",\r\n        \"email\": \"test@gmail.com\",\r\n        \"url\": \"http://test.com\"\r\n    },\r\n    \"optionalInput\": {\r\n        \"last_bets\": null,\r\n        \"last_wins\": \"\",\r\n        \"total_bonuses\": \"\",\r\n        \"last_real_bets\": \"\",\r\n        \"last_real_wins\": \"\",\r\n        \"total_deposits\": \"\",\r\n        \"last_bonus_bets\": \"\",\r\n        \"last_bonus_wins\": \"\",\r\n        \"average_real_bet\": \"\",\r\n        \"last_bets_amount\": \"\",\r\n        \"last_wins_amount\": \"\",\r\n        \"average_bonus_bet\": \"\",\r\n        \"bonus_to_deposits\": \"\",\r\n        \"last_deposit_date\": \"\",\r\n        \"total_withdrawals\": \"\",\r\n        \"is_phone_confirmed\": \"\",\r\n        \"money_in_money_out\": \"\",\r\n        \"last_deposit_amount\": \"\",\r\n        \"last_freespins_date\": \"\",\r\n        \"last_freespins_name\": \"\",\r\n        \"last_free_bonus_date\": \"\",\r\n        \"last_free_bonus_name\": \"\",\r\n        \"total_bonuses_amount\": \"\",\r\n        \"last_freespins_amount\": \"\",\r\n        \"last_freespins_status\": \"\",\r\n        \"last_real_bets_amount\": \"\",\r\n        \"last_real_wins_amount\": \"\",\r\n        \"total_deposits_amount\": \"\",\r\n        \"last_bonus_bets_amount\": \"\",\r\n        \"last_bonus_wins_amount\": \"\",\r\n        \"last_free_bonus_amount\": \"\",\r\n        \"last_free_bonus_status\": \"\",\r\n        \"last_deposit_bonus_date\": \"\",\r\n        \"last_deposit_bonus_name\": \"\",\r\n        \"last_freespins_currency\": \"\",\r\n        \"last_freespins_wagering\": \"\",\r\n        \"withdrawals_to_deposits\": \"\",\r\n        \"last_free_bonus_currency\": \"\",\r\n        \"last_free_bonus_wagering\": \"\",\r\n        \"total_withdrawals_amount\": \"\",\r\n        \"withdrawal_ewallet_email\": \"\",\r\n        \"last_deposit_bonus_amount\": \"\",\r\n        \"last_deposit_bonus_status\": \"\",\r\n        \"last_deposit_bonus_currency\": \"\",\r\n        \"last_deposit_bonus_wagering\": \"\",\r\n        \"session\": \"\",\r\n        \"payment_mode\": \"\",\r\n        \"card_fullname\": \"\",\r\n        \"card_bin\": \"\",\r\n        \"card_hash\": \"\",\r\n        \"card_last\": \"\",\r\n        \"card_expire\": \"\",\r\n        \"avs_result\": \"\",\r\n        \"cvv_result\": \"\",\r\n        \"sca_method\": \"\",\r\n        \"user_bank_account\": \"\",\r\n        \"user_bank_name\": \"\",\r\n        \"user_balance\": \"\",\r\n        \"user_verification_level\": \"\",\r\n        \"status_3d\": \"\",\r\n        \"regulation\": \"\",\r\n        \"payment_provider\": \"\",\r\n        \"phone_number\": \"\",\r\n        \"transaction_type\": \"\",\r\n        \"transaction_amount\": \"\",\r\n        \"transaction_currency\": \"\",\r\n        \"merchant_id\": \"\",\r\n        \"details_url\": \"\",\r\n        \"name\": \"\",\r\n        \"person_type\": \"\",\r\n        \"gender\": \"\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"{{StagingBaseURL}}/trustScore"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"Date","value":"Sun, 29 Oct 2023 09:21:22 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"CF-Cache-Status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"endpoints\":[{\"url\":\"https:\\/\\/a.nel.cloudflare.com\\/report\\/v3?s=r2%2FuLwSilxdD1lpiI1VqpgF0Tu9etiNhupySeBHl0zcU8XV1z8kwR%2FJ00ti4xpMdrTXW%2BkqZkLGrkkaUnMWFsaYlg%2FfA9UC4wIKwmc9LHUwna491EmnC3b3vlabzhUJ11CMpnVmicUE%3D\"}],\"group\":\"cf-nel\",\"max_age\":604800}"},{"key":"NEL","value":"{\"success_fraction\":0,\"report_to\":\"cf-nel\",\"max_age\":604800}"},{"key":"Server","value":"cloudflare"},{"key":"CF-RAY","value":"81da590e8d4345a0-LHR"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"trustScore\": 0,\n    \"deliverable\": \"false\",\n    \"proxy\": \"false\",\n    \"vpn\": \"false\",\n    \"tor\": \"false\",\n    \"active_vpn\": \"false\",\n    \"active_tor\": \"false\",\n    \"recent_abuse\": \"false\",\n    \"bot_status\": \"false\"\n}"},{"id":"7bbccfc3-812d-4e19-a47b-e4572bea1b47","name":"TrustScoreError","originalRequest":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n    \"requiredinput\": {\r\n        \"ip\": \"2001:8004:cc2:fadb:9958:4523:6c42:e3f2\",\r\n        \"email\": \"test@gmail.com\",\r\n        \"url\": \"http://test.com\"\r\n    },\r\n    \"optionalInput\": {\r\n        \"last_bets\": null,\r\n        \"last_wins\": \"\",\r\n        \"total_bonuses\": \"\",\r\n        \"last_real_bets\": \"\",\r\n        \"last_real_wins\": \"\",\r\n        \"total_deposits\": \"\",\r\n        \"last_bonus_bets\": \"\",\r\n        \"last_bonus_wins\": \"\",\r\n        \"average_real_bet\": \"\",\r\n        \"last_bets_amount\": \"\",\r\n        \"last_wins_amount\": \"\",\r\n        \"average_bonus_bet\": \"\",\r\n        \"bonus_to_deposits\": \"\",\r\n        \"last_deposit_date\": \"\",\r\n        \"total_withdrawals\": \"\",\r\n        \"is_phone_confirmed\": \"\",\r\n        \"money_in_money_out\": \"\",\r\n        \"last_deposit_amount\": \"\",\r\n        \"last_freespins_date\": \"\",\r\n        \"last_freespins_name\": \"\",\r\n        \"last_free_bonus_date\": \"\",\r\n        \"last_free_bonus_name\": \"\",\r\n        \"total_bonuses_amount\": \"\",\r\n        \"last_freespins_amount\": \"\",\r\n        \"last_freespins_status\": \"\",\r\n        \"last_real_bets_amount\": \"\",\r\n        \"last_real_wins_amount\": \"\",\r\n        \"total_deposits_amount\": \"\",\r\n        \"last_bonus_bets_amount\": \"\",\r\n        \"last_bonus_wins_amount\": \"\",\r\n        \"last_free_bonus_amount\": \"\",\r\n        \"last_free_bonus_status\": \"\",\r\n        \"last_deposit_bonus_date\": \"\",\r\n        \"last_deposit_bonus_name\": \"\",\r\n        \"last_freespins_currency\": \"\",\r\n        \"last_freespins_wagering\": \"\",\r\n        \"withdrawals_to_deposits\": \"\",\r\n        \"last_free_bonus_currency\": \"\",\r\n        \"last_free_bonus_wagering\": \"\",\r\n        \"total_withdrawals_amount\": \"\",\r\n        \"withdrawal_ewallet_email\": \"\",\r\n        \"last_deposit_bonus_amount\": \"\",\r\n        \"last_deposit_bonus_status\": \"\",\r\n        \"last_deposit_bonus_currency\": \"\",\r\n        \"last_deposit_bonus_wagering\": \"\",\r\n        \"session\": \"\",\r\n        \"payment_mode\": \"\",\r\n        \"card_fullname\": \"\",\r\n        \"card_bin\": \"\",\r\n        \"card_hash\": \"\",\r\n        \"card_last\": \"\",\r\n        \"card_expire\": \"\",\r\n        \"avs_result\": \"\",\r\n        \"cvv_result\": \"\",\r\n        \"sca_method\": \"\",\r\n        \"user_bank_account\": \"\",\r\n        \"user_bank_name\": \"\",\r\n        \"user_balance\": \"\",\r\n        \"user_verification_level\": \"\",\r\n        \"status_3d\": \"\",\r\n        \"regulation\": \"\",\r\n        \"payment_provider\": \"\",\r\n        \"phone_number\": \"\",\r\n        \"transaction_type\": \"\",\r\n        \"transaction_amount\": \"\",\r\n        \"transaction_currency\": \"\",\r\n        \"merchant_id\": \"\",\r\n        \"details_url\": \"\",\r\n        \"name\": \"\",\r\n        \"person_type\": \"\",\r\n        \"gender\": \"\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"{{StagingBaseURL}}/trustScore"},"status":"Unauthorized","code":401,"_postman_previewlanguage":"json","header":[{"key":"Date","value":"Sun, 29 Oct 2023 09:28:33 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"CF-Cache-Status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"endpoints\":[{\"url\":\"https:\\/\\/a.nel.cloudflare.com\\/report\\/v3?s=herXY1o%2BFZa%2F3qNFjvh4ANgP%2FD0DdAVVFm0vUZDAst2rFkieItm%2Fu0VN24DYrdp7MHMHFKWLvrsBYVIxjDPDaLgJjeGBvlTP2iZoB5EnG1hPPHUVXRNP%2FGMmOTh%2Fp7gsyj0vihW1kMk%3D\"}],\"group\":\"cf-nel\",\"max_age\":604800}"},{"key":"NEL","value":"{\"success_fraction\":0,\"report_to\":\"cf-nel\",\"max_age\":604800}"},{"key":"Server","value":"cloudflare"},{"key":"CF-RAY","value":"81da6398ab144913-LHR"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Incorrect secret_key\",\n    \"code\": \"authentication_failed\"\n}"}],"_postman_id":"35ab4812-eb0b-466a-a362-8f3457c13353"},{"name":"checkTransactionAllowed","id":"41e54637-ea23-4638-9b1c-85498cca0eb6","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n    \"requiredinput\": {\r\n        \"ip\": \"111.11.11.11\",\r\n        \"email\": \"test@gmail.com\",\r\n        \"url\": \"https://www.asos.com/\"\r\n    },\r\n    \"optionalInput\": {\r\n        \"last_bets\": null,\r\n        \"last_wins\": \"\",\r\n        \"total_bonuses\": \"\",\r\n        \"last_real_bets\": \"\",\r\n        \"last_real_wins\": \"\",\r\n        \"total_deposits\": \"\",\r\n        \"last_bonus_bets\": \"\",\r\n        \"last_bonus_wins\": \"\",\r\n        \"average_real_bet\": \"\",\r\n        \"last_bets_amount\": \"\",\r\n        \"last_wins_amount\": \"\",\r\n        \"average_bonus_bet\": \"\",\r\n        \"bonus_to_deposits\": \"\",\r\n        \"last_deposit_date\": \"\",\r\n        \"total_withdrawals\": \"\",\r\n        \"is_phone_confirmed\": \"\",\r\n        \"money_in_money_out\": \"\",\r\n        \"last_deposit_amount\": \"\",\r\n        \"last_freespins_date\": \"\",\r\n        \"last_freespins_name\": \"\",\r\n        \"last_free_bonus_date\": \"\",\r\n        \"last_free_bonus_name\": \"\",\r\n        \"total_bonuses_amount\": \"\",\r\n        \"last_freespins_amount\": \"\",\r\n        \"last_freespins_status\": \"\",\r\n        \"last_real_bets_amount\": \"\",\r\n        \"last_real_wins_amount\": \"\",\r\n        \"total_deposits_amount\": \"\",\r\n        \"last_bonus_bets_amount\": \"\",\r\n        \"last_bonus_wins_amount\": \"\",\r\n        \"last_free_bonus_amount\": \"\",\r\n        \"last_free_bonus_status\": \"\",\r\n        \"last_deposit_bonus_date\": \"\",\r\n        \"last_deposit_bonus_name\": \"\",\r\n        \"last_freespins_currency\": \"\",\r\n        \"last_freespins_wagering\": \"\",\r\n        \"withdrawals_to_deposits\": \"\",\r\n        \"last_free_bonus_currency\": \"\",\r\n        \"last_free_bonus_wagering\": \"\",\r\n        \"total_withdrawals_amount\": \"\",\r\n        \"withdrawal_ewallet_email\": \"\",\r\n        \"last_deposit_bonus_amount\": \"\",\r\n        \"last_deposit_bonus_status\": \"\",\r\n        \"last_deposit_bonus_currency\": \"\",\r\n        \"last_deposit_bonus_wagering\": \"\",\r\n        \"session\": \"\",\r\n        \"payment_mode\": \"\",\r\n        \"card_fullname\": \"\",\r\n        \"card_bin\": \"\",\r\n        \"card_hash\": \"\",\r\n        \"card_last\": \"\",\r\n        \"card_expire\": \"\",\r\n        \"avs_result\": \"\",\r\n        \"cvv_result\": \"\",\r\n        \"sca_method\": \"\",\r\n        \"user_bank_account\": \"\",\r\n        \"user_bank_name\": \"\",\r\n        \"user_balance\": \"\",\r\n        \"user_verification_level\": \"\",\r\n        \"status_3d\": \"\",\r\n        \"regulation\": \"\",\r\n        \"payment_provider\": \"\",\r\n        \"phone_number\": \"\",\r\n        \"transaction_type\": \"\",\r\n        \"transaction_amount\": \"\",\r\n        \"transaction_currency\": \"\",\r\n        \"merchant_id\": \"\",\r\n        \"details_url\": \"\",\r\n        \"name\": \"\",\r\n        \"person_type\": \"\",\r\n        \"gender\": \"\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/checkTransAllowed","description":"<h3 id=\"general-trustscore\">General TrustScore</h3>\n<p>Request for the checkTransactionAllowed endpoint is identical to the TrustScore API. Only thing different is the response. Instead of detailed score, this endpoint only returns <code>transactionAllowed</code> parameter that can have either <code>YES</code> or <code>NO</code> value.</p>\n<h3 id=\"permission\"><strong>Permission</strong></h3>\n<p>Access to this API has to be given to you by the admin. So please contact your sales representative at Paysecure to get access to this API, if you get a 401 error of \"You are not allowed to call this API service\".</p>\n<h3 id=\"mandatory-parameters-in-body\">Mandatory Parameters (in body)</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameters</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>ip</td>\n<td>IP of the user. Both IP4 and IP6 are valid</td>\n</tr>\n<tr>\n<td>email</td>\n<td>The email id of the user you want to trust score on</td>\n</tr>\n<tr>\n<td>url</td>\n<td>The URL on which the user is trying to purchase or consume a product, service or data.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"other-optional-paramters\">Other optional paramters:</h3>\n<p>The optional parameters are self-explanatory and appropriate values can be given in string format.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameters</strong></th>\n<th><strong>Values</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>last_bets</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_wins</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_bonuses</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_real_bets</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_real_wins</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_deposits</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bonus_bets</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bonus_wins</td>\n<td>String</td>\n</tr>\n<tr>\n<td>average_real_bet</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bets_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_wins_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>average_bonus_bet</td>\n<td>String</td>\n</tr>\n<tr>\n<td>bonus_to_deposits</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_date</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_withdrawals</td>\n<td>String</td>\n</tr>\n<tr>\n<td>is_phone_confirmed</td>\n<td>String</td>\n</tr>\n<tr>\n<td>money_in_money_out</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_date</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_date</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_bonuses_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_status</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_real_bets_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_real_wins_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_deposits_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bonus_bets_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_bonus_wins_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_status</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_date</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_currency</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_freespins_wagering</td>\n<td>String</td>\n</tr>\n<tr>\n<td>withdrawals_to_deposits</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_currency</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_free_bonus_wagering</td>\n<td>String</td>\n</tr>\n<tr>\n<td>total_withdrawals_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>withdrawal_ewallet_email</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_status</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_currency</td>\n<td>String</td>\n</tr>\n<tr>\n<td>last_deposit_bonus_wagering</td>\n<td>String</td>\n</tr>\n<tr>\n<td>session</td>\n<td>String</td>\n</tr>\n<tr>\n<td>payment_mode</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_fullname</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_bin</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_hash</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_last</td>\n<td>String</td>\n</tr>\n<tr>\n<td>card_expire</td>\n<td>String</td>\n</tr>\n<tr>\n<td>avs_result</td>\n<td>String</td>\n</tr>\n<tr>\n<td>cvv_result</td>\n<td>String</td>\n</tr>\n<tr>\n<td>sca_method</td>\n<td>String</td>\n</tr>\n<tr>\n<td>user_bank_account</td>\n<td>String</td>\n</tr>\n<tr>\n<td>user_bank_name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>user_balance</td>\n<td>String</td>\n</tr>\n<tr>\n<td>user_verification_level</td>\n<td>String</td>\n</tr>\n<tr>\n<td>status_3d</td>\n<td>String</td>\n</tr>\n<tr>\n<td>regulation</td>\n<td>String</td>\n</tr>\n<tr>\n<td>payment_provider</td>\n<td>String</td>\n</tr>\n<tr>\n<td>phone_number</td>\n<td>String</td>\n</tr>\n<tr>\n<td>transaction_type</td>\n<td>String</td>\n</tr>\n<tr>\n<td>transaction_amount</td>\n<td>String</td>\n</tr>\n<tr>\n<td>transaction_currency</td>\n<td>String</td>\n</tr>\n<tr>\n<td>merchant_id</td>\n<td>String</td>\n</tr>\n<tr>\n<td>details_url</td>\n<td>String</td>\n</tr>\n<tr>\n<td>name</td>\n<td>String</td>\n</tr>\n<tr>\n<td>person_type</td>\n<td>String</td>\n</tr>\n<tr>\n<td>gender</td>\n<td>String</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response\">Response</h3>\n<p>Response contains a single parameter: <code>transactionAllowed</code> which can either be <code>YES</code> or <code>NO</code> .</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n\"transactionAllowed\" : \"YES\"\n}\n\n</code></pre>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<p>the possible error codes one can get on calling this APIs are:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Code</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>400, 404, 401, 415, 405</td>\n</tr>\n</tbody>\n</table>\n</div><p>for example:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Code</strong></th>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>401</td>\n<td>Incorrect secret_key</td>\n</tr>\n<tr>\n<td>401</td>\n<td>You are not Allowed to call this API service</td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"path":["checkTransAllowed"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"4fd67bc9-63ff-46d8-a270-a8d748b5ef5a","name":"TrustScoreExists","originalRequest":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n    \"requiredinput\": {\r\n        \"ip\": \"2001:8004:cc2:fadb:9958:4523:6c42:e3f2\",\r\n        \"email\": \"test@gmail.com\",\r\n        \"url\": \"http://test.com\"\r\n    },\r\n    \"optionalInput\": {\r\n        \"last_bets\": null,\r\n        \"last_wins\": \"\",\r\n        \"total_bonuses\": \"\",\r\n        \"last_real_bets\": \"\",\r\n        \"last_real_wins\": \"\",\r\n        \"total_deposits\": \"\",\r\n        \"last_bonus_bets\": \"\",\r\n        \"last_bonus_wins\": \"\",\r\n        \"average_real_bet\": \"\",\r\n        \"last_bets_amount\": \"\",\r\n        \"last_wins_amount\": \"\",\r\n        \"average_bonus_bet\": \"\",\r\n        \"bonus_to_deposits\": \"\",\r\n        \"last_deposit_date\": \"\",\r\n        \"total_withdrawals\": \"\",\r\n        \"is_phone_confirmed\": \"\",\r\n        \"money_in_money_out\": \"\",\r\n        \"last_deposit_amount\": \"\",\r\n        \"last_freespins_date\": \"\",\r\n        \"last_freespins_name\": \"\",\r\n        \"last_free_bonus_date\": \"\",\r\n        \"last_free_bonus_name\": \"\",\r\n        \"total_bonuses_amount\": \"\",\r\n        \"last_freespins_amount\": \"\",\r\n        \"last_freespins_status\": \"\",\r\n        \"last_real_bets_amount\": \"\",\r\n        \"last_real_wins_amount\": \"\",\r\n        \"total_deposits_amount\": \"\",\r\n        \"last_bonus_bets_amount\": \"\",\r\n        \"last_bonus_wins_amount\": \"\",\r\n        \"last_free_bonus_amount\": \"\",\r\n        \"last_free_bonus_status\": \"\",\r\n        \"last_deposit_bonus_date\": \"\",\r\n        \"last_deposit_bonus_name\": \"\",\r\n        \"last_freespins_currency\": \"\",\r\n        \"last_freespins_wagering\": \"\",\r\n        \"withdrawals_to_deposits\": \"\",\r\n        \"last_free_bonus_currency\": \"\",\r\n        \"last_free_bonus_wagering\": \"\",\r\n        \"total_withdrawals_amount\": \"\",\r\n        \"withdrawal_ewallet_email\": \"\",\r\n        \"last_deposit_bonus_amount\": \"\",\r\n        \"last_deposit_bonus_status\": \"\",\r\n        \"last_deposit_bonus_currency\": \"\",\r\n        \"last_deposit_bonus_wagering\": \"\",\r\n        \"session\": \"\",\r\n        \"payment_mode\": \"\",\r\n        \"card_fullname\": \"\",\r\n        \"card_bin\": \"\",\r\n        \"card_hash\": \"\",\r\n        \"card_last\": \"\",\r\n        \"card_expire\": \"\",\r\n        \"avs_result\": \"\",\r\n        \"cvv_result\": \"\",\r\n        \"sca_method\": \"\",\r\n        \"user_bank_account\": \"\",\r\n        \"user_bank_name\": \"\",\r\n        \"user_balance\": \"\",\r\n        \"user_verification_level\": \"\",\r\n        \"status_3d\": \"\",\r\n        \"regulation\": \"\",\r\n        \"payment_provider\": \"\",\r\n        \"phone_number\": \"\",\r\n        \"transaction_type\": \"\",\r\n        \"transaction_amount\": \"\",\r\n        \"transaction_currency\": \"\",\r\n        \"merchant_id\": \"\",\r\n        \"details_url\": \"\",\r\n        \"name\": \"\",\r\n        \"person_type\": \"\",\r\n        \"gender\": \"\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"{{StagingBaseURL}}/checkTransAllowed"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"Date","value":"Sun, 29 Oct 2023 09:21:22 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"CF-Cache-Status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"endpoints\":[{\"url\":\"https:\\/\\/a.nel.cloudflare.com\\/report\\/v3?s=r2%2FuLwSilxdD1lpiI1VqpgF0Tu9etiNhupySeBHl0zcU8XV1z8kwR%2FJ00ti4xpMdrTXW%2BkqZkLGrkkaUnMWFsaYlg%2FfA9UC4wIKwmc9LHUwna491EmnC3b3vlabzhUJ11CMpnVmicUE%3D\"}],\"group\":\"cf-nel\",\"max_age\":604800}"},{"key":"NEL","value":"{\"success_fraction\":0,\"report_to\":\"cf-nel\",\"max_age\":604800}"},{"key":"Server","value":"cloudflare"},{"key":"CF-RAY","value":"81da590e8d4345a0-LHR"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"transactionAllowed\": \"YES\"\n}"},{"id":"ec014e56-45ce-4d7c-8fd7-7534c48c7950","name":"TrustScoreError","originalRequest":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n    \"requiredinput\": {\r\n        \"ip\": \"2001:8004:cc2:fadb:9958:4523:6c42:e3f2\",\r\n        \"email\": \"test@gmail.com\",\r\n        \"url\": \"http://test.com\"\r\n    },\r\n    \"optionalInput\": {\r\n        \"last_bets\": null,\r\n        \"last_wins\": \"\",\r\n        \"total_bonuses\": \"\",\r\n        \"last_real_bets\": \"\",\r\n        \"last_real_wins\": \"\",\r\n        \"total_deposits\": \"\",\r\n        \"last_bonus_bets\": \"\",\r\n        \"last_bonus_wins\": \"\",\r\n        \"average_real_bet\": \"\",\r\n        \"last_bets_amount\": \"\",\r\n        \"last_wins_amount\": \"\",\r\n        \"average_bonus_bet\": \"\",\r\n        \"bonus_to_deposits\": \"\",\r\n        \"last_deposit_date\": \"\",\r\n        \"total_withdrawals\": \"\",\r\n        \"is_phone_confirmed\": \"\",\r\n        \"money_in_money_out\": \"\",\r\n        \"last_deposit_amount\": \"\",\r\n        \"last_freespins_date\": \"\",\r\n        \"last_freespins_name\": \"\",\r\n        \"last_free_bonus_date\": \"\",\r\n        \"last_free_bonus_name\": \"\",\r\n        \"total_bonuses_amount\": \"\",\r\n        \"last_freespins_amount\": \"\",\r\n        \"last_freespins_status\": \"\",\r\n        \"last_real_bets_amount\": \"\",\r\n        \"last_real_wins_amount\": \"\",\r\n        \"total_deposits_amount\": \"\",\r\n        \"last_bonus_bets_amount\": \"\",\r\n        \"last_bonus_wins_amount\": \"\",\r\n        \"last_free_bonus_amount\": \"\",\r\n        \"last_free_bonus_status\": \"\",\r\n        \"last_deposit_bonus_date\": \"\",\r\n        \"last_deposit_bonus_name\": \"\",\r\n        \"last_freespins_currency\": \"\",\r\n        \"last_freespins_wagering\": \"\",\r\n        \"withdrawals_to_deposits\": \"\",\r\n        \"last_free_bonus_currency\": \"\",\r\n        \"last_free_bonus_wagering\": \"\",\r\n        \"total_withdrawals_amount\": \"\",\r\n        \"withdrawal_ewallet_email\": \"\",\r\n        \"last_deposit_bonus_amount\": \"\",\r\n        \"last_deposit_bonus_status\": \"\",\r\n        \"last_deposit_bonus_currency\": \"\",\r\n        \"last_deposit_bonus_wagering\": \"\",\r\n        \"session\": \"\",\r\n        \"payment_mode\": \"\",\r\n        \"card_fullname\": \"\",\r\n        \"card_bin\": \"\",\r\n        \"card_hash\": \"\",\r\n        \"card_last\": \"\",\r\n        \"card_expire\": \"\",\r\n        \"avs_result\": \"\",\r\n        \"cvv_result\": \"\",\r\n        \"sca_method\": \"\",\r\n        \"user_bank_account\": \"\",\r\n        \"user_bank_name\": \"\",\r\n        \"user_balance\": \"\",\r\n        \"user_verification_level\": \"\",\r\n        \"status_3d\": \"\",\r\n        \"regulation\": \"\",\r\n        \"payment_provider\": \"\",\r\n        \"phone_number\": \"\",\r\n        \"transaction_type\": \"\",\r\n        \"transaction_amount\": \"\",\r\n        \"transaction_currency\": \"\",\r\n        \"merchant_id\": \"\",\r\n        \"details_url\": \"\",\r\n        \"name\": \"\",\r\n        \"person_type\": \"\",\r\n        \"gender\": \"\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"{{StagingBaseURL}}/checkTransAllowed"},"status":"Unauthorized","code":401,"_postman_previewlanguage":"json","header":[{"key":"Date","value":"Sun, 29 Oct 2023 09:28:33 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"CF-Cache-Status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"endpoints\":[{\"url\":\"https:\\/\\/a.nel.cloudflare.com\\/report\\/v3?s=herXY1o%2BFZa%2F3qNFjvh4ANgP%2FD0DdAVVFm0vUZDAst2rFkieItm%2Fu0VN24DYrdp7MHMHFKWLvrsBYVIxjDPDaLgJjeGBvlTP2iZoB5EnG1hPPHUVXRNP%2FGMmOTh%2Fp7gsyj0vihW1kMk%3D\"}],\"group\":\"cf-nel\",\"max_age\":604800}"},{"key":"NEL","value":"{\"success_fraction\":0,\"report_to\":\"cf-nel\",\"max_age\":604800}"},{"key":"Server","value":"cloudflare"},{"key":"CF-RAY","value":"81da6398ab144913-LHR"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Incorrect secret_key\",\n    \"code\": \"authentication_failed\"\n}"}],"_postman_id":"41e54637-ea23-4638-9b1c-85498cca0eb6"}],"id":"3a696fea-6a8e-4702-b451-f56154171d91","_postman_id":"3a696fea-6a8e-4702-b451-f56154171d91","description":""},{"name":"Cashier APIs","item":[{"name":"Customer","id":"80a9faa2-891c-4b9e-ab87-ae455e81b3dd","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"city\": \"Jaipur\",\r\n    \"stateCode\": \"RJ\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"CustRegDate\": \"2023-12-27\", //non-mandatory - customer registration date on merchant site\r\n    \"SuccessTxn\": \"32\", //non-mandatory - total successful customer orders on merchant site\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer","description":"<p><strong>OVERIEW</strong></p>\n<p>The <strong>createCustomer API</strong> allows merchants to create a customer profile on PaySecure when a user visits their website, facilitating a seamless payment experience by pre-filling the customer's details, on the PaySecure Cashier. The API takes in customer information and returns a unique customerID that can be passed in purchase payload, eliminating the need for customers to manually enter their details during transactions.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th><strong>Required</strong></th>\n<th>Description</th>\n<th>Example</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>merchantCustomerId</td>\n<td>String</td>\n<td>Yes</td>\n<td>unique customer ID provided by merchant. This can be email, mobile or an alphanumeric string</td>\n<td><a href=\"https://mailto:rahultestcustomer@paysecure.net\">rahultestcustomer@paysecure.net</a></td>\n</tr>\n<tr>\n<td>fullName</td>\n<td>String</td>\n<td>Yes</td>\n<td>Full name of the customer.</td>\n<td>Rahul Agarwal</td>\n</tr>\n<tr>\n<td>emailId</td>\n<td>String</td>\n<td>Yes</td>\n<td>Email address of the customer.</td>\n<td><a href=\"https://mailto:test@paysecure.net\">test@paysecure.net</a></td>\n</tr>\n<tr>\n<td>dateOfBirth</td>\n<td>String</td>\n<td>Optional</td>\n<td>Customer's date of birth in YYYY-MM-DD format.</td>\n<td>1995-12-27</td>\n</tr>\n<tr>\n<td>phoneNo</td>\n<td>String</td>\n<td>Yes</td>\n<td>Customer's phone number. Preferred with the country code</td>\n<td>+91 797639082</td>\n</tr>\n<tr>\n<td>city</td>\n<td>String</td>\n<td>Optional</td>\n<td>City of the customer.</td>\n<td>Jaipur</td>\n</tr>\n<tr>\n<td>stateCode</td>\n<td>String</td>\n<td>Yes</td>\n<td>State code of the customer.</td>\n<td>RJ</td>\n</tr>\n<tr>\n<td>zipCode</td>\n<td>String</td>\n<td>Optional</td>\n<td>Postal code of the customer's location.</td>\n<td>302018</td>\n</tr>\n<tr>\n<td>address</td>\n<td>String</td>\n<td>Optional</td>\n<td>Full address of the customer.</td>\n<td>House Number 53, Vaishali Nagar, Jaipur</td>\n</tr>\n<tr>\n<td>country</td>\n<td>String</td>\n<td>Yes</td>\n<td>Country code (ISO 3166-1 alpha-2).</td>\n<td>IN</td>\n</tr>\n<tr>\n<td>custRegDate</td>\n<td>Sting</td>\n<td>Optional</td>\n<td>Customer registration date on merchant site in YYYY-MM-DD format.</td>\n<td>2023-12-27</td>\n</tr>\n<tr>\n<td>successTxn</td>\n<td>String</td>\n<td>Optional</td>\n<td>Number of successful transactions customer has carried on merchant site.</td>\n<td>32</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"user-flow\"><strong>User Flow</strong></h3>\n<ol>\n<li><p><strong>Customer visits merchant's website</strong>: The customer selects the product or service and proceeds to checkout page.</p>\n</li>\n<li><p><strong>Merchant calls the</strong> <strong><code>createCustomer</code></strong> <strong>API</strong>: The merchant sends a <code>POST</code> request to the Paysecure API with the customer's details.</p>\n</li>\n<li><p><strong>Customer ID generation</strong>: Paysecure processes the request and generates a unique <code>customerId</code> which is returned in the response.</p>\n</li>\n<li><p><strong>Payment Process</strong>: The merchant uses the <code>customerId</code> for subsequent session creation, ensuring the customer doesn’t need to re-enter their details for future payments.</p>\n</li>\n</ol>\n<hr />\n<h3 id=\"benefits\"><strong>Benefits</strong></h3>\n<ul>\n<li><p><strong>Seamless user experience</strong>: The customer does not have to enter their details manually for every purchase.</p>\n</li>\n<li><p><strong>Faster Checkout</strong>: The merchant can use the <code>customerId</code> for faster payment processing.</p>\n</li>\n<li><p><strong>Data Security</strong>: Customer details are stored securely and can be reused across transactions, reducing the chances of errors.</p>\n</li>\n</ul>\n<h3 id=\"implementing-createcustomer-on-merchant-site\">Implementing createCustomer on merchant site:</h3>\n<p>The <code>createCustomer</code> can be implemented on merchant site in one of two ways, depending on merchant’s integration flow:</p>\n<p><strong>At Checkout:</strong></p>\n<p>When a customer initiates the checkout process, your system should invoke the <code>createCustomer</code> API, before actually starting the session.</p>\n<ul>\n<li><p><strong>Call</strong> <strong><code>createCustomer</code></strong>: This API call generates a unique customer ID.</p>\n</li>\n<li><p><strong>Use of Customer ID:</strong> Pass the returned customer ID in Session API, when creating a payment session.</p>\n</li>\n</ul>\n<p><strong>Upon Customer Login:</strong></p>\n<p>Alternatively, merchants may choose to call <code>createCustomer</code> at the time of customer login on their site.</p>\n<ul>\n<li><p><strong>Persistent Customer Profiles:</strong> This approach can help build or maintain a persistent customer profile, ensuring the customer ID is available for any subsequent payment sessions without needing to call <code>createCustomer</code> again.</p>\n</li>\n<li><p><strong>Integration Flexibility:</strong> This is useful for merchants who want to initialize customer data early in the customer journey rather than during checkout.</p>\n</li>\n</ul>\n<p>The method you choose depends on your business requirements and how your system is architected. Regardless of when you call it, the resulting customer ID must be passed to the <code>createSession</code> API to initiate a payment session.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","name":"Cashier APIs","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","customer"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"d02651e7-1068-4f10-8108-f5cca8738f1a","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"If this parameter is passed in the header, a unique customer will be created under that particular Brand Name. else, the customer will be created under the main merchant (irrespective of the brands)","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"city\": \"Jaipur\",\r\n    \"stateCode\": \"RJ\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"CustRegDate\": \"2023-12-27\", //non-mandatory - customer registration date on merchant site\r\n    \"SuccessTxn\": \"32\", //non-mandatory - total successful customer orders on merchant site\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer"},"status":"OK","code":200,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"customerId\": \"691afbc6fd96d34a8113a34d\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"brandID\": \"1d666074-39be-4b90-aec9-e9de78fbdcb9\",\r\n    \"city\": \"Jaipur\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"stateCode\": \"RJ\",\r\n    \"custRegDate\": \"2023-12-27\",\r\n    \"successTrans\": 0,\r\n    \"createdOn\": 1763376070,\r\n    \"lastUpdated\": 0,\r\n    \"lastActivity\": 1763376070,\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}"},{"id":"b84585c1-8006-4dbe-9cd6-c2be1f5cd083","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"If this parameter is passed in the header, a unique customer will be created under that particular Brand Name. else, the customer will be created under the main merchant (irrespective of the brands)","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"city\": \"Jaipur\",\r\n    \"stateCode\": \"RJ\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"CustRegDate\": \"2023-12-27\", //non-mandatory - customer registration date on merchant site\r\n    \"SuccessTxn\": \"32\", //non-mandatory - total successful customer orders on merchant site\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer"},"status":"Bad Request","code":400,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Invalid Email Format\",\r\n    \"code\": \"invalid_email\"\r\n}"},{"id":"dd78ad81-3a71-487e-8213-333507fe1261","name":"Existing Customer","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"If this parameter is passed in the header, a unique customer will be created under that particular Brand Name. else, the customer will be created under the main merchant (irrespective of the brands)","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"city\": \"Jaipur\",\r\n    \"stateCode\": \"RJ\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"CustRegDate\": \"2023-12-27\", //non-mandatory - customer registration date on merchant site\r\n    \"SuccessTxn\": \"32\", //non-mandatory - total successful customer orders on merchant site\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer"},"status":"Unauthorized","code":401,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Customer already exists with this information\",\r\n    \"code\": \"customer_already_exists\"\r\n}"}],"_postman_id":"80a9faa2-891c-4b9e-ab87-ae455e81b3dd"},{"name":"Customer","id":"8db7e7d8-d5b9-481f-99ed-c76418c182eb","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\"\n}","options":{"raw":{"language":"json"}}},"url":"https://app.paysecure.net/api/v1/customer","description":"<p>This endpoint makes an HTTP GET request to retrieve customer information from the Paysecure API.</p>\n<h3 id=\"request\">Request</h3>\n<p>The request does not include any query parameters, but it uses a raw request body with the following parameter \"merchantCustomerId\", which will be the customer id on the merchant's side.</p>\n<h3 id=\"response\">Response</h3>\n<p>The response of this request can be documented as a JSON schema.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","name":"Cashier APIs","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","customer"],"host":["app","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"1a133d7c-abb6-4ca4-bd0f-7ed51b3215e9","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\"\n}","options":{"raw":{"language":"json"}}},"url":"https://app.paysecure.net/api/v1/customer"},"status":"OK","code":200,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\n    \"customerId\": \"691afbc6fd96d34a8113a34d\",\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\",\n    \"fullName\": \"Rahul Agarwal\",\n    \"emailId\": \"rahul+26@paysecure.net\",\n    \"dateOfBirth\": \"1994-06-03\",\n    \"phoneNo\": \"+91 797639082\",\n    \"brandID\": \"1d666074-39be-4b90-aec9-e9de78fbdcb9\",\n    \"city\": \"Jaipur\",\n    \"zipCode\": \"302018\",\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\n    \"country\": \"IN\",\n    \"stateCode\": \"RJ\",\n    \"custRegDate\": \"2023-12-27\",\n    \"successTrans\": 0,\n    \"createdOn\": 1763376070,\n    \"lastUpdated\": 0,\n    \"lastActivity\": 1763376070,\n    \"extraParam\": {\n        \"param1\": \"value1\",\n        \"param2\": \"value2\",\n        \"param3\": \"value3\",\n        \"param4\": \"value4\"\n    }\n}"},{"id":"e60b568b-3bba-40b7-ae58-04c0d02cda54","name":"Invalid Customer","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\"\n}","options":{"raw":{"language":"json"}}},"url":"https://app.paysecure.net/api/v1/customer"},"status":"Bad Request","code":400,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Customer with this information does not exist\",\n    \"code\": \"customer_does_not_exist\"\n}"}],"_postman_id":"8db7e7d8-d5b9-481f-99ed-c76418c182eb"},{"name":"Customer","event":[{"listen":"test","script":{"id":"272f785d-43b9-49f8-8029-580e45c98165","exec":["var template = `","<style type=\"text/css\">","    .tftable {font-size:14px;color:#333333;width:100%;border-width: 1px;border-color: #87ceeb;border-collapse: collapse;}","    .tftable th {font-size:18px;background-color:#87ceeb;border-width: 1px;padding: 8px;border-style: solid;border-color: #87ceeb;text-align:left;}","    .tftable tr {background-color:#ffffff;}","    .tftable td {font-size:14px;border-width: 1px;padding: 8px;border-style: solid;border-color: #87ceeb;}","    .tftable tr:hover {background-color:#e0ffff;}","</style>","","<table class=\"tftable\" border=\"1\">","    <tr>","        <th>Customer ID</th>","        <th>First Name</th>","        <th>Last Name</th>","        <th>Email</th>","        <th>Phone</th>","    </tr>","    ","    <tr>","        <td>{{response.customerId}}</td>","        <td>{{response.firstName}}</td>","        <td>{{response.lastName}}</td>","        <td>{{response.email}}</td>","        <td>{{response.phone}}</td>","    </tr>","</table>","`;","","function constructVisualizerPayload() {","    return {response: pm.response.json()}","}","","pm.visualizer.set(template, constructVisualizerPayload());"],"type":"text/javascript","packages":{},"requests":{}}}],"id":"0b904593-8381-4b27-89bd-ec6dc13ee794","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"PATCH","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"fullName\": \"Gouri Shankar3\",\n    \"emailId\": \"gouri@paysecure.com\",\n    \"dateOfBirth\": \"1990-11-27\",\n    \"phoneNo\": \"+91 9413666514\",\n    \"city\": \"Dausa\",\n    \"stateCode\": \"Raj\",\n    \"zipCode\": \"202021\",\n    \"address\": \"Somnath Nagar\",\n    \"country\": \"IN\",\n    \"CustRegDate\": \"2023-12-28\",\n    \"SuccessTxn\": \"33\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/{PaysecureCustomerId}/patchCustomer","description":"<p>Whenever a customer or the merchant updates customer details on the merchant site, a PATCH request must be made to synchronize these changes with Paysecure.</p>\n<p>This API endpoint allows you to update the customer details using an HTTP PATCH request. The request should be sent to <a href=\"https://api.paysecure.net/api/v1/%7BcustomerId%7D/patchCustomer\">https://api.paysecure.net/api/v1/{customerId}/patchCustomer</a>.</p>\n<h3 id=\"request-body\">Request Body</h3>\n<p>The request body should be in raw format and include the following parameters:</p>\n<ul>\n<li><p><code>fullName</code> (string): The full name of the customer.</p>\n</li>\n<li><p><code>emailId</code> (string): The email address of the customer.</p>\n</li>\n<li><p><code>dateOfBirth</code> (string): The date of birth of the customer.</p>\n</li>\n<li><p><code>phoneNo</code> (string): The phone number of the customer.</p>\n</li>\n<li><p><code>city</code> (string): The city of the customer.</p>\n</li>\n<li><p><code>stateCode</code> (string): The state code of the customer.</p>\n</li>\n<li><p><code>zipCode</code> (string): The zip code of the customer.</p>\n</li>\n<li><p><code>address</code> (string): The address of the customer.</p>\n</li>\n<li><p><code>country</code> (string): The country of the customer.</p>\n</li>\n<li><p><code>createdOn</code> (string): Time when the customer was created.</p>\n</li>\n<li><p><code>custRegDate</code> (string): Customer registration date (Non-Mandatory).</p>\n</li>\n<li><p><code>successTxn</code> (string): Success transaction details (Non-Mandatory).</p>\n</li>\n<li><p><code>lastActivity</code> (string): Time of the last activity.</p>\n</li>\n<li><p><code>lastUpdated</code> (string): Time when the last patch was called.</p>\n</li>\n<li><p><code>extraParam</code> (object): Additional parameters including <code>param1</code>, <code>param2</code>, <code>param3</code>, <code>param4</code> with their respective values.</p>\n</li>\n</ul>\n<h3 id=\"response\">Response</h3>\n<p>The response will contain the updated customer details or a success message upon successful update.</p>\n","urlObject":{"protocol":"https","path":["api","v1","{PaysecureCustomerId}","patchCustomer"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"315616af-fd27-4629-b572-43cd29d4d80f","name":"Success","originalRequest":{"method":"PATCH","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Authorisation","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"fullName\": \"Gouri Shankar3\",\n    \"emailId\": \"gouri@paysecure.com\",\n    \"dateOfBirth\": \"1990-11-27\",\n    \"phoneNo\": \"+91 9413666514\",\n    \"city\": \"Dausa\",\n    \"stateCode\": \"Raj\",\n    \"zipCode\": \"202021\",\n    \"address\": \"Somnath Nagar\",\n    \"country\": \"IN\",\n    \"CustRegDate\": \"2023-12-28\",\n    \"SuccessTxn\": \"33\",\n    \"extraParam\": {\n        \"param1\": \"value1\",\n        \"param2\": \"value2\",\n        \"param3\": \"value3\",\n        \"param4\": \"value4\"\n    }\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/{PaysecureCustomerId}/patchCustomer"},"status":"OK","code":200,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\n    \"customerId\": \"691afbc6fd96d34a8113a34d\",\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\",\n    \"fullName\": \"Gouri Shankar3\",\n    \"emailId\": \"gouri@paysecure.com\",\n    \"dateOfBirth\": \"1990-11-27\",\n    \"phoneNo\": \"+91 9413666514\",\n    \"brandID\": \"brandID\",\n    \"city\": \"Dausa\",\n    \"zipCode\": \"202021\",\n    \"address\": \"Somnath Nagar\",\n    \"country\": \"IN\",\n    \"stateCode\": \"Raj\",\n    \"custRegDate\": \"2023-12-28\",\n    \"successTrans\": 0,\n    \"createdOn\": 1763376070,\n    \"lastUpdated\": 1763377024,\n    \"lastActivity\": 1763377024,\n    \"extraParam\": {\n        \"param1\": \"value1\",\n        \"param2\": \"value2\",\n        \"param3\": \"value3\",\n        \"param4\": \"value4\"\n    }\n}"}],"_postman_id":"0b904593-8381-4b27-89bd-ec6dc13ee794"},{"name":"Purchase Session","id":"f1041a2e-6810-448a-989b-cea08fcb2b8e","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"68fed1855ebbe829416b08c6\",\r\n    \"merchantRef\": \"rahultestcustomer1@paysecure.net\", // optional\r\n    \"currency\": \"EUR\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"10\"\r\n        },\r\n        {\r\n            \"name\": \"Product2\",\r\n            \"price\": \"12\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"22\", // optional, but if present have precedence over sum of prices mentioned above.\r\n    \"paymentMethod\": \"VISA\", //optional\r\n    \"success_redirect\": \"https://merchant-success-page.com/\",\r\n    \"failure_redirect\": \"https://merchant-failure-page.com/\",\r\n    \"pending_redirect\": \"https://merchant-pending-page.com/\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"showCryptoConversion\": \"yes\",\r\n        \"cryptoCurrencies\": \"[\\\"BTC\\\",\\\"ETH\\\",\\\"USDT\\\",\\\"XRP\\\",\\\"LTC\\\",\\\"DOGE\\\",\\\"ETC\\\",\\\"BNB\\\",\\\"USDC\\\",\\\"SOL\\\",\\\"ADA\\\",\\\"BCH\\\",\\\"DASH\\\",\\\"BTG\\\",\\\"ZEC\\\",\\\"DGB\\\",\\\"EOS\\\",\\\"XLM\\\",\\\"TRX\\\",\\\"QTUM\\\",\\\"POL\\\",\\\"SHIB\\\",\\\"LINK\\\",\\\"DAI\\\",\\\"TON\\\",\\\"AVAX\\\",\\\"FDUSD\\\",\\\"ARB\\\",\\\"OP\\\"]\",\r\n            \"param3\": \"value3\",\r\n            \"param4\": \"value4\"\r\n        }\r\n    }","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession","description":"<p><strong>OVERIEW</strong></p>\n<p>The <code>createSession</code> API is designed to initiate a payment session for a customer after their profile has been created via the <strong>createCustomer</strong> API. The session is automatically generated at the backend on the merchant’s checkout URL. This session allows the customer to continue with their transaction without having to manually interact with the session URL, and ensures the session remains active until the payment is completed or the session expires.</p>\n<p>This API improves the user experience by reducing transaction failures and enhancing the overall payment process, thus reducing transaction churn rates.</p>\n<h3 id=\"mandatory-parameters\">Mandatory Parameters</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th>Description</th>\n<th>Example</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>customerId</td>\n<td>String</td>\n<td>The unique ID of the customer (generated from createCustomer).</td>\n<td>6731a609b6bb5a43ad66c4a6</td>\n</tr>\n</tbody>\n</table>\n</div><h4 id=\"show-crypto-conversion\">Show Crypto Conversion</h4>\n<p>Additionally, there are some default extra parameters that you can pass for allowing Crypto Conversion on Paysecure's cashier itself.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th></th>\n<th><strong>Type</strong></th>\n<th><strong>Description</strong></th>\n<th><strong>Example</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>extraParam.showCryptoConversion</td>\n<td>String</td>\n<td>This optional parameter allows customer to see crypto value equivelant to the Fiat amount the customer is planning to pay.</td>\n<td>Yes</td>\n</tr>\n<tr>\n<td>extraParam.cryptoCurrencies</td>\n<td>String</td>\n<td>Pass here the allowed crypto tokens on the cashier, where customer can see the the conversion value</td>\n<td>[\\\"BTC\\\",\\\"ETH\\\",\\\"USDT\\\",\\\"XRP\\\",\\\"LTC\\\",\\\"DOGE\\\",\\\"ETC\\\",\\\"BNB\\\",\\\"USDC\\\",\\\"SOL\\\",\\\"ADA\\\",\\\"BCH\\\",\\\"DASH\\\",\\\"BTG\\\",\\\"ZEC\\\",\\\"DGB\\\",\\\"EOS\\\",\\\"XLM\\\",\\\"TRX\\\",\\\"QTUM\\\",\\\"POL\\\",\\\"SHIB\\\",\\\"LINK\\\",\\\"DAI\\\",\\\"TON\\\",\\\"AVAX\\\",\\\"FDUSD\\\",\\\"ARB\\\",\\\"OP\\\"]</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"usage-flow\"><strong>Usage Flow</strong></h3>\n<ol>\n<li><p><strong>Customer completes the</strong> <strong><code>createCustomer</code></strong> <strong>API</strong>: Once the customer is created via the <code>createCustomer</code> API, the merchant proceeds to call the <code>createSession</code> API to generate a session.</p>\n</li>\n<li><p><strong>Merchant sends</strong> <strong><code>createSession</code></strong> <strong>request</strong>: The merchant sends a <code>POST</code> request to the <code>createSession</code> API with the customer’s <code>customerId</code> and the merchant’s <code>brandId</code>.</p>\n</li>\n<li><p><strong>Session created automatically on the checkout URL</strong>: PaySecure creates the session and associates it with the merchant’s checkout page. This session remains active on the backend, allowing the customer to continue the payment process without interruption.</p>\n</li>\n<li><p><strong>Customer proceeds to checkout</strong>: The customer is redirected to the checkout page as part of the merchant's payment flow, where the session is automatically validated. The session remains active for a set period, allowing the customer to complete the payment without needing to manually interact with the session URL.</p>\n</li>\n<li><p><strong>Session Expiry</strong>: The session expires after the set expiration time (<code>expiryOn</code>), ensuring the payment process is completed within the defined window. Default is 15 mins from the creation time.</p>\n</li>\n</ol>\n<hr />\n<h3 id=\"benefits\"><strong>Benefits</strong></h3>\n<ul>\n<li><p><strong>Seamless Checkout</strong>: The session URL is automatically generated and active at the backend, ensuring a smoother and uninterrupted customer experience.</p>\n</li>\n<li><p><strong>Reduced Transaction Failures</strong>: By ensuring the session remains active during the payment process, the chances of transaction failures due to session timeouts are minimized.</p>\n</li>\n<li><p><strong>Improved User Experience</strong>: The customer does not need to click on a session URL or navigate away from the page, leading to faster and more secure payment processing.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","name":"Cashier APIs","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","createSession"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"198cb577-ffb5-43b7-bccd-2ff04ec98d3b","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"it is mandatory to pass the BrandId in header for each createSession request. ","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"68fed1855ebbe829416b08c6\",\r\n    \"merchantRef\": \"rahultestcustomer1@paysecure.net\", // optional\r\n    \"currency\": \"EUR\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"10\"\r\n        },\r\n        {\r\n            \"name\": \"Product2\",\r\n            \"price\": \"12\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"22\", // optional, but if present have precedence over sum of prices mentioned above.\r\n    \"paymentMethod\": \"VISA\", //optional\r\n    \"success_redirect\": \"https://merchant-success-page.com/\",\r\n    \"failure_redirect\": \"https://merchant-failure-page.com/\",\r\n    \"pending_redirect\": \"https://merchant-pending-page.com/\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"status":"OK","code":200,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"sessionUrl\": \"https://api.paysecure.net/payment-session/691b02b48c73dd76eedaa379/\",\r\n    \"brandId\": \"brand_id_value\",\r\n    \"customerId\": \"68fed1855ebbe829416b08c6\",\r\n    \"sessionId\": \"691b02b48c73dd76eedaa379\",\r\n    \"expiryOn\": 1763378744,\r\n    \"createdOn\": 1763377844\r\n}"},{"id":"6d16678d-9daa-45a3-9f29-9fa06177e11a","name":"Session with CryptoConversion","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"it is mandatory to pass the BrandId in header for each createSession request. ","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"68fed1855ebbe829416b08c6\",\r\n    \"merchantRef\": \"rahultestcustomer1@paysecure.net\", // optional\r\n    \"currency\": \"EUR\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"10\"\r\n        },\r\n        {\r\n            \"name\": \"Product2\",\r\n            \"price\": \"12\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"22\", // optional, but if present have precedence over sum of prices mentioned above.\r\n    \"paymentMethod\": \"VISA\", //optional\r\n    \"success_redirect\": \"https://merchant-success-page.com/\",\r\n    \"failure_redirect\": \"https://merchant-failure-page.com/\",\r\n    \"pending_redirect\": \"https://merchant-pending-page.com/\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"showCryptoConversion\": \"yes\",\r\n        \"cryptoCurrencies\": \"[\\\"BTC\\\",\\\"ETH\\\",\\\"USDT\\\",\\\"XRP\\\",\\\"LTC\\\",\\\"DOGE\\\",\\\"ETC\\\",\\\"BNB\\\",\\\"USDC\\\",\\\"SOL\\\",\\\"ADA\\\",\\\"BCH\\\",\\\"DASH\\\",\\\"BTG\\\",\\\"ZEC\\\",\\\"DGB\\\",\\\"EOS\\\",\\\"XLM\\\",\\\"TRX\\\",\\\"QTUM\\\",\\\"POL\\\",\\\"SHIB\\\",\\\"LINK\\\",\\\"DAI\\\",\\\"TON\\\",\\\"AVAX\\\",\\\"FDUSD\\\",\\\"ARB\\\",\\\"OP\\\"]\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"status":"OK","code":200,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"sessionUrl\": \"https://api.paysecure.net/payment-session/691b02b48c73dd76eedaa379/\",\n    \"brandId\": \"brand_id_value\",\n    \"customerId\": \"68fed1855ebbe829416b08c6\",\n    \"sessionId\": \"691b02b48c73dd76eedaa379\",\n    \"expiryOn\": 1763378744,\n    \"createdOn\": 1763377844\n}"},{"id":"57ccf9d2-acca-48a1-a7ba-1f119d17a110","name":"Invalid Session","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"BrandId","value":"brand_id_value","description":"it is mandatory to pass the BrandId in header for each createSession request. ","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"68fed1855ebbe829416b08c6\",\r\n    \"merchantRef\": \"rahultestcustomer1@paysecure.net\", // optional\r\n    \"currency\": \"EUR\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"10\"\r\n        },\r\n        {\r\n            \"name\": \"Product2\",\r\n            \"price\": \"12\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"22\", // optional, but if present have precedence over sum of prices mentioned above.\r\n    \"paymentMethod\": \"VISA\", //optional\r\n    \"success_redirect\": \"https://merchant-success-page.com/\",\r\n    \"failure_redirect\": \"https://merchant-failure-page.com/\",\r\n    \"pending_redirect\": \"https://merchant-pending-page.com/\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"status":"Bad Request","code":400,"_postman_previewlanguage":null,"header":null,"cookie":[],"responseTime":null,"body":"{\r\n    \"message\": \"Customer does not exist with this Customer Id\",\r\n    \"code\": \"Customer Id is invalid\"\r\n}"}],"_postman_id":"f1041a2e-6810-448a-989b-cea08fcb2b8e"},{"name":"Payout Session","id":"4698c16a-9459-4a7c-acff-29f722be884f","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"67c9983fba18400ab6cceb8f\",\r\n    \"currency\": \"USD\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"2\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"2\",\r\n    \"tax_amount\": \"\", // optional\r\n    \"tax_percent\": \"\", // optional\r\n    \"type\": \"payout\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"showCryptoConversion\": \"yes\",\r\n        \"cryptoCurrencies\": \"[\\\"BTC\\\",\\\"ETH\\\",\\\"USDT\\\",\\\"XRP\\\",\\\"LTC\\\",\\\"DOGE\\\",\\\"ETC\\\",\\\"BNB\\\",\\\"USDC\\\",\\\"SOL\\\",\\\"ADA\\\",\\\"BCH\\\",\\\"DASH\\\",\\\"BTG\\\",\\\"ZEC\\\",\\\"DGB\\\",\\\"EOS\\\",\\\"XLM\\\",\\\"TRX\\\",\\\"QTUM\\\",\\\"POL\\\",\\\"SHIB\\\",\\\"LINK\\\",\\\"DAI\\\",\\\"TON\\\",\\\"AVAX\\\",\\\"FDUSD\\\",\\\"ARB\\\",\\\"OP\\\"]\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession","description":"<p>This API is used to initiate a payout session for a customer. By passing the <code>customerId</code> (generated via the <code>createCustomer</code> API) and specifying <code>\"type\": \"payout\"</code>, a payout session is started.<br />A <code>sessionURL</code> is returned in the response, which can be used to redirect the customer to the payout cashier. The customer can then select the payout method, pass required parameters, and the payout will be processed.</p>\n<h4 id=\"parameters\">Parameters:</h4>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Type</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><strong>customerId</strong></td>\n<td>string</td>\n<td>The unique ID of the customer for whom the payout session is created. This ID is generated by the <code>createCustomer</code> API.</td>\n</tr>\n<tr>\n<td><strong>currency</strong></td>\n<td>string</td>\n<td>The currency of the payout session (e.g., USD).</td>\n</tr>\n<tr>\n<td><strong>products</strong></td>\n<td>array</td>\n<td>A list of products associated with the payout (e.g., name and price).</td>\n</tr>\n<tr>\n<td><strong>totalAmount</strong></td>\n<td>string</td>\n<td>The total payout amount (optional. calculated dynamically if value is not passed).</td>\n</tr>\n<tr>\n<td><strong>tax_amount</strong></td>\n<td>string</td>\n<td>The tax amount to be applied (optional).</td>\n</tr>\n<tr>\n<td><strong>tax_percent</strong></td>\n<td>string</td>\n<td>The tax percentage to be applied (optional).</td>\n</tr>\n<tr>\n<td><strong>type</strong></td>\n<td>string</td>\n<td>Should be set to \"payout\" to initiate a payout session.</td>\n</tr>\n<tr>\n<td><strong>success_redirect</strong></td>\n<td>string</td>\n<td>The URL where the customer will be redirected after a successful payout.</td>\n</tr>\n<tr>\n<td><strong>pending_redirect</strong></td>\n<td>string</td>\n<td>The URL where the customer will be redirected after a pending payout.</td>\n</tr>\n<tr>\n<td><strong>failure_redirect</strong></td>\n<td>string</td>\n<td>The URL where the customer will be redirected after a failed payout attempt.</td>\n</tr>\n<tr>\n<td><strong>success_callback</strong></td>\n<td>string</td>\n<td>The callback URL for successful payout.</td>\n</tr>\n<tr>\n<td><strong>failure_callback</strong></td>\n<td>string</td>\n<td>The callback URL for failed payout.</td>\n</tr>\n<tr>\n<td><strong>extraParam</strong></td>\n<td>object</td>\n<td>Contains additional parameters for the payout session.</td>\n</tr>\n<tr>\n<td><strong>extraParam.showCryptoConversion</strong></td>\n<td>string</td>\n<td>Set to \"yes\" to display cryptocurrency conversion.</td>\n</tr>\n<tr>\n<td><strong>extraParam.cryptoCurrencies</strong></td>\n<td>string</td>\n<td>A list of accepted cryptocurrencies (e.g., BTC, ETH, USDT).</td>\n</tr>\n</tbody>\n</table>\n</div><h4 id=\"request-headers\">Request Headers:</h4>\n<ul>\n<li><p><strong>BrandId</strong>: Your unique brand ID (required).</p>\n</li>\n<li><p><strong>Content-Type</strong>: application/json (required).</p>\n</li>\n</ul>\n<h4 id=\"response\">Response:</h4>\n<p>The API will return a JSON object containing the <code>sessionURL</code> that can be used to redirect the customer to the payout cashier.</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"sessionUrl\": \"https://api.paysecure.net/payoutSession/68341ad35f895955355d5452/\",\n    \"brandId\": \"brand_id_value\",\n    \"customerId\": \"67c9983fba18400ab6cceb8f\",\n    \"sessionId\": \"68341ad35f895955355d5452\",\n    \"expiryOn\": 1748246103,\n    \"createdOn\": 1748245203\n}\n\n</code></pre>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","name":"Cashier APIs","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","createSession"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"e94c661e-d205-4126-9f40-7484afea9e75","name":"payoutSession","originalRequest":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"67c9983fba18400ab6cceb8f\",\r\n    \"currency\": \"USD\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"2\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"2\",\r\n    \"tax_amount\": \"\", // optional\r\n    \"tax_percent\": \"\", // optional\r\n    \"type\": \"payout\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"sessionUrl\": \"https://staging.paysecure.net/payoutSession/68341e385f895955355d5671/\",\n    \"brandId\": \"{yourBrandID}\",\n    \"customerId\": \"67c9983fba18400ab6cceb8f\",\n    \"sessionId\": \"68341e385f895955355d5671\",\n    \"expiryOn\": 1748246972,\n    \"createdOn\": 1748246072\n}"},{"id":"3521f463-23aa-49f4-9af9-a7fd9aae5b71","name":"payoutSession with Crypto Conversion","originalRequest":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"customerId\": \"67c9983fba18400ab6cceb8f\",\r\n    \"currency\": \"USD\",\r\n    \"products\": [\r\n        {\r\n            \"name\": \"Product1\",\r\n            \"price\": \"2\"\r\n        }\r\n    ],\r\n    \"totalAmount\": \"2\",\r\n    \"tax_amount\": \"\",\r\n    \"tax_percent\": \"\",\r\n    \"type\": \"payout\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\",\r\n    \"extraParam\": {\r\n        \"showCryptoConversion\": \"yes\",\r\n        \"cryptoCurrencies\": \"[\\\"BTC\\\",\\\"ETH\\\",\\\"USDT\\\",\\\"XRP\\\",\\\"LTC\\\",\\\"DOGE\\\",\\\"ETC\\\",\\\"BNB\\\",\\\"USDC\\\",\\\"SOL\\\",\\\"ADA\\\",\\\"BCH\\\",\\\"DASH\\\",\\\"BTG\\\",\\\"ZEC\\\",\\\"DGB\\\",\\\"EOS\\\",\\\"XLM\\\",\\\"TRX\\\",\\\"QTUM\\\",\\\"POL\\\",\\\"SHIB\\\",\\\"LINK\\\",\\\"DAI\\\",\\\"TON\\\",\\\"AVAX\\\",\\\"FDUSD\\\",\\\"ARB\\\",\\\"OP\\\"]\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"sessionUrl\": \"https://staging.paysecure.net/payoutSession/68341e385f895955355d5671/\",\n    \"brandId\": \"{yourBrandID}\",\n    \"customerId\": \"67c9983fba18400ab6cceb8f\",\n    \"sessionId\": \"68341e385f895955355d5671\",\n    \"expiryOn\": 1748246972,\n    \"createdOn\": 1748246072\n}"}],"_postman_id":"4698c16a-9459-4a7c-acff-29f722be884f"},{"name":"Check Status - Payin","id":"7888039f-2bf0-4a8f-a6d5-956bd4374d89","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/{Session ID}/","description":"<p>This endpoint retrieves the details of a session identified by the provided session ID.</p>\n<blockquote>\n<p>Note that this API only respond once the SessionURL, received in the response for session API, is clicked. </p>\n</blockquote>\n<blockquote>\n<p>Once the SessionURL is clicked and the user has selected a payment method and click on \"Pay\" button, a purchase is created on our backend. If you call this API before that, you will get an error.</p>\n</blockquote>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","name":"Cashier APIs","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","purchases","{Session ID}",""],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"e78d5794-1977-41c9-a328-8775e3a39555","name":"202 Success","originalRequest":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/6950e4ba5205280b71ac2010/"},"status":"Accepted","code":202,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 28 Dec 2025 08:03:36 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"d5308b2a-537d-466a-8273-f754ba3491b8"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 f89daa99b6a349030b23247a4977cb5e.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"Ed-N_b__1xPz7yrAt9mMc6JrgiZqMiuPi3uJbZ4AeuUKm-Ziiohlcw=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=V90OEeQkl%2Fh028giW2T2qMbuNADZ5EvKMZG33harMVuXpmo%2BnNQm5JeDtH2802Oa8hw5kJG737sqfdiLVuvIq%2F5E5tHoRdK8Zj6OU6yO255A\"}]}"},{"key":"CF-RAY","value":"9b4f8ac7caf2f4ca-IAD"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"purchaseId\": \"6950e4e3e4a1b008c2fae5c3\",\n    \"client\": {\n        \"customerId\": \"69034a5a61b460084d20c23b\",\n        \"email\": \"rahul+23@paysecure.net\",\n        \"phone\": \"+919634088561\",\n        \"full_name\": \"Rahul Agarwal\",\n        \"street_address\": \"Vaishali Jaipur\",\n        \"country\": \"NA\",\n        \"city\": \"jaipur\",\n        \"zip_code\": \"202020\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"RA\"\n    },\n    \"updated_on\": 1766909180,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"MASTER,VISA,JCB,AMEX,CRYPTO-BRIDGE,FawryPay,INTERAC-E-TRANSFER,INTERAC-REQUEST-MONEY,MOBILEMONEY,NEOSURF,PAYID,PIX,SPEI,THIRDPARTY-UPI,DISCOVER,BANKTRANSFER,VIRTUAL-IBAN,UPI-COLLECT,UPI-QR,VIRTUAL-ACCOUNT,DINERS,NETBANKING,THIRDPARTY-NETBANKING,MAYA,GCASH,INTERAC-EXPRESS,QRPH\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"This customer can not be processed !\",\n    \"errorCode\": \"NA\",\n    \"savedCardUsed\": \"NO\",\n    \"redirectType\": \"POST\",\n    \"force_recurring\": false,\n    \"created_on\": 1766909155,\n    \"merchantRef\": \"6950e4e3e4a1b008c2fae5c3\",\n    \"merchantName\": \"rahul_test\",\n    \"merchantType\": \"MERCHANT\",\n    \"purchase\": {\n        \"currency\": \"EUR\",\n        \"products\": [\n            {\n                \"name\": \"NA\",\n                \"quantity\": 1.0,\n                \"price\": 22.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 22.0,\n        \"requestAmount\": 22.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"Testing\",\n        \"brand_name\": \"Testing\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"07\",\n            \"amount\": 22.0,\n            \"card_issuer\": \"CIAGROUP\",\n            \"masked_pan\": \"55555555****4444\",\n            \"card_brand\": \"MASTER\",\n            \"card_issuer_country\": \"BR\",\n            \"card_type\": \"DEBIT\",\n            \"cardholder_name\": \"rahul\",\n            \"expiry_year\": \"30\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"183.83.53.214\",\n                \"type\": \"execute\",\n                \"payment_method\": \"MASTER\",\n                \"flow\": \"payform\",\n                \"successful\": false,\n                \"country\": \"BR\",\n                \"processing_time\": 1766909179,\n                \"extra\": {\n                    \"expiry_month\": \"07\",\n                    \"amount\": 22.0,\n                    \"card_issuer\": \"CIAGROUP\",\n                    \"masked_pan\": \"55555555****4444\",\n                    \"card_brand\": \"MASTER\",\n                    \"card_issuer_country\": \"BR\",\n                    \"card_type\": \"DEBIT\",\n                    \"cardholder_name\": \"rahul\",\n                    \"expiry_year\": \"30\"\n                },\n                \"error\": {\n                    \"message\": \"This customer can not be processed !\",\n                    \"code\": \"no_mid_found\"\n                }\n            }\n        ]\n    },\n    \"status\": \"ERROR\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1766909155\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1766909179\n        },\n        {\n            \"status\": \"error\",\n            \"timestamp\": 1766909180\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1766909186\n        }\n    ],\n    \"viewedOn\": 1766909186,\n    \"is_test\": false,\n    \"brand_id\": \"59c5ed48-caf9-464a-ba54-26e1e02bc1bc\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS334\",\n    \"issued\": \"2025-12-28\",\n    \"due\": 1766909155,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"0\",\n    \"trustScore\": \"0\",\n    \"extraFee\": \"0\",\n    \"paidOn\": 0,\n    \"receivedAmt\": 0.0,\n    \"taxAmount\": 0.0,\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"sessionId\": \"6950e4ba5205280b71ac2010\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0.0,\n    \"success_redirect\": \"https://google.com/\",\n    \"failure_redirect\": \"https://google.com/\",\n    \"pending_redirect\": \"https://google.com/\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"platform\": \"API\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/adb6e07f74ec6197ef764909736d478e/\",\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/6950e4e3e4a1b008c2fae5c3/\",\n    \"payoutProcess\": false\n}"},{"id":"bb8043a1-64a8-41ee-8897-c51ff7889910","name":"400 Bad Request","originalRequest":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/purchases/6950e4ba5205280b71ac2010/"},"status":"Bad Request","code":400,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 28 Dec 2025 08:03:36 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"d5308b2a-537d-466a-8273-f754ba3491b8"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 f89daa99b6a349030b23247a4977cb5e.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"Ed-N_b__1xPz7yrAt9mMc6JrgiZqMiuPi3uJbZ4AeuUKm-Ziiohlcw=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=V90OEeQkl%2Fh028giW2T2qMbuNADZ5EvKMZG33harMVuXpmo%2BnNQm5JeDtH2802Oa8hw5kJG737sqfdiLVuvIq%2F5E5tHoRdK8Zj6OU6yO255A\"}]}"},{"key":"CF-RAY","value":"9b4f8ac7caf2f4ca-IAD"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"message\": \"PurchaseId Not found.\",\n    \"code\": \"transaction_error\"\n}"},{"id":"89ec26b7-642c-42f7-960e-8c426df7632a","name":"401 Unauthorized","originalRequest":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/{Session ID}/"},"status":"Unauthorized","code":401,"_postman_previewlanguage":null,"header":[{"key":"Date","value":"Sun, 28 Dec 2025 08:03:36 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"d5308b2a-537d-466a-8273-f754ba3491b8"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 f89daa99b6a349030b23247a4977cb5e.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"Ed-N_b__1xPz7yrAt9mMc6JrgiZqMiuPi3uJbZ4AeuUKm-Ziiohlcw=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=V90OEeQkl%2Fh028giW2T2qMbuNADZ5EvKMZG33harMVuXpmo%2BnNQm5JeDtH2802Oa8hw5kJG737sqfdiLVuvIq%2F5E5tHoRdK8Zj6OU6yO255A\"}]}"},{"key":"CF-RAY","value":"9b4f8ac7caf2f4ca-IAD"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Incorrect secret_key\",\n    \"code\": \"authentication_failed\"\n}"}],"_postman_id":"7888039f-2bf0-4a8f-a6d5-956bd4374d89"},{"name":"Check Status - Payout","id":"16c35a74-3e73-4400-954f-bfba5187e149","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/getpayout/{Session ID}/","description":"<p>This API tells you about all the details of a Payout, including its history</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the payoutId or session id in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>payout_in_process</td>\n<td>payout is under Processing.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","name":"Cashier APIs","type":"folder"}},"urlObject":{"path":["getpayout","{Session ID}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"8110f305-ddd5-4df9-b748-85e3a231756d","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/getpayout/{Session ID}/"},"status":"Accepted","code":202,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Mon, 27 Apr 2026 07:03:52 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"9be65213-e200-4ef2-831c-683022389e8b"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 ea9784182c7536f5ce15ec71cf0089d6.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"SQqBgIYJCqc_HzF2NrYyoiCCGUdxGyPFZ3OzmUrrL-XBe56tKWTifA=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=dRx0V9WF8UC%2FPmYeyh%2Fl2YI7rIhT15NcQDiRVHdKuzF4jjsVyYmbl2imFi%2FSpP4VpmIHsFmO0xzXUjyO1%2BwKeupdremHVjRNwtqENY%2FZxgVpN7KFFzAhSQDhOMdd62Anr2zN\"}]}"},{"key":"CF-RAY","value":"9f2bf84969fa9c85-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"payoutId\": \"65ffadb4c1c83822903a9205\",\n    \"client\": {\n        \"email\": \"customer141@email.uk\",\n        \"full_name\": \"Test Person-uk\",\n        \"street_address\": \"Random city address\",\n        \"country\": \"SG\",\n        \"city\": \"Singapore\",\n        \"zip_code\": \"123456\",\n        \"stateCode\": \"test\"\n    },\n    \"updated_on\": 1711254964,\n    \"payoutMethod\": \"Payout-BANKTRANSFER\",\n    \"beneficiaryDetail\":{\n    \"bankName\": \"DBS Bank\",      \n    \"bankAccountName\": \"test test\",\n    \"bankAccountCurrency\": \"SGD\",\n    \"bankAccountNumber\": \"12345640\",\n    \"bankCountryCode\" : \"SG\",\n    \"swiftCode\": \"DBSSSGSG\",\n    \"routing_param\" :\n    {\n        \"bankCode\": \"897678\",\n        \"bankBranchCode\" : \"888\"\n           \n    }\n     },\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 1000.0,\n    \"errorMsg\": \"Currency Account has insufficient balance.\",\n    \"purpose\": \"test payout\",\n    \"created_on\": 1711254972,\n    \"merchantRef\": \"65ffadb4c1c83822903a9205\",\n    \"status\": \"ERROR\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1711254964\n        },\n        {\n            \"status\": \"error\",\n            \"timestamp\": 1711254972\n        }\n    ],\n    \"currency\": \"USD\",\n    \"success_callback\": \"https://success.com\",\n    \"failure_callback\": \"https://failure.com\"\n}"}],"_postman_id":"16c35a74-3e73-4400-954f-bfba5187e149"}],"id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52","description":"<p>Paysecure Cashier is a unified payment management solution that connects with leading PSP and acquirers, offering merchants one convenient access point to simplify transaction processing and enhance efficiency.</p>\n<p>To start the cashier system, a <strong>payment session</strong> is initiated—a secure, temporary environment generated by our payment gateway. This session encapsulates all transaction details and state information before the cashier loads, overseeing the complete lifecycle of a payment attempt—from initial setup to final completion—ensuring every necessary detail is managed safely and consistently.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"d418f8e5-428a-4ab3-9e85-19843b35c14a","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"d030bfe6-8611-4e65-9e84-089e4613094c","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"9c31c1ef-e9a4-44d8-916c-4c90e9604f52"},{"name":"User Defined Fields (UDF)","item":[],"id":"02ceacd6-cbd8-4fd7-8b2a-7552030a51b4","description":"<p>User Defined Fields (also referred to as Merchant Defined Parameters) allow you to attach custom identifiers to transactions. These identifiers can help you map transactions to your internal systems and configure advanced routing rules.</p>\n<p>Once created, you can pass the parameter in the purchases or session API using the <code>extraParam</code> object in the payload, to receive the same in the API response and the following webhooks.</p>\n<h3 id=\"adding-a-user-defined-field\">Adding a User Defined Field</h3>\n<ol>\n<li><p>Click <strong>Add Parameters</strong>.</p>\n</li>\n<li><p>Enter the <strong>Parameter Name</strong>.</p>\n</li>\n<li><p>Choose the <strong>Value Type</strong> (Numeric, String, or Boolean).</p>\n</li>\n<li><p>Click <strong>Add</strong> to save.</p>\n</li>\n</ol>\n<p>Here is how you can define UDFs in Paysecure's app.</p>\n<img src=\"https://content.pstmn.io/af86f713-7ddc-410b-81e0-0de7c10cb7ce/U2NyZWVuc2hvdCAyMDI1LTA4LTI2IGF0IDQuNDMuNTXigK9QTS5wbmc=\" />\n\n<h3 id=\"using-udf-in-api-requests\">Using UDF in API Requests</h3>\n<p>Once created, you can pass the parameter in the <code>purchases</code> or <code>session</code> API using the <code>extraParam</code> object in the payload, to receive the same in the API response and the following webhooks.</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">\"extraParam\": {\n    \"userDefinedParameter\": \"value\"\n}\n\n</code></pre>\n<h3 id=\"best-practices\">Best Practices</h3>\n<ul>\n<li><p>Use <strong>consistent naming conventions</strong> for parameters to avoid confusion across integrations.</p>\n</li>\n<li><p>Keep the number of UDFs minimal — only add fields that provide clear value (e.g., customer segment, order type, risk score).</p>\n</li>\n<li><p>Leverage UDFs in <strong>rule-based routing</strong> to optimize processing flows (e.g., route high-value transactions to a specific MID).</p>\n</li>\n<li><p>Document your UDFs internally so operations and support teams can easily reference them.</p>\n</li>\n</ul>\n<p>Note:<br />This feature is enabled only for the whitelabel merchant solution. If you are using a merchant solution, please contact your Account Manager for doing these changes.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"185d5b1e-697e-4c0c-9ed3-1aa00b840121","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"a3f50383-f5fa-4fe7-8ff2-eb1502ff2310","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"02ceacd6-cbd8-4fd7-8b2a-7552030a51b4"},{"name":"Recurring Payments","item":[{"name":"Registration Flow","item":[],"id":"169fd8a8-0ab4-4236-93d9-40eb3a5cc47c","description":"<img src=\"https://content.pstmn.io/aed8483b-3304-43c4-a305-291e37c9b534/aW1hZ2UucG5n\" alt height=\"1489\" width=\"734\" />","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"4dd59959-4622-432c-bc11-18d1c70d6b36","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"8f04a996-e1ca-482c-9407-e2ccc5c2b3da","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"169fd8a8-0ab4-4236-93d9-40eb3a5cc47c"},{"name":"Recurring Flow","item":[],"id":"dc8652bb-1567-4fa2-8002-18de31c41c64","description":"<p><strong>For cases where the Merchant handles the scheduling:</strong></p>\n<img src=\"https://content.pstmn.io/0fde3212-41fe-4574-9371-3dcc9cee33ec/aW1hZ2UucG5n\" alt height=\"541\" width=\"703\" />\n\n<p><strong>For cases where Paysecure handles the scheduling:</strong></p>\n<img src=\"https://content.pstmn.io/384c80a7-159a-4777-ac2c-0bcbb4aa66a8/aW1hZ2UucG5n\" alt height=\"671\" width=\"806\" />","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"4dd59959-4622-432c-bc11-18d1c70d6b36","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"8f04a996-e1ca-482c-9407-e2ccc5c2b3da","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"dc8652bb-1567-4fa2-8002-18de31c41c64"},{"name":"APIs","item":[{"name":"Create Customer","id":"5f080837-26f1-4410-995d-cc82189b6135","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"fullName\": \"Rahul Agarwal\",\n    \"emailId\": \"rahul+26@paysecure.net\",\n    \"dateOfBirth\": \"1994-06-03\",\n    \"phoneNo\": \"+91 797639082\",\n    \"city\": \"Jaipur\",\n    \"stateCode\": \"RJ\",\n    \"zipCode\": \"302018\",\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\n    \"country\": \"IN\",\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\n    \"CustRegDate\": \"2023-12-27\", //non-mandatory - customer registration date on merchant site\n    \"SuccessTxn\": \"32\", //non-mandatory - total successful customer orders on merchant site\n    \"extraParam\": {\n        \"param1\": \"value1\",\n        \"param2\": \"value2\",\n        \"param3\": \"value3\",\n        \"param4\": \"value4\"\n    }\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer","description":"<p><strong>OVERIEW</strong></p>\n<p>The <strong>createCustomer API</strong> allows merchants to create a customer profile on Paysecure when a user visits their website, facilitating a seamless payment experience by pre-filling the customer's details, on the Paysecure Cashier.</p>\n<p>The API takes in customer information and returns a unique customerID that can be passed in purchase payload, eliminating the need for customers to manually enter their details during transactions.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th><strong>Required</strong></th>\n<th>Description</th>\n<th>Example</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>merchantCustomerId</td>\n<td>String</td>\n<td>Yes</td>\n<td>unique customer ID provided by merchant. This can be email, mobile or an alphanumeric string</td>\n<td><a href=\"https://mailto:rahultestcustomer@paysecure.net\">rahultestcustomer@paysecure.net</a></td>\n</tr>\n<tr>\n<td>fullName</td>\n<td>String</td>\n<td>Yes</td>\n<td>Full name of the customer.</td>\n<td>Rahul Agarwal</td>\n</tr>\n<tr>\n<td>emailId</td>\n<td>String</td>\n<td>Yes</td>\n<td>Email address of the customer.</td>\n<td><a href=\"https://mailto:test@paysecure.net\">test@paysecure.net</a></td>\n</tr>\n<tr>\n<td>dateOfBirth</td>\n<td>String</td>\n<td>Optional</td>\n<td>Customer's date of birth in YYYY-MM-DD format.</td>\n<td>1995-12-27</td>\n</tr>\n<tr>\n<td>phoneNo</td>\n<td>String</td>\n<td>Yes</td>\n<td>Customer's phone number. Preferred with the country code</td>\n<td>+91 797639082</td>\n</tr>\n<tr>\n<td>city</td>\n<td>String</td>\n<td>Optional</td>\n<td>City of the customer.</td>\n<td>Jaipur</td>\n</tr>\n<tr>\n<td>stateCode</td>\n<td>String</td>\n<td>Yes</td>\n<td>State code of the customer.</td>\n<td>RJ</td>\n</tr>\n<tr>\n<td>zipCode</td>\n<td>String</td>\n<td>Optional</td>\n<td>Postal code of the customer's location.</td>\n<td>302018</td>\n</tr>\n<tr>\n<td>address</td>\n<td>String</td>\n<td>Optional</td>\n<td>Full address of the customer.</td>\n<td>House Number 53, Vaishali Nagar, Jaipur</td>\n</tr>\n<tr>\n<td>country</td>\n<td>String</td>\n<td>Yes</td>\n<td>Country code (ISO 3166-1 alpha-2).</td>\n<td>IN</td>\n</tr>\n<tr>\n<td>custRegDate</td>\n<td>Sting</td>\n<td>Optional</td>\n<td>Customer registration date on merchant site in YYYY-MM-DD format.</td>\n<td>2023-12-27</td>\n</tr>\n<tr>\n<td>successTxn</td>\n<td>String</td>\n<td>Optional</td>\n<td>Number of successful transactions customer has carried on merchant site.</td>\n<td>32</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"user-flow\"><strong>User Flow</strong></h3>\n<ol>\n<li><p><strong>Customer visits merchant's website</strong>: The customer selects the product or service and proceeds to checkout page.</p>\n</li>\n<li><p><strong>Merchant calls the</strong> <strong><code>createCustomer</code></strong> <strong>API</strong>: The merchant sends a <code>POST</code> request to the Paysecure API with the customer's details.</p>\n</li>\n<li><p><strong>Customer ID generation</strong>: Paysecure processes the request and generates a unique <code>customerId</code> which is returned in the response.</p>\n</li>\n<li><p><strong>Payment Process</strong>: The merchant uses the <code>customerId</code> for subsequent session creation, ensuring the customer doesn’t need to re-enter their details for future payments.</p>\n</li>\n</ol>\n<hr />\n<h3 id=\"benefits\"><strong>Benefits</strong></h3>\n<ul>\n<li><p><strong>Seamless user experience</strong>: The customer does not have to enter their details manually for every purchase.</p>\n</li>\n<li><p><strong>Faster Checkout</strong>: The merchant can use the <code>customerId</code> for faster payment processing.</p>\n</li>\n<li><p><strong>Data Security</strong>: Customer details are stored securely and can be reused across transactions, reducing the chances of errors.</p>\n</li>\n</ul>\n<h3 id=\"implementing-createcustomer-on-merchant-site\">Implementing createCustomer on merchant site:</h3>\n<p>The <code>createCustomer</code> can be implemented on merchant site in one of two ways, depending on merchant’s integration flow:</p>\n<p><strong>At Checkout:</strong></p>\n<p>When a customer initiates the checkout process, your system should invoke the <code>createCustomer</code> API, before actually starting the session.</p>\n<ul>\n<li><p><strong>Call</strong> <strong><code>createCustomer</code></strong>: This API call generates a unique customer ID.</p>\n</li>\n<li><p><strong>Use of Customer ID:</strong> Pass the returned customer ID in Session API, when creating a payment session.</p>\n</li>\n</ul>\n<p><strong>Upon Customer Login:</strong></p>\n<p>Alternatively, merchants may choose to call <code>createCustomer</code> at the time of customer login on their site.</p>\n<ul>\n<li><p><strong>Persistent Customer Profiles:</strong> This approach can help build or maintain a persistent customer profile, ensuring the customer ID is available for any subsequent payment sessions without needing to call <code>createCustomer</code> again.</p>\n</li>\n<li><p><strong>Integration Flexibility:</strong> This is useful for merchants who want to initialize customer data early in the customer journey rather than during checkout.</p>\n</li>\n</ul>\n<p>The method you choose depends on your business requirements and how your system is architected. Regardless of when you call it, the resulting customer ID must be passed to the <code>createSession</code> API to initiate a payment session.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"path":["customer"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"f85b2640-a686-458c-9f89-c390da0126d6","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"fullName\": \"Rahul Agarwal\",\r\n    \"emailId\": \"rahul+26@paysecure.net\",\r\n    \"dateOfBirth\": \"1994-06-03\",\r\n    \"phoneNo\": \"+91 797639082\",\r\n    \"city\": \"Jaipur\",\r\n    \"stateCode\": \"RJ\",\r\n    \"zipCode\": \"302018\",\r\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\r\n    \"country\": \"IN\",\r\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\r\n    \"CustRegDate\": \"2023-12-27\", //non-mandatory - customer registration date on merchant site\r\n    \"SuccessTxn\": \"32\", //non-mandatory - total successful customer orders on merchant site\r\n    \"extraParam\": {\r\n        \"param1\": \"value1\",\r\n        \"param2\": \"value2\",\r\n        \"param3\": \"value3\",\r\n        \"param4\": \"value4\"\r\n    }\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/customer"},"status":"OK","code":200,"_postman_previewlanguage":null,"header":[{"key":"Date","value":"Sat, 31 Jan 2026 14:56:20 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"d248f17f-e674-4a0a-8dfe-b862eabc5cc5"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 6225fd23298b677711e0721417a30ae2.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"bbu1ItT0MbY2zy91fGODaOu6WWheF2CPo7DPYkIh-lxzFZFdFDgEyw=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=lUm%2FZBBs45Cas%2FwmM6M3RYhfSTKtEYd5XVPihkyRHHF92PBKUR%2BaNp5%2F65qClhn8h%2FMKHq6yiUSf2WFapmiBdVJdzE86w6J8%2B%2F7AvvxYzio%3D\"}]}"},{"key":"CF-RAY","value":"9c6a0e1fbf4657b2-IAD"}],"cookie":[],"responseTime":null,"body":"{\n    \"customerId\": \"691afbc6fd96d34a8113a34d\",\n    \"merchantCustomerId\": \"rahultestcustomer@paysecure.net\",\n    \"fullName\": \"Rahul Agarwal\",\n    \"emailId\": \"rahul+26@paysecure.net\",\n    \"dateOfBirth\": \"1994-06-03\",\n    \"phoneNo\": \"+91 797639082\",\n    \"brandID\": \"1d666074-39be-4b90-aec9-e9de78fbdcb9\",\n    \"city\": \"Jaipur\",\n    \"zipCode\": \"302018\",\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\n    \"country\": \"IN\",\n    \"stateCode\": \"RJ\",\n    \"custRegDate\": \"2023-12-27\",\n    \"successTrans\": 0,\n    \"createdOn\": 1763376070,\n    \"lastUpdated\": 0,\n    \"lastActivity\": 1763376070,\n    \"extraParam\": {\n        \"param1\": \"value1\",\n        \"param2\": \"value2\",\n        \"param3\": \"value3\",\n        \"param4\": \"value4\"\n    }\n}"}],"_postman_id":"5f080837-26f1-4410-995d-cc82189b6135"},{"name":"Get Customer","id":"a2401032-1393-40ef-8351-dbd898d4b454","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\"\n}","options":{"raw":{"language":"json"}}},"url":"https://app.paysecure.net/api/v1/customer","description":"<p>This endpoint makes an HTTP GET request to retrieve customer information from the Paysecure API.</p>\n<h3 id=\"request\">Request</h3>\n<p>The request does not include any query parameters, but it uses a raw request body with the following parameter \"merchantCustomerId\", which will be the customer id on the merchant's side.</p>\n<h3 id=\"response\">Response</h3>\n<p>The response of this request can be documented as a JSON schema.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","customer"],"host":["app","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"b0707d55-5c1a-4d50-901e-ac1581014021","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Accept","value":"*/*","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\"\n}","options":{"raw":{"language":"json"}}},"url":"https://app.paysecure.net/api/v1/customer"},"status":"OK","code":200,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sat, 31 Jan 2026 15:00:13 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"x-session-id","value":"74520247-3540-48b2-81f9-33fd50e71e01"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"Set-Cookie","value":"SESSION=NDRjYjEwZGQtNTAyMy00MDA1LWFiNTUtNTBmNmY2YWY1NjZj; Path=/; Secure; HttpOnly; SameSite=Strict"},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=gy0s5195rsESyn%2B0cQcmwej6qKnbNzrAcSxW%2F%2FrtkYk52a4Lipz%2FTBcpX5IjTYOHLNsLsPeT9jJFd4rUsIPUJbu4R%2B%2BcaGEmcMT6de1u%2FVA%3D\"}]}"},{"key":"CF-RAY","value":"9c6a13d27f38a3ba-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"customerId\": \"691afbc6fd96d34a8113a34d\",\n    \"merchantCustomerId\": \"rahultestcustomer1@paysecure.net\",\n    \"fullName\": \"Rahul Agarwal\",\n    \"emailId\": \"rahul+26@paysecure.net\",\n    \"dateOfBirth\": \"1994-06-03\",\n    \"phoneNo\": \"+91 797639082\",\n    \"brandID\": \"1d666074-39be-4b90-aec9-e9de78fbdcb9\",\n    \"city\": \"Jaipur\",\n    \"zipCode\": \"302018\",\n    \"address\": \"House Number 53, Vaishali Nagar, Jaipur\",\n    \"country\": \"IN\",\n    \"stateCode\": \"RJ\",\n    \"custRegDate\": \"2023-12-27\",\n    \"successTrans\": 0,\n    \"createdOn\": 1763376070,\n    \"lastUpdated\": 0,\n    \"lastActivity\": 1763376070,\n    \"extraParam\": {\n        \"param1\": \"value1\",\n        \"param2\": \"value2\",\n        \"param3\": \"value3\",\n        \"param4\": \"value4\"\n    }\n}"}],"_postman_id":"a2401032-1393-40ef-8351-dbd898d4b454"},{"name":"Create Session (CIT)","id":"db129eb4-636a-4ed4-819f-6eb1f6bc0dcc","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"customerId\": \"685f870cf3435a2d5b35ee08\", // mandatory\n    \"currency\": \"EUR\",\n    \"products\": [\n        {\n            \"name\": \"Product1\",\n            \"price\": \"10\"\n        },\n        {\n            \"name\": \"Product2\",\n            \"price\": \"10\"\n        }\n    ],\n    \"totalAmount\": \"21\", // optional, but if present have precedence over sum of prices.\n    \"paymentMethod\": \"VISA\", //optional\n    \"success_redirect\": \"https://merchant.com/success\",\n    \"pending_redirect\": \"https://merchant.com/pending\",\n    \"failure_redirect\": \"https://merchant.com/failure\",\n    \"success_callback\": \"https://merchant.com/webhook/success\",\n    \"failure_callback\": \"https://merchant.com/webhook/failure\",\n    \"payment_type\": \"mandate\",\n    \"mandate\": {\n        \"mandate_max_amount\": \"5000\", // the mandated amount should be less than or equal to this amount.\n        \"amount_variability\": \"Fixed\",\n        \"start_date\": \"1598965200\", // epoch timestamp or UNIX timestamp\n        \"end_date\": \"1914141600\", // epoch timestamp or UNIX timestamp\n        \"frequency\": \"MONTHLY\",\n        \"rule\": \"on\",\n        \"value\": 1\n    }\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession","description":"<p><strong>OVERIEW</strong></p>\n<p>The <code>createSession</code> API is designed to initiate a payment session for a customer after their profile has been created via the <strong>createCustomer</strong> API. The session is automatically generated at the backend on the merchant’s checkout URL. This session allows the customer to continue with their transaction without having to manually interact with the session URL, and ensures the session remains active until the payment is completed or the session expires.</p>\n<p>This API improves the user experience by reducing transaction failures and enhancing the overall payment process, thus reducing transaction churn rates.</p>\n<h3 id=\"mandatory-parameters\">Mandatory Parameters</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th>Description</th>\n<th>Example</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>customerId</td>\n<td>String</td>\n<td>The unique ID of the customer (generated from createCustomer).</td>\n<td>6731a609b6bb5a43ad66c4a6</td>\n</tr>\n</tbody>\n</table>\n</div><p>To register a mandate, pass mandate related parameters in the Create Session API to create a mandate registration purchase. Post transaction completion, use Get Status API and Webhooks to capture mandate registration details.</p>\n<h3 id=\"additional-parameters-for-this-usecase\">Additional <strong>parameters for this usecase:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>payment_type</td>\n<td>Mandatory.  <br />To be passed as \"mandate\".</td>\n</tr>\n<tr>\n<td>mandate</td>\n<td>Mandatory.  <br />This object is mandatory for mandate flow</td>\n</tr>\n<tr>\n<td>mandate.mandate_max_amount</td>\n<td>Optional  <br />Maximum amount for a mandate.</td>\n</tr>\n<tr>\n<td>mandate.amount_variability</td>\n<td>Optional  <br />Specifies whether the amount is fixed or variable for each recurrence.  <br />  <br />Possible values: Fixed or Variable</td>\n</tr>\n<tr>\n<td>mandate.start_date</td>\n<td>Mandatory  <br />Specifies the time when the mandate will start.</td>\n</tr>\n<tr>\n<td>mandate.end_date</td>\n<td>Mandatory  <br />Specifies the time when the mandate will end.</td>\n</tr>\n<tr>\n<td>mandate.frequency</td>\n<td>Mandatory  <br />Defines the frequency of mandate execution, how often a customer should be charged.  <br />  <br />Possible Values:  <br /><strong>ONETIME</strong>: This is for a one-time mandate. The customer provides authorisation to debit their account a single time for a specific amount.  <br />  <br /><strong>DAILY</strong>: Recurring mandate. The customer provides authorisation to debit their account daily for a specific amount.  <br />  <br /><strong>WEEKLY</strong>: Recurring mandate. Authorisation given by a customer to debit their account weekly once for a specified amount.  <br />  <br /><strong>FORTNIGHTLY</strong>: Recurring mandate. The customer provides authorisation to debit their account fortnightly for a specific amount.  <br />  <br /><strong>MONTHLY</strong>: Recurring mandate. The customer provides authorisation to debit their account monthly for a specific amount.  <br />  <br /><strong>BIMONTHLY</strong>: Recurring mandate. The customer provides authorisation to debit their account bimonthly for a specific amount.  <br />  <br /><strong>QUARTERLY</strong>: Recurring mandate. The customer provides authorisation to debit their account quarterly for a specific amount.  <br />  <br /><strong>HALFYEARLY</strong>: Recurring mandate. The customer provides authorisation to debit their account once in every 6 months for a specific amount.  <br />  <br /><strong>YEARLY</strong>: Recurring mandate. The customer provides authorisation to debit their account once a year for a specific amount.  <br />  <br /><strong>ASPRESENTED</strong>: For cases where the scheduling is handled by the merchant. The customer provides authorization to debit their account whenever there is an execution request.</td>\n</tr>\n<tr>\n<td>mandate.rule</td>\n<td>Optional.  <br />Indicates the recurrence rule of the mandate. This rule is not required for onetime, daily, and aspresented recurrence patterns.  <br />Possible values: on/before/after  <br />By Default: on</td>\n</tr>\n<tr>\n<td>mandate.value</td>\n<td>Conditional.  <br />The recurrence Value of the mandate.  <br />It is not required for ONETIME, DAILY and ASPRESENTED frequencies.  <br />  <br />Possible values:  <br />For WEEKLY: The value should be 1-Monday to 7-Sunday.  <br />For MONTHLY, BIMONTHLY, QUARTERLY, HALFYEARLY or YEARLY: The value should be between 1 to 30/31 days.  <br />  <br />By Default: The value will be treated as 1.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"usage-flow\"><strong>Usage Flow</strong></h3>\n<ol>\n<li><p><strong>Customer completes the</strong> <strong><code>createCustomer</code></strong> <strong>API</strong>: Once the customer is created via the <code>createCustomer</code> API, the merchant proceeds to call the <code>createSession</code> API to generate a session.</p>\n</li>\n<li><p><strong>Merchant sends</strong> <strong><code>createSession</code></strong> <strong>request</strong>: The merchant sends a <code>POST</code> request to the <code>createSession</code> API with the customer’s <code>customerId</code> and the merchant’s <code>brandId</code>.</p>\n</li>\n<li><p><strong>Session created automatically on the checkout URL</strong>: PaySecure creates the session and associates it with the merchant’s checkout page. This session remains active on the backend, allowing the customer to continue the payment process without interruption.</p>\n</li>\n<li><p><strong>Customer proceeds to checkout</strong>: The customer is redirected to the checkout page as part of the merchant's payment flow, where the session is automatically validated. The session remains active for a set period, allowing the customer to complete the payment without needing to manually interact with the session URL.</p>\n</li>\n<li><p><strong>Session Expiry</strong>: The session expires after the set expiration time (<code>expiryOn</code>), ensuring the payment process is completed within the defined window. Default is 15 mins from the creation time.</p>\n</li>\n</ol>\n<hr />\n<h3 id=\"benefits\"><strong>Benefits</strong></h3>\n<ul>\n<li><p><strong>Seamless Checkout</strong>: The session URL is automatically generated and active at the backend, ensuring a smoother and uninterrupted customer experience.</p>\n</li>\n<li><p><strong>Reduced Transaction Failures</strong>: By ensuring the session remains active during the payment process, the chances of transaction failures due to session timeouts are minimized.</p>\n</li>\n<li><p><strong>Improved User Experience</strong>: The customer does not need to click on a session URL or navigate away from the page, leading to faster and more secure payment processing.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","createSession"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"b6df31a9-1f62-4235-b837-543d77192b95","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"brand_id_value","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"customerId\": \"685f870cf3435a2d5b35ee08\", // mandatory\n    \"currency\": \"EUR\",\n    \"products\": [\n        {\n            \"name\": \"Product1\",\n            \"price\": \"10\"\n        },\n        {\n            \"name\": \"Product2\",\n            \"price\": \"10\"\n        }\n    ],\n    \"totalAmount\": \"21\", // optional, but if present have precedence over sum of prices.\n    \"paymentMethod\": \"VISA\", //optional\n    \"success_redirect\": \"https://merchant.com/success\",\n    \"pending_redirect\": \"https://merchant.com/pending\",\n    \"failure_redirect\": \"https://merchant.com/failure\",\n    \"success_callback\": \"https://merchant.com/webhook/success\",\n    \"failure_callback\": \"https://merchant.com/webhook/failure\",\n    \"payment_type\": \"mandate\",\n    \"mandate\": {\n        \"mandate_max_amount\": \"5000\", // the mandated amount should be less than or equal to this amount.\n        \"amount_variability\": \"Fixed\",\n        \"start_date\": \"1598965200\", // epoch timestamp or UNIX timestamp\n        \"end_date\": \"1914141600\", // epoch timestamp or UNIX timestamp\n        \"frequency\": \"MONTHLY\",\n        \"rule\": \"on\",\n        \"value\": 1\n    }\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/createSession"},"status":"OK","code":200,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sat, 31 Jan 2026 15:03:03 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"a1b350a8-3571-4d8d-bc24-d101d22cd00a"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 f50e53e9e947bca4dadaaf68ff4c7ea4.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"PPcszsJpkuNycxcxWExDrgtmzycS3Ty-qSugN-xvzxN5XDNbUuYX4A=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=rZYK3Hg4zn%2FCuotFLtqHtD2%2F1oVqT7cNmz67YbXBCtsgOhig8X7SPRj8n%2BH9ifhPdt2TF5yERePKHIScEDWDp3BYw9aY1WM%2FmECM6XWiUQw%3D\"}]}"},{"key":"CF-RAY","value":"9c6a17f2cb21d64b-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"sessionUrl\": \"https://api.paysecure.net/api/v1/session/685bdefb9a1a8f16b3c4489c/\",\n    \"brandId\": \"<UUID>\",\n    \"customerId\": \"685bdd529a1a8f16b3c445a4\",\n    \"sessionId\": \"685cc8515e3af922dd0e8c31\",\n    \"expiryOn\": 1750852223,\n    \"createdOn\": 1750851323,\n    \"expiry_in_mins\": \"86400\"\n}"}],"_postman_id":"db129eb4-636a-4ed4-819f-6eb1f6bc0dcc"},{"name":"Create Purchase (CIT)","id":"1c2b3650-3754-4c40-9708-375dfc292dc6","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"rahul@gmail.com\",\n        \"country\": \"GB\",\n        \"city\": \"London\",\n        \"stateCode\": \"LO\",\n        \"street_address\": \"Flat 61 Priory Court Romford RM7 0FY\",\n        \"zip_code\": \"234567\",\n        \"full_name\": \"Rahul Agarwal\",\n        \"phone\": \"+44 07932665877\" // optional\n    },\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"product name\",\n                \"price\": \"1\"\n            }\n        ]\n    },\n    \"merchantRef\": \"your-merchant-ref\", // optional\n    \"paymentMethod\": \"MASTER\",\n    \"brand_id\": \"your-brand-id\",\n    \"payment_type\": \"mandate\",\n    \"mandate\": {\n        \"mandate_max_amount\": \"5000\", // Conditional\n        \"amount_variability\": \"Fixed\", // optional\n        \"start_date\": \"1598965200\", // optional\n        \"end_date\": \"1914141600\", // optional\n        \"frequency\": \"MONTHLY\", // mandatory\n        \"rule\": \"on\", // optional\n        \"value\": 1 // conditional\n    },\n    \"success_redirect\": \"https://merchant.com/success\", // mandatory\n    \"pending_redirect\": \"https://merchant.com/pending\", // mandatory\n    \"failure_redirect\": \"https://merchant.com/failure\", // mandatory\n    \"success_callback\": \"https://merchant.com/webhook/success\", // mandatory\n    \"failure_callback\": \"https://merchant.com/webhook/failure\" // mandatory\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<p><strong>OVERIEW</strong></p>\n<p>The <code>create Purchase</code> API is designed to initiate a payment for a merchant who doesn't want to use Paysecure's cashier and wants to keep everything S2S.</p>\n<p>The merchant doesn't need to create a customer in this case and directly needs to call the purchase API and then call the S2S API after that.</p>\n<h3 id=\"additional-parameters-for-this-usecase\">Additional <strong>parameters for this usecase:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>payment_type</td>\n<td>Mandatory.  <br />To be passed as \"mandate\".</td>\n</tr>\n<tr>\n<td>paymentMethod</td>\n<td>Mandatory.  <br />Example: MASTER, VISA</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Mandatory.  <br />Your brand id.</td>\n</tr>\n<tr>\n<td>mandate</td>\n<td>Mandatory.  <br />This object is mandatory for mandate flow</td>\n</tr>\n<tr>\n<td>mandate.mandate_max_amount</td>\n<td>Conditional.  <br />Mandatory when amount_variability is \"Variable\".  <br />Maximum amount for a mandate.</td>\n</tr>\n<tr>\n<td>mandate.amount_variability</td>\n<td>Optional  <br />Specifies whether the amount is fixed or variable for each recurrence.  <br />  <br />Possible values: Fixed or Variable</td>\n</tr>\n<tr>\n<td>mandate.start_date</td>\n<td>Optional  <br />Specifies the time when the mandate will start.</td>\n</tr>\n<tr>\n<td>mandate.end_date</td>\n<td>Optional  <br />Specifies the time when the mandate will end.  <br />(If not passed then indefinite)</td>\n</tr>\n<tr>\n<td>mandate.frequency</td>\n<td>Mandatory  <br />Defines the frequency of mandate execution, how often a customer should be charged.  <br />  <br />Possible Values:  <br /><strong>ONETIME</strong>: This is for a one-time mandate. The customer provides authorisation to debit their account a single time for a specific amount.  <br />  <br /><strong>DAILY</strong>: Recurring mandate. The customer provides authorisation to debit their account daily for a specific amount.  <br />  <br /><strong>WEEKLY</strong>: Recurring mandate. Authorisation given by a customer to debit their account weekly once for a specified amount.  <br />  <br /><strong>FORTNIGHTLY</strong>: Recurring mandate. The customer provides authorisation to debit their account fortnightly for a specific amount.  <br />  <br /><strong>MONTHLY</strong>: Recurring mandate. The customer provides authorisation to debit their account monthly for a specific amount.  <br />  <br /><strong>BIMONTHLY</strong>: Recurring mandate. The customer provides authorisation to debit their account bimonthly for a specific amount.  <br />  <br /><strong>QUARTERLY</strong>: Recurring mandate. The customer provides authorisation to debit their account quarterly for a specific amount.  <br />  <br /><strong>HALFYEARLY</strong>: Recurring mandate. The customer provides authorisation to debit their account once in every 6 months for a specific amount.  <br />  <br /><strong>YEARLY</strong>: Recurring mandate. The customer provides authorisation to debit their account once a year for a specific amount.  <br />  <br /><strong>ASPRESENTED</strong>: For cases where the scheduling is handled by the merchant. The customer provides authorization to debit their account whenever there is an execution request.</td>\n</tr>\n<tr>\n<td>mandate.rule</td>\n<td>Optional.  <br />Indicates the recurrence rule of the mandate. This rule is not required for onetime, daily, and aspresented recurrence patterns.  <br />Possible values: on/before/after  <br />By Default: on</td>\n</tr>\n<tr>\n<td>mandate.value</td>\n<td>Conditional.  <br />The recurrence Value of the mandate.  <br />It is not required for ONETIME, DAILY and ASPRESENTED frequencies.  <br />  <br />Possible values:  <br />For WEEKLY: The value should be 1-Monday to 7-Sunday.  <br />For MONTHLY, BIMONTHLY, QUARTERLY, HALFYEARLY or YEARLY: The value should be between 1 to 30/31 days.  <br />  <br />By Default: The value will be treated as 1.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","purchases"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"7624599c-5088-4af3-900e-3a657484f3b9","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"rahul@gmail.com\",\n        \"country\": \"GB\",\n        \"city\": \"London\",\n        \"stateCode\": \"LO\",\n        \"street_address\": \"Flat 61 Priory Court Romford RM7 0FY\",\n        \"zip_code\": \"234567\",\n        \"full_name\": \"Rahul Agarwal\",\n        \"phone\": \"+44 07932665877\" // optional\n    },\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"product name\",\n                \"price\": \"1\"\n            }\n        ]\n    },\n    \"merchantRef\": \"your-merchant-ref\", // optional\n    \"paymentMethod\": \"MASTER\",\n    \"brand_id\": \"your-brand-id\",\n    \"payment_type\": \"mandate\",\n    \"mandate\": {\n        \"mandate_max_amount\": \"5000\", // Conditional\n        \"amount_variability\": \"Fixed\", // optional\n        \"start_date\": \"1598965200\", // optional\n        \"end_date\": \"1914141600\", // optional\n        \"frequency\": \"MONTHLY\", // mandatory\n        \"rule\": \"on\", // optional\n        \"value\": 1 // conditional\n    },\n    \"success_redirect\": \"https://merchant.com/success\", // mandatory\n    \"pending_redirect\": \"https://merchant.com/pending\", // mandatory\n    \"failure_redirect\": \"https://merchant.com/failure\", // mandatory\n    \"success_callback\": \"https://merchant.com/webhook/success\", // mandatory\n    \"failure_callback\": \"https://merchant.com/webhook/failure\" // mandatory\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"status":"Unauthorized","code":401,"_postman_previewlanguage":null,"header":[{"key":"Date","value":"Mon, 30 Mar 2026 12:23:05 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"668295f8-5770-4492-8318-01e2d1c09664"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 b4011ac432e4f034161d5cccc8a4ac80.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"46KSjvCpG3Uv-3pzVOVedkJkacP2LZAI0m9ByboJ-rzLxQkfNNycJA=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=1p%2FF34n2kiKpiE2WnCntzJPGKU28mcMx4pIFZ9F6UFZqmnoSxQEqZQ44WCu6SsOg5eYfqPqYGdhXxgBbuVLNwP5Xyc2OqoL1lTauqUylCkCPuOXJ1VRrvygGOmX9Yslw6BqJ\"}]}"},{"key":"CF-RAY","value":"9e471560fd16d6d5-IAD"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"69f8d167db7ca561ab27c484\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"paysecuretest@gmail.com\",\n        \"street_address\": \"Flat 61 Priory Court Romford RM7 0FY\",\n        \"country\": \"GB\",\n        \"city\": \"London\",\n        \"zip_code\": \"234567\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"LO\"\n    },\n    \"updated_on\": 1777914215,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"VISA\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"errorCode\": \"NA\",\n    \"force_recurring\": false,\n    \"created_on\": 1777914215,\n    \"merchantRef\": \"69f8d167db7ca561ab27c484\",\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"product name\",\n                \"quantity\": 1.0,\n                \"price\": 5.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 5.0,\n        \"requestAmount\": 5.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"Testing\",\n        \"brand_name\": \"Testing\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1777914215\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"59c5ed48-caf9-464a-ba54-26e1e02bc1bc\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS1736\",\n    \"issued\": \"2026-05-04\",\n    \"due\": 1777914215,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"extraFee\": \"0\",\n    \"totalRefunded\": 0.0,\n    \"paidOn\": 0,\n    \"receivedAmt\": 0.0,\n    \"taxAmount\": 0.0,\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"sessionId\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0.0,\n    \"success_redirect\": \"https://merchant.com/success\",\n    \"failure_redirect\": \"https://merchant.com/failure\",\n    \"pending_redirect\": \"https://merchant.com/pending\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://merchant.com/webhook/success\",\n    \"failure_callback\": \"https://merchant.com/webhook/failure\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"2406:b400:75:22bd:b48e:a33e:4e26:a542\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/16550278d7e374e53048b72dcf253a3a/\",\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/69f8d167db7ca561ab27c484/\",\n    \"payoutProcess\": false,\n    \"payment_type\": \"mandate\",\n    \"mandate\": {\n        \"frequency\": \"ASPRESENTED\",\n        \"rule\": \"on\",\n        \"value\": null,\n        \"mandate_max_amount\": null,\n        \"amount_variability\": \"Variable\",\n        \"end_date\": null,\n        \"mandate_status\": \"CREATED\",\n        \"mandate_id\": \"69f8d167db7ca561ab27c484\"\n    }\n}"}],"_postman_id":"1c2b3650-3754-4c40-9708-375dfc292dc6"},{"name":"S2S API","id":"88d85203-1a5d-40f8-badb-f41bd9d22354","protocolProfileBehavior":{"disableBodyPruning":true,"disableUrlEncoding":false},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"cardholder_name\": \"dk\",\r\n    \"card_number\": \"4111111111111111\",\r\n    \"expires\": \"10/23\",\r\n    \"cvc\": \"345\",\r\n    \"remember_card\": \"on\",\r\n    \"remote_ip\": \"157.38.242.7\",\r\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\r\n    \"accept_header\": \"text/html\",\r\n    \"language\": \"en-US\",\r\n    \"java_enabled\": false,\r\n    \"javascript_enabled\": true,\r\n    \"color_depth\": 24,\r\n    \"utc_offset\": 0,\r\n    \"screen_width\": 1920,\r\n    \"screen_height\": 1080\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/p/64bff4fff63e36669499e9c8/?s2s=true","description":"<p>This API would be the 2nd in sequence to call if the call to <code>/purchases/</code> was successful in step 1. and you want to do the transaction via Server-to-Server mode.</p>\n<p>The request body would contain the details of the card that's to be transacted upon.</p>\n<h3 id=\"mandatory-parameters-in-request-body\"><strong>Mandatory parameters in request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>remote_ip</td>\n<td>IP address of the customer’s device used for transaction. Helps in fraud checks and risk scoring. Ex- 157.38.242.7</td>\n</tr>\n<tr>\n<td>user_agent</td>\n<td>Full browser and operating system details captured from HTTP header. EX- Chrome/5.0 (X11; Linux x86_64)</td>\n</tr>\n<tr>\n<td>accept_header</td>\n<td>Browser’s accepted content types (from HTTP header). Used for validating request origin and device info. EX- text/html</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"essential-parameters-in-request-body\"><strong>Essential parameters in request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>cardholder_name</td>\n<td>Name of the cardholder</td>\n</tr>\n<tr>\n<td>card_number</td>\n<td>The card numbers Must be 10-20 characters.</td>\n</tr>\n<tr>\n<td>expires</td>\n<td>must be greater than the current month/year.</td>\n</tr>\n<tr>\n<td>cvc</td>\n<td>3 or 4 digit</td>\n</tr>\n</tbody>\n</table>\n</div><p>**<br />Other optional parameters in request body:**</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>language</td>\n<td>Preferred language of the user’s browser . EX - en-US</td>\n</tr>\n<tr>\n<td>java_enabled</td>\n<td>Indicates if Java is enabled in the browser. Helps PSPs in device profiling. Ex- true/false</td>\n</tr>\n<tr>\n<td>javascript_enabled</td>\n<td>Indicates if JavaScript is enabled in the client browser. Used for 3DS or risk-based checks. Ex- true</td>\n</tr>\n<tr>\n<td>color_depth</td>\n<td>Bit depth of the display screen. Ex- 24</td>\n</tr>\n<tr>\n<td>utc_offset</td>\n<td>Difference in minutes between local time and UTC. Used for location and timezone checks. Ex- 330</td>\n</tr>\n<tr>\n<td>screen_width</td>\n<td>Width of the device screen in pixels. Used in device profiling. Ex- 1920</td>\n</tr>\n<tr>\n<td>screen_height</td>\n<td>Height of the device screen in pixels. Ex- 1080</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Successful Response</strong></p>\n<p>If all the details are correct you'll get a 202 response with staus as Pending</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"status\": \"pending\",\n    \"callback_url\": \"https://paysecure.net/payment/63bd0bf80fb42a076e8a4dd1/\",\n    \"method\": \"GET\"\n}\n\n</code></pre>\n<p>If the response code is 202, after receiving the response body, direct the customer to the callback_url provided in the response.</p>\n<p><strong>Errors</strong></p>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Client Ip could not be matched with Merchant Ip</td>\n</tr>\n<tr>\n<td>Invalid Card Information</td>\n</tr>\n<tr>\n<td>Card is Blocked</td>\n</tr>\n<tr>\n<td>Different Type of key used to create purchase and payment</td>\n</tr>\n<tr>\n<td>You charges setting is incomplete .Plese Contact to adminstrartor.</td>\n</tr>\n<tr>\n<td>Allowed Attempt for this Transaction has been consumed</td>\n</tr>\n<tr>\n<td>Invalid Card Expiry(Valid Format:MM/YY) must be greator than current month/year</td>\n</tr>\n<tr>\n<td>Customer profile is Blocked</td>\n</tr>\n<tr>\n<td>Customer/Card not allowed for transaction</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"path":["p","64bff4fff63e36669499e9c8",""],"host":["https://api.paysecure.net/api/v1"],"query":[{"key":"s2s","value":"true"}],"variable":[]}},"response":[{"id":"9a8d95e9-f393-4eb2-8899-0d4c787b9fc5","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"cardholder_name\": \"dk\",\r\n    \"card_number\": \"4111111111111111\",\r\n    \"expires\": \"10/23\",\r\n    \"cvc\": \"345\",\r\n    \"remember_card\": \"on\",\r\n    \"remote_ip\": \"157.38.242.7\",\r\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\r\n    \"accept_header\": \"text/html\",\r\n    \"language\": \"en-US\",\r\n    \"java_enabled\": false,\r\n    \"javascript_enabled\": true,\r\n    \"color_depth\": 24,\r\n    \"utc_offset\": 0,\r\n    \"screen_width\": 1920,\r\n    \"screen_height\": 1080\r\n}","options":{"raw":{"language":"json"}}},"url":{"raw":"https://api.paysecure.net/api/v1/p/64bff4fff63e36669499e9c8/?s2s=true","protocol":"https","host":["api","paysecure","net"],"path":["api","v1","p","64bff4fff63e36669499e9c8",""],"query":[{"key":"s2s","value":"true"}]}},"status":"Accepted","code":202,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Mon, 30 Mar 2026 12:29:20 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"013dfd43-0689-4d6b-a797-38281465a753"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 3b66cea026f27925ba048cc96a0885ca.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"SWosGrWkPMrZoTyRfLd6N01fBb57k60RtzFzD-r38XQXmfTQEW_SRQ=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=qC4PItJ0vJPndQ4Ni%2F0rS%2BPlrlTkj9%2F28whoJdWsDG4oYZpOnmcmYgstZyXlRLs5CC6XI1kBR7nuEUQ6t4NoE1tnrhM8iv1IV%2BvSYTxq3AryDLbD0zZlxLVKj9jllGVm3RVN\"}]}"},{"key":"CF-RAY","value":"9e471e8bcf88824e-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"status\": \"pending\",\n    \"callback_url\": \"http://18.214.100.20/api/v1/payment/64b034ecc6dccf7d329d9eb3/\",\n    \"method\": \"GET\"\n}"}],"_postman_id":"88d85203-1a5d-40f8-badb-f41bd9d22354"},{"name":"Get Mandate","id":"ef48e986-6884-41eb-8f8c-b047f5c94c76","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"your-brand-value","type":"text"}],"body":{"mode":"raw","raw":"","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/mandate/{mandate_id or session_id}","description":"<p>This endpoint will be used to get all the details of a particular mandate. You can search for a particular mandate id or for a particular session id.</p>\n<h3 id=\"response-parameters\">Response <strong>parameters:</strong></h3>\n<ol>\n<li><p><strong>totalDeductedAmount</strong><br /> This is the total amount which is deducted from the user's account.</p>\n</li>\n<li><p><strong>recurringMandateIds</strong><br /> This object returns a list of all the MIT transactions done for the respective mandate.</p>\n</li>\n<li><p><strong>nextMandateDate</strong><br /> This is the date when the next recurring payment will happen.</p>\n</li>\n</ol>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","mandate","{mandate_id or session_id}"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"eb515f42-207e-46de-a07b-96bc1fd41a40","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"BrandId","value":"your-brand-value","type":"text"}],"url":"https://api.paysecure.net/api/v1/mandate/696bd471b0c24568ade46466"},"status":"Internal Server Error","code":500,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 01 Feb 2026 06:56:32 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"b8dc3fe9-c56b-4718-a6e8-b4044e69120b"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 05a63efd5ebb043211ccf075f3a8aa68.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"UPvql_nBAvRboQG1BikwIVIHoN_m5uHLEWWErbwD0Lr7fo5x48HpaA=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=Tp4EtXNt4DgHuaJ2Q9BfPJURiEh05tLCWMtFCu9z05OQ7YEYP1Cf3TATCi0U0OCbQWhfsBnlVUnPsz2DBH5%2FMZIxm8AQy7eBsf%2Fnh1HJP8Q%3D\"}]}"},{"key":"CF-RAY","value":"9c6f8cad4867d6fd-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"status\": \"ACTIVE\",\n    \"frequency\": \"YEARLY\",\n    \"rule\": \"on\",\n    \"value\": 12,\n    \"totalDeductedAmount\": \"20.00\",\n    \"recurringMandateIds\": [\n        \"6973ad04fa54ee2cf14f438c\",\n        \"697ce750e6446c7babfe4727\"\n    ],\n    \"email\": \"ranigupta89@paysecure.net\",\n    \"nextMandateDate\": 1799778418,\n    \"customer_id\": \"68dcd9c057c92d789953fec6\",\n    \"mandate_id\": \"696bd471b0c24568ade46466\",\n    \"mandate_max_amount\": 120,\n    \"amount_variability\": \"Variable\",\n    \"start_date\": \"1768674418\",\n    \"end_date\": \"null\",\n    \"pause_start_date\": \"null\",\n    \"pause_end_date\": \"null\",\n    \"session_id\": \"696bd468b0c24568ade4645e\"\n}\n"}],"_postman_id":"ef48e986-6884-41eb-8f8c-b047f5c94c76"},{"name":"Create Purchase (MIT)","id":"9f09699d-4395-418e-8fe8-698cacab95d7","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"685f870cf3435a2d5b35ee08\", // optional\r\n        \"email\": \"abby.aadeniran@gmail.com\", // mandatory\r\n        \"phone\": \"+44 07932665877\", // optional\r\n        \"full_name\": \"Navya Jain\", // optional\r\n        \"street_address\": \"Flat 61 Priory Court Romford RM7 0FY\", // mandatory\r\n        \"country\": \"GB\", // mandatory\r\n        \"city\": \"London\", // mandatory\r\n        \"zip_code\": \"234567\",  // mandatory\r\n        \"stateCode\": \"LO\" // mandatory\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"price\": 1\r\n            }\r\n        ]\r\n    },\r\n    \"merchantRef\": \"{{your-merchant-ref}}\", // optional\r\n    \"brand_id\": \"{{merchant_brand_id}}\", // mandatory\r\n    \"payment_type\": \"recurring\", // mandatory\r\n    \"mandate_id\": \"{{mandate-id}}\", // mandatory\r\n    \"success_redirect\": \"https://your.success.redirect.com\", // mandatory\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\", // optional\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\", // mandatory\r\n    \"success_callback\": \"https://your.success.callback.com\", // optional\r\n    \"failure_callback\": \"https://your.failure.callback.com\" // optional\r\n}"},"url":"https://api.paysecure.net/api/v1/purchases","description":"<p>After the successful Mandate registration, Merchant will receive a mandate_id from Paysecure that should be stored against a customer at their end.</p>\n<p>If the <strong>merchant handles their own scheduling,</strong> then for the subsequent transactions, the merchant is supposed to pass a combination of customer_id and mandate_id to do a debit. This API will perform a transaction with a PSP based on the mandate_id passed in the request.</p>\n<p>If <strong>Paysecure handles the scheduling for the merchant</strong> on their behalf, then this API is not for them. The MIT transactions will be handled by Paysecure from our side.</p>\n<p>Note:<br />Recurring payments should only be done if the mandate registration has been successful and the mandate is ACTIVE.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","purchases"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"4c6a9c4c-5556-4ab3-8bf9-8dec9637d410","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"},{"key":"Accept","value":"*/*","type":"text"},{"key":"Content-Type","value":"application/json","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"customerId\": \"685f870cf3435a2d5b35ee08\", // optional\r\n        \"email\": \"abby.aadeniran@gmail.com\", // mandatory\r\n        \"phone\": \"+44 07932665877\", // optional\r\n        \"full_name\": \"Navya Jain\", // optional\r\n        \"street_address\": \"Flat 61 Priory Court Romford RM7 0FY\", // mandatory\r\n        \"country\": \"GB\", // mandatory\r\n        \"city\": \"London\", // mandatory\r\n        \"zip_code\": \"234567\",  // mandatory\r\n        \"stateCode\": \"LO\" // mandatory\r\n    },\r\n    \"purchase\": {\r\n        \"currency\": \"USD\",\r\n        \"products\": [\r\n            {\r\n                \"name\": \"test\",\r\n                \"price\": 1\r\n            }\r\n        ]\r\n    },\r\n    \"merchantRef\": \"{{your-merchant-ref}}\", // optional\r\n    \"brand_id\": \"{{merchant_brand_id}}\", // mandatory\r\n    \"payment_type\": \"recurring\", // mandatory\r\n    \"mandate_id\": \"{{mandate-id}}\", // mandatory\r\n    \"success_redirect\": \"https://your.success.redirect.com\", // mandatory\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\", // optional\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\", // mandatory\r\n    \"success_callback\": \"https://your.success.callback.com\", // optional\r\n    \"failure_callback\": \"https://your.failure.callback.com\" // optional\r\n}"},"url":"https://api.paysecure.net/api/v1/purchases"},"status":"OK","code":200,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 01 Feb 2026 07:33:08 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"37f1854e-59ef-4553-928a-273030e84769"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 adbd5a952eb287ac84e05fd5fd42328e.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"7AJkDib2VzETAS6vS-ZJxKBYVyLrDSEJQl_Tnle4M6l-IWwqo2asaA=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=EtWT1DIhR3ebhY8soSvPlHMZW8ROhPoWtuiPSMSlWz3I2qU3notH7b6tEnFIyl%2B6iQZs2wFrTKESZRcMCfuxDwqNPDAccnSfvR5gjUb7kUs%3D\"}]}"},{"key":"CF-RAY","value":"9c6fc2486bdc311a-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"purchaseId\": \"69f8d407ea26ad15715ebb85\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"recurring@yopmail.com\",\n        \"date_of_birth\": \"1800-01-01\",\n        \"street_address\": \"120, jaipur\",\n        \"country\": \"CA\",\n        \"city\": \"London\",\n        \"zip_code\": \"W1S 3BE\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"QLD\"\n    },\n    \"updated_on\": 1777914890,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"VISA\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"errorCode\": \"NA\",\n    \"force_recurring\": false,\n    \"created_on\": 1777914887,\n    \"merchantRef\": \"69f8d407ea26ad15715ebb85\",\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"gaming cards\",\n                \"quantity\": 1.0,\n                \"price\": 1.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 1.0,\n        \"requestAmount\": 1.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 1.0,\n        \"currency\": \"USD\",\n        \"net_amount\": 1.0,\n        \"fee_amount\": 0.0,\n        \"pending_amount\": 0.0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1777914887,\n        \"remote_paid_on\": 1777914887\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"Testing\",\n        \"brand_name\": \"Testing\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"04\",\n            \"amount\": 1.0,\n            \"card_issuer\": \"REVOLUT BANK UAB\",\n            \"masked_pan\": \"41659827****0724\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"CH\",\n            \"card_type\": \"DEBIT\",\n            \"cardholder_name\": \"Amit Hooja\",\n            \"expiry_year\": \"31\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"183.82.186.156\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"CH\",\n                \"processing_time\": 1777914887,\n                \"extra\": {\n                    \"expiry_month\": \"04\",\n                    \"amount\": 1.0,\n                    \"card_issuer\": \"REVOLUT BANK UAB\",\n                    \"masked_pan\": \"41659827****0724\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"CH\",\n                    \"card_type\": \"DEBIT\",\n                    \"cardholder_name\": \"Amit Hooja\",\n                    \"expiry_year\": \"31\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1777914887\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1777914887\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1777914890\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"brand_id\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS1738\",\n    \"issued\": \"2026-05-04\",\n    \"due\": 1777914887,\n    \"refund_upto\": 1780503290,\n    \"cc_descriptor\": \"multitasklist\",\n    \"fraudScore\": \"0\",\n    \"trustScore\": \"0\",\n    \"extraFee\": \"0\",\n    \"totalRefunded\": 0.0,\n    \"paidOn\": 1777914890,\n    \"receivedAmt\": 0.0,\n    \"taxAmount\": 0.0,\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"sessionId\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 1.0,\n    \"success_redirect\": \"https://staging.paysecure.net/getResponse.jsp?issucces=true\",\n    \"failure_redirect\": \"https://staging.paysecure.net/getResponse.jsp?issucces=false\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"failure_callback\": \"https://staging.paysecure.net/merchant\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"2406:b400:75:22bd:b48e:a33e:4e26:a542\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/0bc9c18600980b03a08fb030726428f8/\",\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/69f8d407ea26ad15715ebb85/\",\n    \"payoutProcess\": false,\n    \"payment_type\": \"recurring\",\n    \"mandate_id\": \"69f8cfa1db7ca561ab23fed2\"\n}"}],"_postman_id":"9f09699d-4395-418e-8fe8-698cacab95d7"},{"name":"Revoke Mandate","id":"f8d2de93-e71e-4106-8f16-1936482c1a11","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Brandid","value":"your-brand-id","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"mandate_id\": \"685cc8515e3af922dd0e8c31\",\n    \"command\": \"revoke\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/mandate","description":"<p>Required for cases where the Paysecure is handling the scheduling of recurring payments. Use this API to revoke/cancel an ACTIVE mandate.</p>\n<p>Note:<br />Revoking a mandate should be done at the same instance this API is called. The mandate status should be updated to “REVOKED” at the same instant.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","mandate"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"efd6a18f-2417-46ad-a9e5-292a29933da6","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Brandid","value":"your-brand-id","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"mandate_id\": \"685cc8515e3af922dd0e8c31\",\n    \"command\": \"revoke\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/mandate"},"status":"OK","code":200,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 01 Feb 2026 07:35:47 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"4a8592fc-9fa6-4fbb-9e07-cdcd7edc5e40"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 f89daa99b6a349030b23247a4977cb5e.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"HmEu78FCUGrOzYk6YJdjvLfy0B6-xSVbGbk0Yud_HA3Bg0EgIfBt5A=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=oMkGA9vbkd3bDC7Q9cfg5OcebtSE%2FehjdB9%2BKjGMP%2BJEyQIpOYfkAN1qKp5ByOTxfmLL6i9TB6nS8bdIIYKhIw0xHog50DJhUAPxJMEFv2M%3D\"}]}"},{"key":"CF-RAY","value":"9c6fc62b3b071e2d-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"mandateId\": \"6943aabe3f5c35b0f7849768\",\n    \"message\": \"Mandate revoked successfully\",\n    \"revokeDate\": 1769857766,\n    \"status\": \"REVOKED\"\n}"}],"_postman_id":"f8d2de93-e71e-4106-8f16-1936482c1a11"},{"name":"Pause Mandate","id":"309b05d7-cc06-4805-92f2-34d7b2d0a7a2","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"BrandId","value":"your-brand-id","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"mandate_id\": \"685cc8515e3af922dd0e8c31\",\n    \"command\": \"pause\",\n    \"pause_start_date\": \"1761985415\",\n    \"pause_end_date\": \"1761985415\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/mandate","description":"<p>Required for cases where the Paysecure is handling the scheduling of recurring payments. Use this API to pause an ACTIVE mandate.</p>\n<h3 id=\"additional-parameters-for-this-usecase\">Additional <strong>parameters for this usecase:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>command</td>\n<td>Mandatory.  <br />To be passed as \"pause\".</td>\n</tr>\n<tr>\n<td>mandate_id</td>\n<td>Mandatory.</td>\n</tr>\n<tr>\n<td>pause_start_date</td>\n<td>Optional  <br />Date in UNIX EPOCH timestamp (UTC timezone) format, when the mandate will be paused.  <br />If not passed, Default value will be the current date.</td>\n</tr>\n<tr>\n<td>pause_end_date</td>\n<td>Mandatory  <br />Date in UNIX EPOCH timestamp (UTC timezone) format, when the mandate status will be automatically changed to ACTIVE.</td>\n</tr>\n</tbody>\n</table>\n</div><p>Note:<br />For pausing a mandate you need to keep the exact timestamp in mind.<br />If a recurring payment is scheduled between the pause_start_date and pause_end_date then it will not be executed.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","mandate"],"host":["api","paysecure","net"],"query":[],"variable":[]}},"response":[{"id":"45dd1924-09cd-441f-a043-b19482bd8bb0","name":"Pause Mandate","originalRequest":{"method":"POST","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"BrandId","value":"your-brand-id","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"mandate_id\": \"685cc8515e3af922dd0e8c31\",\n    \"command\": \"pause\",\n    \"pause_start_date\": \"1761985415\",\n    \"pause_end_date\": \"1761985415\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/mandate"},"status":"OK","code":200,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 01 Feb 2026 07:43:17 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"d58bc371-c0da-450a-acfe-0c3201044a0d"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 1a12f863197f986ec10d35ed76e104f0.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"ywPaVLC1kDeRa4Z9VCMmj4E3hj0lAODhase1DUwkbaCEeCW3c2Y0Bw=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=jxNgzPiQ7b3lf84TmsdZvXle8FBgBUNhmJa5W6ZgA0z943LEtK3kWUVHzpO%2B9jLRC7jxqt2Df6QyJBu3anUlhBNLpCn0uxchM1IvQNKx90c%3D\"}]}"},{"key":"CF-RAY","value":"9c6fd1258d901ff2-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"mandateId\": \"693c053feef6a6b6928b48b0\",\n    \"pauseEndDate\": 1769859769,\n    \"message\": \"Mandate paused configuration done successfully for the selected duration\",\n    \"pauseStartDate\": 1769857969,\n    \"status\": \"PAUSED\"\n}"}],"_postman_id":"309b05d7-cc06-4805-92f2-34d7b2d0a7a2"},{"name":"List Mandates","id":"66481019-6cec-4c73-851b-6d0aace18710","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"BrandId","value":"your-brand-id","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/mandate?customerId=696bd627b0c24568ade4675e&email=test@gmail.com","description":"<p>This endpoint will be used to list all the mandates for a particular customer of a merchant.</p>\n<h3 id=\"response-parameters\">Response <strong>parameters:</strong></h3>\n<ol>\n<li><p><strong>totalDeductedAmount</strong><br /> This is the total amount which is deducted from the user's account.</p>\n</li>\n<li><p><strong>recurringMandateIds</strong><br /> This object returns a list of all the MIT transactions done for the respective mandate.</p>\n</li>\n<li><p><strong>nextMandateDate</strong><br /> This is the date when the next recurring payment will happen.</p>\n</li>\n</ol>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"protocol":"https","path":["api","v1","mandate"],"host":["api","paysecure","net"],"query":[{"key":"customerId","value":"696bd627b0c24568ade4675e"},{"key":"email","value":"test@gmail.com"}],"variable":[]}},"response":[{"id":"4043e26a-5be9-44c5-8db7-bef06ab1e3d9","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"BrandId","value":"your-brand-id","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"","options":{"raw":{"language":"json"}}},"url":{"raw":"https://api.paysecure.net/api/v1/mandate?customerId=696bd627b0c24568ade4675e&email=test@gmail.com","protocol":"https","host":["api","paysecure","net"],"path":["api","v1","mandate"],"query":[{"key":"customerId","value":"696bd627b0c24568ade4675e"},{"key":"email","value":"test@gmail.com"}]}},"status":"OK","code":200,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 01 Feb 2026 07:45:33 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"f16548e2-fc87-44fc-bbf1-767f2c82af0c"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 9bce423254194c16408d5cf7234126e2.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"ywr-KbYLgcl2CP9ZyFndEJjR7VI6jATRNoLeJen1sLm6hmk4VPBSGw=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=SuOGk1BmR%2B6RDq9oMjQI0y4v%2B2wZpehSeXuXxwibUF8%2B%2Fg6CIX9K27%2F1oT205007Yq63%2BR2d2casubErbR9yDAk78NgFsX%2Bd%2FGq2v9VBBGY%3D\"}]}"},{"key":"CF-RAY","value":"9c6fd4788b13c5ce-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"mandates\": [\n        {\n            \"status\": \"ACTIVE\",\n            \"frequency\": \"WEEKLY\",\n            \"rule\": \"after\",\n            \"value\": 4,\n            \"totalDeductedAmount\": \"10.00\",\n            \"recurringMandateIds\": [\n                \"6973ad04fa54ee2cf14f438c\",\n                \"697ce750e6446c7babfe4727\"\n            ],\n            \"email\": \"test@gmail.com\",\n            \"nextMandateDate\": 1770398106,\n            \"customer_id\": \"696bd627b0c24568ade4675e\",\n            \"mandate_id\": \"696bc39a7bc779fac5201357\",\n            \"mandate_max_amount\": 120,\n            \"amount_variability\": \"Variable\",\n            \"start_date\": \"1768670106\"\n        },\n        {\n            \"status\": \"CREATED\",\n            \"frequency\": \"WEEKLY\",\n            \"rule\": \"on\",\n            \"value\": 6,\n            \"totalDeductedAmount\": \"0\",\n            \"email\": \"test@gmail.com\",\n            \"customer_id\": \"696bd627b0c24568ade4675e\",\n            \"mandate_id\": \"696bd627b0c24568ade4675e\",\n            \"mandate_max_amount\": 120,\n            \"amount_variability\": \"Variable\",\n            \"start_date\": \"1768674855\",\n            \"session_id\": \"\"\n        },\n        {\n            \"status\": \"ACTIVE\",\n            \"frequency\": \"WEEKLY\",\n            \"rule\": \"after\",\n            \"value\": 4,\n            \"totalDeductedAmount\": \"0\",\n            \"email\": \"test@gmail.com\",\n            \"customer_id\": \"696bd627b0c24568ade4675e\",\n            \"mandate_id\": \"69788a5dd1ed27eeb5fb89d6\",\n            \"mandate_max_amount\": 120,\n            \"amount_variability\": \"Variable\",\n            \"start_date\": \"1769507493\",\n            \"session_id\": \"\"\n        },\n        {\n            \"status\": \"ACTIVE\",\n            \"frequency\": \"WEEKLY\",\n            \"rule\": \"after\",\n            \"value\": 4,\n            \"totalDeductedAmount\": \"1000\",\n            \"recurringMandateIds\": [\n                \"6973ad04fa54ee2cf14f438c\",\n                \"697ce750e6446c7babfe4727\"\n            ],\n            \"email\": \"test@gmail.com\",\n            \"customer_id\": \"696bd627b0c24568ade4675e\",\n            \"mandate_id\": \"69788d2f0ea4df4fd4e6eb5b\",\n            \"mandate_max_amount\": 120,\n            \"amount_variability\": \"Variable\",\n            \"start_date\": \"1769508214\",\n            \"session_id\": \"\"\n        },\n        {\n            \"status\": \"FAILED\",\n            \"frequency\": \"WEEKLY\",\n            \"rule\": \"after\",\n            \"value\": 4,\n            \"totalDeductedAmount\": \"0\",\n            \"email\": \"test@gmail.com\",\n            \"customer_id\": \"696bd627b0c24568ade4675e\",\n            \"mandate_id\": \"697b533b34d180d90cfb2f5f\",\n            \"mandate_max_amount\": 120,\n            \"amount_variability\": \"Variable\",\n            \"start_date\": \"1769689915\",\n            \"session_id\": \"\"\n        },\n        {\n            \"status\": \"CREATED\",\n            \"frequency\": \"WEEKLY\",\n            \"rule\": \"after\",\n            \"value\": 4,\n            \"totalDeductedAmount\": \"0\",\n            \"email\": \"test@gmail.com\",\n            \"customer_id\": \"696bd627b0c24568ade4675e\",\n            \"mandate_id\": \"697de0e15d2e562bf8b4552a\",\n            \"mandate_max_amount\": 120,\n            \"amount_variability\": \"Variable\",\n            \"start_date\": \"1769857249\",\n            \"session_id\": \"\"\n        }\n    ]\n}"}],"_postman_id":"66481019-6cec-4c73-851b-6d0aace18710"},{"name":"Get Status","id":"1deb53b7-79f5-4db6-a48e-10e85940596a","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/","description":"<p>This API tells you about all the details of a recurring payment which occurred</p>\n<h3 id=\"mandatory\">Mandatory</h3>\n<p>you need to pass the <code>PurchaseID</code> in the API URL</p>\n<h3 id=\"possible-value-of-status\">Possible Value of Status</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Status</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paid</td>\n<td>Transaction Successful</td>\n</tr>\n<tr>\n<td>expired</td>\n<td>Purchase has Expired.</td>\n</tr>\n<tr>\n<td>error</td>\n<td>Transaction has Failed.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-examples\">Response Examples</h3>\n<p>In the response examples you can see instances of both <code>Paid</code> and <code>Error</code> Status purchases.</p>\n<h3 id=\"error-details\">Error Details</h3>\n<p>If there are any issues on the Purchase you can get more details from the <code>transaction_data.attempts.error</code> attribute of the response object</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}},"urlObject":{"path":["purchases","{purchaseId}",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"72a38101-17c7-4be3-9287-aaba49f32fff","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"url":"https://api.paysecure.net/api/v1/purchases/{purchaseId}/"},"status":"OK","code":200,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 01 Feb 2026 07:59:35 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"e222737a-b9e9-4562-94de-5b80b056c180"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 f89daa99b6a349030b23247a4977cb5e.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"eUcDXjdNU1qDjwPQst7oM9Kbi8qYyd8sncr30-6kphukYSEGv-qwUg=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=i8qaRQprp0TLqlSo5At%2FjpQANnSZgP8iEeVFnMasIN8xyAN2mdqYXVqP3dXt2AbZRL8fj6SRWa%2BFA1dybSS8ebE5scTH8BsB6Ubx8ppJSxc%3D\"}]}"},{"key":"CF-RAY","value":"9c6fe9092c493ec9-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"purchaseId\": \"6973ad04fa54ee2cf14f438c\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"sl68792.bravo@bravapay.com\",\n        \"phone\": \"0557719399\",\n        \"full_name\": \"Test user\",\n        \"date_of_birth\": \"2004-07-12\",\n        \"street_address\": \"10 New Burlington StreetApt. 214\",\n        \"country\": \"CA\",\n        \"city\": \"London\",\n        \"zip_code\": \"W1S 3BE\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"tax_number\": \"+447755564318\",\n        \"bankAccountNumber\": \"1345789678\",\n        \"stateCode\": \"QLD\"\n    },\n    \"updated_on\": 1769188614,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"VISA\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"ERROR_PARSING_GROUP_ID\",\n    \"errorCode\": \"NA\",\n    \"force_recurring\": false,\n    \"created_on\": 1769188612,\n    \"merchantRef\": \"6973ad04fa54ee2cf14f438c\",\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"gaming cards\",\n                \"quantity\": 1.0,\n                \"price\": 10.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 10.0,\n        \"requestAmount\": 10.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"zenith\",\n        \"brand_name\": \"zenith\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"01\",\n            \"amount\": 10.0,\n            \"card_issuer\": \"VISION BANK\",\n            \"masked_pan\": \"42222222*2222\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"SA\",\n            \"card_type\": \"DEBIT\",\n            \"cardholder_name\": \"fgjhknms\",\n            \"expiry_year\": \"29\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"49.36.232.107\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": false,\n                \"country\": \"VISA\",\n                \"processing_time\": 1769188612,\n                \"extra\": {\n                    \"amount\": 10.0,\n                    \"masked_pan\": \"VISA\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"VISA\",\n                    \"cardholder_name\": \"Test user\"\n                },\n                \"error\": {\n                    \"message\": \"This customer can not be processed !\",\n                    \"code\": \"transaction_error\"\n                }\n            },\n            {\n                \"client_ip\": \"\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": false,\n                \"country\": \"SA\",\n                \"processing_time\": 1769188613,\n                \"extra\": {\n                    \"expiry_month\": \"01\",\n                    \"amount\": 10.0,\n                    \"card_issuer\": \"VISION BANK\",\n                    \"masked_pan\": \"42222222*2222\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"SA\",\n                    \"card_type\": \"DEBIT\",\n                    \"cardholder_name\": \"fgjhknms\",\n                    \"expiry_year\": \"29\"\n                },\n                \"error\": {\n                    \"message\": \"ERROR_PARSING_GROUP_ID\",\n                    \"code\": \"transaction_error\"\n                }\n            }\n        ]\n    },\n    \"status\": \"ERROR\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1769188612\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1769188612\n        },\n        {\n            \"status\": \"error\",\n            \"timestamp\": 1769188613\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1769188613\n        },\n        {\n            \"status\": \"error\",\n            \"timestamp\": 1769188614\n        },\n        {\n            \"status\": \"viewed\",\n            \"timestamp\": 1770016552\n        }\n    ],\n    \"viewedOn\": 1770016552,\n    \"is_test\": false,\n    \"brand_id\": \"555c458b-e737-4905-adb2-2451d37cbb6e\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS1841\",\n    \"issued\": \"2026-01-23\",\n    \"due\": 1769188612,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"extraFee\": \"0\",\n    \"paidOn\": 0,\n    \"receivedAmt\": 0.0,\n    \"taxAmount\": 0.0,\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"sessionId\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0.0,\n    \"success_redirect\": \"https://staging.paysecure.net/getResponse.jsp?issucces=true\",\n    \"failure_redirect\": \"https://staging.paysecure.net/getResponse.jsp?issucces=false\",\n    \"pending_redirect\": \"https://staging.paysecure.net/getResponse.jsp?issucces=pending \",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://www.google.com/\",\n    \"failure_callback\": \"https://staging.paysecure.net/merchant\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"49.36.232.107\",\n    \"checkout_url\": \"https://test4.paymentsclub.net/payments/a28ed9974a22a4cbd5f2f49cc26cc334/\",\n    \"direct_post_url\": \"https://test4.paymentsclub.net/api/v1/p/6973ad04fa54ee2cf14f438c/\",\n    \"payoutProcess\": false,\n    \"payment_type\": \"internal recurring\",\n    \"mandate_id\": \"696bc39a7bc779fac5201357\"\n}"}],"_postman_id":"1deb53b7-79f5-4db6-a48e-10e85940596a"}],"id":"1dbf7322-e009-4884-b0bf-459b3a88883c","_postman_id":"1dbf7322-e009-4884-b0bf-459b3a88883c","description":"","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0","id":"917da390-3ff9-462e-83c3-363f9b44a6b0","name":"Recurring Payments","type":"folder"}}}],"id":"917da390-3ff9-462e-83c3-363f9b44a6b0","description":"<h1 id=\"overview\">Overview</h1>\n<p>Recurring Payments allow merchants to automatically charge customers at predefined or flexible intervals without requiring the customer to re-enter payment details each time.</p>\n<p>A <strong>Mandate</strong> represents the customer’s authorization that links their payment method to the merchant for future recurring charges. Once created, this mandate is used as a secure reference for all upcoming payments.</p>\n<p>Instead of processing every transaction as a one-time payment, merchants rely on mandates to execute recurring debits in a frictionless and compliant manner.</p>\n<p>The recurring payments may be initiated using Paysecure APIs as fixed/ non-fixed intervals based on your business use case.</p>\n<p>The Paysecure Subscription module (also known as Mandates) enables merchants to automate recurring billing for products and services. Unlike standard one-off transactions, this feature creates a persistent link between the merchant and the customer's payment method, allowing for future charges without requiring the customer to be present or re-enter their details.</p>\n<p>This system is built around two fundamental transaction types that define the lifecycle of a subscription:</p>\n<h3 id=\"1-mandate-registration-cit\"><strong>1. Mandate Registration (CIT)</strong></h3>\n<p>The <strong>Customer Initiated Transaction (CIT)</strong> represents the initial setup of the recurring payment mandate, during which the customer is actively present on the merchant’s website or application (in-session flow).</p>\n<p>In this flow, the merchant collects and submits the customer’s basic details along with the mandate configuration, including registration information, payment amount (fixed or variable, as applicable), and the scheduling frequency for recurring debits.</p>\n<p>As part of the setup process, the customer must explicitly provide consent for the mandate. To authenticate and activate the mandate, the customer also completes a one-time payment using the selected payment method. Once this payment is successful, the mandate is registered and becomes eligible for future automated recurring transactions as per the defined schedule.</p>\n<p><strong>Purpose</strong>:</p>\n<ul>\n<li><p>Capture customer payment details</p>\n</li>\n<li><p>Authenticate the transaction (typically via 3D Secure)</p>\n</li>\n<li><p>Collect customer consent for recurring billing</p>\n</li>\n</ul>\n<p><strong>Outcome:</strong></p>\n<ul>\n<li><p>A unique mandate_id is generated</p>\n</li>\n<li><p>This mandate acts as a secure token for all future charges</p>\n</li>\n</ul>\n<p><strong>Use Case:</strong></p>\n<p>The customer signs up for a subscription and completes the first payment</p>\n<h3 id=\"2-recurring-payments-mit\"><strong>2. Recurring Payments (MIT)</strong></h3>\n<p>The <strong>Merchant Initiated Transaction (MIT)</strong> represents the execution phase of the recurring payment lifecycle. In this stage, payments are automatically triggered by the merchant’s system or through Paysecure’s built-in scheduler without requiring the customer to be actively present (off-session flow).</p>\n<p>Once a mandate is successfully registered, merchants can initiate recurring debits as per the defined schedule and payment terms. These transactions are processed seamlessly using the customer’s authorized payment method.</p>\n<p>The Paysecure Mandate module provides the following benefits:</p>\n<ul>\n<li><p>Prebuilt support for a complete mandate registration experience using cards as the payment method</p>\n</li>\n<li><p>Flexible mandate setup to match different business models and customer requirements</p>\n</li>\n<li><p>Simplified execution of recurring payments through the Paysecure Dashboard with minimal operational effort</p>\n</li>\n<li><p>Built-in analytics and reporting tools to monitor mandate sign-ups, payment performance, and renewals</p>\n</li>\n</ul>\n<p><strong>Purpose:</strong></p>\n<ul>\n<li>Debit the customer according to the defined schedule or usage</li>\n</ul>\n<p><strong>Mechanism:</strong></p>\n<ul>\n<li><p>Merchant (or Paysecure scheduler) sends payment requests using the mandate_id</p>\n</li>\n<li><p>No card details are required again</p>\n</li>\n<li><p>Usually bypasses 3D Secure</p>\n</li>\n</ul>\n<p><strong>Use Case:</strong></p>\n<p>Monthly subscription renewal payment.</p>\n<h1 id=\"key-capabilities\"><strong>Key Capabilities</strong></h1>\n<ul>\n<li><p><strong>Flexible Scheduling:</strong> Define rigid schedules (Daily, Weekly, Monthly, Yearly) or use \"As Presented\" for irregular billing intervals.</p>\n</li>\n<li><p><strong>Amount Variability:</strong> Support for <strong>Fixed</strong> amounts (e.g., $10/month license) or <strong>Variable</strong> amounts (e.g., utility bills where the cost changes based on usage).</p>\n</li>\n<li><p><strong>Smart Management:</strong></p>\n<ul>\n<li><p><strong>Merchant Managed:</strong> You track the dates and trigger the API call when payment is due.</p>\n</li>\n<li><p><strong>Paysecure Managed:</strong> You define the rules (start date, end date, frequency), and Paysecure handles the execution logic.</p>\n</li>\n</ul>\n</li>\n<li><p><strong>Analytics &amp; Operations:</strong> Includes a dedicated dashboard for monitoring signup performance, renewal success rates, and managing cancellations.</p>\n</li>\n</ul>\n<p>There are 2 ways in which subscriptions are handled at Paysecure’s end:</p>\n<h4 id=\"merchant-managed-scheduling\"><strong>Merchant Managed Scheduling</strong></h4>\n<p>After successfully registering the mandate, the merchant creates a subscription linked to the customer’s mandate. Based on the defined billing cycle and business logic, the merchant then triggers the Recurring Payments API according to their own payment schedule to execute automated debits.</p>\n<p>This approach allows merchants to maintain full control over when and how recurring charges are initiated.</p>\n<ul>\n<li><p>Merchant tracks payment due dates</p>\n</li>\n<li><p>Merchant triggers recurring API calls manually</p>\n</li>\n</ul>\n<p><strong>Best for:</strong></p>\n<p>Custom billing logic or internal scheduling systems.</p>\n<h4 id=\"paysecure-managed-scheduling\"><strong>Paysecure Managed Scheduling</strong></h4>\n<p>In this model, the merchant creates a subscription within the Paysecure system and submits the recurring payment schedule, including billing frequency and timing. Based on the provided configuration, Paysecure automatically manages the execution of recurring transactions as per the defined schedule.</p>\n<p>This removes the need for merchants to manually trigger each payment, ensuring consistent and timely debits while maintaining a fully automated recurring billing process</p>\n<ul>\n<li><p>Merchant defines payment rules (start date, frequency, end date)</p>\n</li>\n<li><p>Paysecure automatically executes recurring charges</p>\n</li>\n</ul>\n<p><strong>Best for:</strong></p>\n<p>Standard subscription models with minimal operational overhead.</p>\n<h1 id=\"prerequisites\"><strong>Prerequisites</strong></h1>\n<p>Before starting the mandate integration, merchants must ensure that the required configurations are enabled both at the PSP level and within the Paysecure system.</p>\n<h4 id=\"mandate-enablement-at-psp-level\"><strong>Mandate Enablement at PSP Level</strong></h4>\n<p>Merchants must enable mandate-related features on their respective PSP (Payment Service Provider) dashboard. This ensures that the PSP supports recurring and mandate-based transactions.</p>\n<h4 id=\"configuration-on-the-paysecure-dashboard\"><strong>Configuration on the Paysecure Dashboard</strong></h4>\n<ul>\n<li><p>For whitelabel merchants or those using Paysecure’s whitelabel solution, the mandate support toggle must be enabled within the MID settings of the PSP configuration. This allows Paysecure to recognize and route mandate transactions correctly.</p>\n</li>\n<li><p>For merchants directly onboarded with Paysecure, this configuration is managed by the Paysecure team. Merchants should coordinate with their account manager to ensure mandate enablement is completed.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"a503cce9-b5d0-4867-93f2-cf8cbf7e27b1","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"a62b1609-bc9a-4d3e-b407-18f0904d8f2f","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"917da390-3ff9-462e-83c3-363f9b44a6b0"},{"name":"Transaction Reporting","item":[{"name":"List Transactions","id":"87d72b7e-f6ae-47fb-9b03-f24074c7cbfe","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"BrandId","value":"your-brand-id"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/external/transactions/list?page_no=1&page_size=10&transaction_id=69d4ba22465443878a0045ba&start_date=2025-10-29%2000%3A00%3A00%20+05%3A30&end_date=2026-04-23%2000%3A00%3A00%20+05%3A30&last_updated_start=2026-01-07%2016%3A12%3A00%20+05%3A30&last_updated_end=2026-12-07%2016%3A12%3A00%20+05%3A30&customer_id=NA&status=paid&currency=USD&is_sandbox=true","description":"<p>Fetches a paginated list of transactions. This endpoint is optimized for high-volume retrieval and returns a summary view of each transaction (ID and Status).</p>\n<h4 id=\"important-path-params-to-consider\"><strong>Important Path Params to consider:</strong></h4>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Fields</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>page_no</td>\n<td>The index number of the page to retrieve.  <br />Zero-based indexing: The first page is 0, the second is 1, etc.  <br />Example: To get the third page of results, send page_no=2</td>\n</tr>\n<tr>\n<td>page_size</td>\n<td>The number of records to return per page.  <br />Minimum: 1  <br />Maximum: 100 (or whatever your API limit is).  <br />Usage: A larger page_size reduces the number of API calls but increases payload size.</td>\n</tr>\n<tr>\n<td>transaction_id</td>\n<td>If you want to filter with a specific transaction id. Multiple ids are not supported.  <br />If a transaction id is passed, it has the highest priority. All the below mentioned filters are ommitted.</td>\n</tr>\n<tr>\n<td>start_date</td>\n<td>If you want to filter between 2 dates.  <br />Format: 2026-01-07 16:12:00 +05:30  <br />Base timezone is in UTC.</td>\n</tr>\n<tr>\n<td>end_date</td>\n<td>If you want to filter between 2 dates  <br />Format: 2026-01-07 16:12:00 +05:30  <br />Base timezone is in UTC.</td>\n</tr>\n<tr>\n<td>last_updated_start</td>\n<td>If you want to filter with the last updated date of a transaction.  <br />Format: 2026-01-07 16:12:00 +05:30  <br />Base timezone is in UTC.</td>\n</tr>\n<tr>\n<td>last_updated_end</td>\n<td>If you want to filter with the last updated date of a transaction.  <br />Format: 2026-01-07 16:12:00 +05:30  <br />Base timezone is in UTC.</td>\n</tr>\n<tr>\n<td>customer_id</td>\n<td>If you want to filter with a specific customer id. Multiple ids are not supported.</td>\n</tr>\n<tr>\n<td>status</td>\n<td>If you want to filter with the status.</td>\n</tr>\n<tr>\n<td>currency</td>\n<td>If you want to filter with the currency.</td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"protocol":"https","path":["api","v1","external","transactions","list"],"host":["api","paysecure","net"],"query":[{"key":"page_no","value":"1"},{"key":"page_size","value":"10"},{"key":"transaction_id","value":"69d4ba22465443878a0045ba"},{"key":"start_date","value":"2025-10-29%2000%3A00%3A00%20+05%3A30"},{"key":"end_date","value":"2026-04-23%2000%3A00%3A00%20+05%3A30"},{"key":"last_updated_start","value":"2026-01-07%2016%3A12%3A00%20+05%3A30"},{"key":"last_updated_end","value":"2026-12-07%2016%3A12%3A00%20+05%3A30"},{"key":"customer_id","value":"NA"},{"key":"status","value":"paid"},{"key":"currency","value":"USD"},{"key":"is_sandbox","value":"true"}],"variable":[]}},"response":[{"id":"976d30b9-b7cb-4348-95b8-7c0711f09d41","name":"Success","originalRequest":{"method":"GET","header":[{"key":"BrandId","value":"your-brand-id"},{"key":"Authorization","value":"Bearer Token"}],"url":{"raw":"https://api.paysecure.net/api/v1/external/transactions/list?page_no=1&page_size=10&start_date=2025-10-29%2000%3A00%3A00%20+05%3A30&end_date=2026-04-23%2000%3A00%3A00%20+05%3A30&last_updated_start=2026-01-07%2016%3A12%3A00%20+05%3A30&last_updated_end=2026-12-07%2016%3A12%3A00%20+05%3A30&customer_id=NA&status=paid&currency=USD&is_sandbox=true","protocol":"https","host":["api","paysecure","net"],"path":["api","v1","external","transactions","list"],"query":[{"key":"page_no","value":"1"},{"key":"page_size","value":"10"},{"key":"transaction_id","value":"69d4ba22465443878a0045ba","disabled":true},{"key":"start_date","value":"2025-10-29%2000%3A00%3A00%20+05%3A30"},{"key":"end_date","value":"2026-04-23%2000%3A00%3A00%20+05%3A30"},{"key":"last_updated_start","value":"2026-01-07%2016%3A12%3A00%20+05%3A30"},{"key":"last_updated_end","value":"2026-12-07%2016%3A12%3A00%20+05%3A30"},{"key":"customer_id","value":"NA"},{"key":"status","value":"paid"},{"key":"currency","value":"USD"},{"key":"is_sandbox","value":"true"}]}},"status":"Bad Request","code":400,"_postman_previewlanguage":null,"header":[{"key":"Date","value":"Sun, 19 Apr 2026 14:11:10 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"c2111eb2-6314-4f0b-b546-4ae3ee123a44"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 6a91ddfdf36644f1344da228258d9082.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"lKDk7cJHKNy2cOdf_AWXk3GlUJdWC5slaGWaVfgUf1Fn0XXm7T7D7Q=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=YLhXcnCfKpMy2KQEcmek7bxnkI2lT3%2F5IQ8opo9ZpZ4E852qZoWIFsjJ%2BcmGZfTO7S1rWYnB3uzuGwMYwevQ%2F47w%2Bm6u51jrIfjuG3TDh08KGeWKRbR92ItXRYPoh1CgVmja\"}]}"},{"key":"CF-RAY","value":"9eec7f31f973c9b7-IAD"}],"cookie":[],"responseTime":null,"body":"{\n    \"data\": {\n        \"content\": [\n            {\n                \"transaction_id\": \"69e2146828bea6ca2e31bc85\",\n                \"status\": \"paid\"\n            },\n            {\n                \"transaction_id\": \"69e20fd928bea6ca2e31b17c\",\n                \"status\": \"paid\"\n            }\n        ],\n        \"currentPage\": 1,\n        \"pageSize\": 2,\n        \"totalElements\": 95,\n        \"totalPages\": 48,\n        \"first\": true,\n        \"last\": false,\n        \"hasNext\": true,\n        \"hasPrevious\": false\n    }\n}"}],"_postman_id":"87d72b7e-f6ae-47fb-9b03-f24074c7cbfe"},{"name":"Get Detailed Transaction Details","id":"fc665062-e61c-4a2f-89bb-a9e2a5abdd2a","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"GET","header":[{"key":"BrandId","value":"your-brand-id"},{"key":"Authorization","value":"Bearer Token"}],"url":"https://api.paysecure.net/api/v1/external/transactions/data/69e20fd928bea6ca2e31b17c?page_no=1&page_size=10&include_subtransactions=true","description":"<p>Retrieves the complete details for a specific transaction. This includes customer info, payment method details, bank response codes, and hierarchy metadata (parent/child transactions).</p>\n<h3 id=\"additional-query-parameters-for-this-usecase\">Additional query <strong>parameters for this usecase:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>include_subtransactions</td>\n<td>Mandatory.  <br />Possible Values: true/false  <br />  <br />If true, includes child transactions (e.g., recurring payments).</td>\n</tr>\n</tbody>\n</table>\n</div>","urlObject":{"protocol":"https","path":["api","v1","external","transactions","data","69e20fd928bea6ca2e31b17c"],"host":["api","paysecure","net"],"query":[{"key":"page_no","value":"1"},{"key":"page_size","value":"10"},{"key":"include_subtransactions","value":"true"}],"variable":[]}},"response":[{"id":"447e5918-db1a-4ea8-b1b8-cceb196a8098","name":"Success","originalRequest":{"method":"GET","header":[{"key":"BrandId","value":"your-brand-id"},{"key":"Authorization","value":"Bearer Token"}],"url":{"raw":"https://api.paysecure.net/api/v1/external/transactions/data/69e20fd928bea6ca2e31b17c?page_no=1&page_size=10&include_subtransactions=true","protocol":"https","host":["api","paysecure","net"],"path":["api","v1","external","transactions","data","69e20fd928bea6ca2e31b17c"],"query":[{"key":"page_no","value":"1"},{"key":"page_size","value":"10"},{"key":"include_subtransactions","value":"true"}]}},"status":"Bad Request","code":400,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Sun, 19 Apr 2026 14:13:09 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"3d9fb1d1-b30f-4c3e-a76f-6956e3731ad3"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 64d4305f6a0418824e90908ac490184e.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"COt7k0tEcVGSOSy8pTkHoOqGoG1lSgC9qz8baoKbgmPkAh5dq0GNjQ=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=hn0q1Q9Cqa9onXwzy%2F1Qeq8u4RTGt3q%2BZNFW29weO%2BOmtABh6y8XLnAH9%2FytCQEEOmNzdnvM0oPcQruiJvYqQQShCKOndiMKUnEksUPM9I9UMph4qP7s1ognTK%2BBhheXvIwO\"}]}"},{"key":"CF-RAY","value":"9eec821e0f4b172c-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"data\": {\n        \"transaction_id\": \"69e20fd928bea6ca2e31b17c\",\n        \"merchant_reference\": \"69e20fd928bea6ca2e31b17c\",\n        \"customer_id\": \"NA\",\n        \"amount\": 1.0,\n        \"currency\": \"USD\",\n        \"status\": \"paid\",\n        \"session_id\": \"\",\n        \"email\": \"aryangupta+3265@paysecure.dev\",\n        \"merchant_name\": \"prithvimerch\",\n        \"payment_method\": \"MASTER\",\n        \"payment_flow\": \"payform\",\n        \"issuing_bank\": \"PUBLIC BANK BERHAD\",\n        \"created_at\": \"2026-04-17T10:47:53Z\",\n        \"error_reason\": \"Transaction succeeded-APPROVED\",\n        \"last_updated_at\": \"2026-04-17T10:49:14Z\",\n        \"transaction_type\": \"parent\",\n        \"fees\": [\n            {\n                \"type\": \"mdr\",\n                \"amount\": 0.00,\n                \"currency\": \"USD\"\n            },\n            {\n                \"type\": \"decline_fee\",\n                \"amount\": 0,\n                \"currency\": \"USD\"\n            },\n            {\n                \"type\": \"transaction_fee\",\n                \"amount\": 0.1,\n                \"currency\": \"USD\"\n            },\n            {\n                \"type\": \"fraud_refund_fee\",\n                \"amount\": 0,\n                \"currency\": \"USD\"\n            },\n            {\n                \"type\": \"refund_fee\",\n                \"amount\": 0,\n                \"currency\": \"USD\"\n            },\n            {\n                \"type\": \"chargeback_fee\",\n                \"amount\": 0,\n                \"currency\": \"USD\"\n            },\n            {\n                \"type\": \"extra_fee\",\n                \"amount\": 0,\n                \"currency\": \"USD\"\n            }\n        ],\n        \"metadata\": {\n            \"has_subtransactions\": false,\n            \"total_subtransactions\": 0,\n            \"transaction_hierarchy_level\": \"parent\"\n        }\n    }\n}"}],"_postman_id":"fc665062-e61c-4a2f-89bb-a9e2a5abdd2a"}],"id":"83a51b51-cb44-486b-ac06-f4b5dcd9a9e3","description":"<h2 id=\"overview\">Overview</h2>\n<p>The Transaction Reporting APIs allow merchants to retrieve detailed logs of their payment activity programmatically. This is useful for:</p>\n<ul>\n<li><p><strong>Reconciliation:</strong> Matching Paysecure records with your internal order system.</p>\n</li>\n<li><p><strong>Audit Trails:</strong> Tracking the status history of specific transactions.</p>\n</li>\n<li><p><strong>Data Export:</strong> Pulling transaction data into your own analytics tools.</p>\n</li>\n</ul>\n<p>There are two primary endpoints:</p>\n<ol>\n<li><p><strong>List Transactions:</strong> Retrieves a paginated list of all transactions for a specific Brand ID.</p>\n</li>\n<li><p><strong>Get Transaction Details:</strong> Retrieves the full data payload for a single transaction ID, including metadata and sub-transaction details.</p>\n</li>\n</ol>\n","_postman_id":"83a51b51-cb44-486b-ac06-f4b5dcd9a9e3"},{"name":"Network Tokenisation","item":[{"name":"Merchant Configuration","item":[],"id":"c0aea73a-98f3-498c-9356-4fc5fd71cdf0","description":"<p>Before you can use network tokenisation in your payment flow, the feature must be enabled and configured on your merchant account. This section walks through the setup steps in the Paysecure Dashboard.</p>\n<h2 id=\"enabling-network-tokenisation\">Enabling Network Tokenisation</h2>\n<p>Network tokenisation requires activation at the merchant level. Follow these steps in the Paysecure Dashboard:</p>\n<ol>\n<li><p>Log in to your Paysecure merchant account.</p>\n</li>\n<li><p>Navigate to Merchant Details → Allowed Services.</p>\n</li>\n<li><p>Enable “Allow Network Token” to activate tokenisation for your account.</p>\n</li>\n</ol>\n<p><strong>Admin Activation Required</strong><br />Network tokenisation must first be enabled at the platform level by your Paysecure account administrator. If you do not see the “Allow Network Token” option in your dashboard, contact your Paysecure account manager to request activation.</p>\n<img src=\"https://content.pstmn.io/6203c767-d43a-4b53-b43b-2b925d101d2d/U2NyZWVuc2hvdCAyMDI2LTAzLTEzIGF0IDEyLjU1LjQ44oCvQU0uanBn\" />\n\n<h2 id=\"paysecure-token-service-setup\">Paysecure Token Service Setup</h2>\n<p>After enabling network tokenisation, configure the Paysecure Token Service with your merchant details:</p>\n<ol>\n<li><p>In the Paysecure Dashboard, navigate to Global Settings → Paysecure Token Service.</p>\n</li>\n<li><p>Fill in all the required fields accurately.</p>\n</li>\n<li><p>Enter your Category Code — this represents your merchant business type code (MCC).</p>\n</li>\n<li><p>Click Save.</p>\n</li>\n<li><p>After saving, verify that the status shows as Pending (visible in the top-right corner of the page).</p>\n</li>\n<li><p>The status will automatically update to Active or Error once your token profile is created.</p>\n</li>\n</ol>\n<img src=\"https://content.pstmn.io/1a41fc67-9194-4ba6-8b4a-2c50a4923740/U2NyZWVuc2hvdCAyMDI2LTAzLTEzIGF0IDMuMjkuNDXigK9BTS5wbmc=\" />\n\n<p><strong>Status Update Timing:</strong> The status update from Pending to Active may take up to 1 hour. Do not attempt to use tokenisation APIs until the status shows Active. If the status changes to Error, contact your Paysecure account manager for resolution.</p>\n<h3 id=\"status-values\"><strong>Status Values</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Status</th>\n<th>Meaning</th>\n<th>Action Required</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Pending</td>\n<td>Your token service profile has been submitted and is being provisioned.</td>\n<td>Wait for the status to update. This may take up to 1 hour.</td>\n</tr>\n<tr>\n<td>Active</td>\n<td>Token service is live and ready to use. You can now process tokenised transactions.</td>\n<td>None — you are ready to integrate.</td>\n</tr>\n<tr>\n<td>Error</td>\n<td>There was a problem creating your token profile.</td>\n<td>Contact your Paysecure account manager to resolve the issue.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"d1edbbc3-7922-454b-9ddc-d07082c1f170","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"973ce7ac-782a-45bc-af35-063df0343ef3","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"c0aea73a-98f3-498c-9356-4fc5fd71cdf0"},{"name":"APIs","item":[{"name":"List Saved Cards","id":"d4aa47d0-af57-44e6-a8c1-ea8a7ca6fbae","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"auth":{"type":"noauth","isInherited":false},"method":"GET","header":[],"url":"https://api.paysecure.net/api/v1/listSavedCards","description":"<h2 id=\"list-saved-cards\">List Saved Cards</h2>\n<p>Retrieve all saved card tokens for a given customer. Returns the last 4 digits of each card and its associated <code>token_reference</code>.</p>\n<p>Use this API to display saved cards to the customer for selection before initiating a payment via the S2S API.</p>\n<h3 id=\"query-parameters\">Query Parameters</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th>Required</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><code>customerId</code></td>\n<td>string</td>\n<td>Yes</td>\n<td>Unique identifier for the customer. Must be URL-encoded if it contains special characters. Email addresses are case-sensitive.</td>\n</tr>\n<tr>\n<td><code>brandId</code></td>\n<td>string</td>\n<td>Yes</td>\n<td>Brand id of the merchant</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"response-fields\">Response Fields</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Field</th>\n<th>Type</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><code>card_last_four</code></td>\n<td>string</td>\n<td>Last 4 digits of the stored card. Display to the customer for card selection.</td>\n</tr>\n<tr>\n<td><code>token_reference</code></td>\n<td>string</td>\n<td>Unique reference for this saved card. Pass this in the S2S payment request or Delete Token request. Do not display to the customer.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"notes\">Notes</h3>\n<ul>\n<li><p>The <code>token_reference</code> does not expire. It remains valid as long as the saved card has not been deleted.</p>\n</li>\n<li><p>Show saved cards to the customer using <code>card_last_four</code> alongside a card brand icon (Visa / Mastercard).</p>\n</li>\n<li><p>The <code>token_reference</code> should only be stored and used server-side.</p>\n</li>\n</ul>\n<h3 id=\"display-tip\">Display Tip</h3>\n<p>Show saved cards using cardlast4 alongside a card brand icon (Visa / Mastercard).<br />The token_reference should only be stored and used server-side.</p>\n","urlObject":{"path":["listSavedCards"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"6adefbd7-a50c-45ec-b443-dc9d00dba79b","name":"Success","originalRequest":{"method":"GET","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer {{APIKey}}","type":"text"}],"url":{"raw":"https://api.paysecure.net/api/v1/listSavedCards?customerId=test@paysecure.dev&brandId=fceb4dea-163c-492c-a9e6-beedd8539da8","host":["https://api.paysecure.net/api/v1"],"path":["listSavedCards"],"query":[{"key":"customerId","value":"test@paysecure.dev"},{"key":"brandId","value":"fceb4dea-163c-492c-a9e6-beedd8539da8"}]}},"status":"OK","code":200,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json"}],"cookie":[],"responseTime":null,"body":"[\n    {\n        \"card_last_four\": \"1003\",\n        \"token_reference\": \"token_2bcf691f0f0347d6bcb38118d1bb31d5\"\n    },\n    {\n        \"card_last_four\": \"6006\",\n        \"token_reference\": \"token_e17dd98c66c14b37afaa62bd4770f915\"\n    },\n    {\n        \"card_last_four\": \"6916\",\n        \"token_reference\": \"token_7178bb7208614544a285656da38ae5ac\"\n    }\n]"}],"_postman_id":"d4aa47d0-af57-44e6-a8c1-ea8a7ca6fbae"},{"name":"Purchase","id":"c105314d-1003-442f-845c-62f5621587a5","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer {{APIKey}}","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"customer@example.com\",\n        \"country\": \"IN\",\n        \"city\": \"Jaipur\",\n        \"stateCode\": \"RJ\",\n        \"street_address\": \"123 Main Street\",\n        \"zip_code\": \"302001\",\n        \"phone\": \"9999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"Product Name\",\n                \"price\": \"10.00\"\n            }\n        ]\n    },\n    \"brand_id\": \"{{BrandId}}\",\n    \"success_redirect\": \"https://yoursite.com/success\",\n    \"failure_redirect\": \"https://yoursite.com/failure\",\n    \"pending_redirect\": \"https://yoursite.com/pending\",\n    \"success_callback\": \"https://yoursite.com/webhook/success\",\n    \"failure_callback\": \"https://yoursite.com/webhook/failure\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/api/v1/purchases","description":"<h2 id=\"purchase\">Purchase</h2>\n<p>Initiate a payment transaction. This is the standard Paysecure Purchase API.</p>\n<p>When a customer completes the purchase on the Paysecure checkout page and opts to save their card, Paysecure provisions a network token in the background and generates a <code>token_reference</code> linked to the customer.</p>\n<h3 id=\"mandatory-parameters\">Mandatory Parameters</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><code>client.email</code></td>\n<td>string</td>\n<td>Customer's email address.  <br />Please send it in smallcase</td>\n</tr>\n<tr>\n<td><code>client.city</code></td>\n<td>string</td>\n<td>Customer's city.</td>\n</tr>\n<tr>\n<td><code>client.country</code></td>\n<td>string</td>\n<td>ISO-3166 Alpha-2 country code, uppercase (e.g., IN, US, SG).</td>\n</tr>\n<tr>\n<td><code>client.stateCode</code></td>\n<td>string</td>\n<td>State code, uppercase (e.g., RJ, CA, AL).</td>\n</tr>\n<tr>\n<td><code>client.street_address</code></td>\n<td>string</td>\n<td>Customer's street address.</td>\n</tr>\n<tr>\n<td><code>client.zip_code</code></td>\n<td>string</td>\n<td>Postal / ZIP code. US format: NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td><code>purchase.currency</code></td>\n<td>string</td>\n<td>ISO 4217 currency code (e.g., USD, EUR). Must be enabled on your account.</td>\n</tr>\n<tr>\n<td><code>purchase.products</code></td>\n<td>array</td>\n<td>Array of product objects with <code>name</code> and <code>price</code>.</td>\n</tr>\n<tr>\n<td><code>brand_id</code></td>\n<td>string</td>\n<td>Your Paysecure Brand ID from Dashboard.</td>\n</tr>\n<tr>\n<td><code>success_redirect</code></td>\n<td>string</td>\n<td>URL to redirect customer after successful payment.</td>\n</tr>\n<tr>\n<td><code>failure_redirect</code></td>\n<td>string</td>\n<td>URL to redirect customer after failed payment.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"optional-parameters\">Optional Parameters</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><code>pending_redirect</code></td>\n<td>string</td>\n<td>URL to redirect when payment is pending.</td>\n</tr>\n<tr>\n<td><code>success_callback</code></td>\n<td>string</td>\n<td>Server-to-server webhook URL for success.</td>\n</tr>\n<tr>\n<td><code>failure_callback</code></td>\n<td>string</td>\n<td>Server-to-server webhook URL for failure.</td>\n</tr>\n<tr>\n<td><code>merchantRef</code></td>\n<td>string</td>\n<td>Your internal reference for this transaction.</td>\n</tr>\n<tr>\n<td><code>paymentMethod</code></td>\n<td>string</td>\n<td>Pre-select payment method (e.g., VISA).</td>\n</tr>\n<tr>\n<td><code>client.phone</code></td>\n<td>string</td>\n<td>Customer's phone number.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"key-response-fields\">Key Response Fields</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Field</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><code>id</code></td>\n<td>Unique purchase ID.</td>\n</tr>\n<tr>\n<td><code>checkout_url</code></td>\n<td>Redirect customer here to complete payment. Card saving happens during this step.</td>\n</tr>\n<tr>\n<td><code>direct_post_url</code></td>\n<td>URL for S2S payment submission.</td>\n</tr>\n<tr>\n<td><code>status</code></td>\n<td>Purchase status. Initially \"created\".</td>\n</tr>\n</tbody>\n</table>\n</div><h4 id=\"network-tokenisation--card-saving\"><strong>Network Tokenisation &amp; Card Saving</strong></h4>\n<p>When the customer completes payment via <code>checkout_url</code> and opts to save their card, Paysecure provisions a network token. The <code>token_reference</code> is then available via the <strong>List Saved Cards</strong> API.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc","id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc","name":"APIs","type":"folder"}},"urlObject":{"path":["api","v1","purchases"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"ff5e1d95-83ac-41c0-b4ad-795ddb258184","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer {{APIKey}}","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"customer@example.com\",\n        \"country\": \"IN\",\n        \"city\": \"Jaipur\",\n        \"stateCode\": \"RJ\",\n        \"street_address\": \"123 Main Street\",\n        \"zip_code\": \"302001\",\n        \"phone\": \"9999999999\"\n    },\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"Product Name\",\n                \"price\": \"10.00\"\n            }\n        ]\n    },\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"success_redirect\": \"https://yoursite.com/success\",\n    \"failure_redirect\": \"https://yoursite.com/failure\",\n    \"pending_redirect\": \"https://yoursite.com/pending\",\n    \"success_callback\": \"https://yoursite.com/webhook/success\",\n    \"failure_callback\": \"https://yoursite.com/webhook/failure\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/api/v1/purchases"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"69b32e42250ac73495aefd50\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"himanshu1@paysecure.net\",\n        \"full_name\": \"OpHM\",\n        \"date_of_birth\": \"1800-01-01\",\n        \"street_address\": \"SB-124\",\n        \"country\": \"BR\",\n        \"city\": \"DLJPR\",\n        \"zip_code\": \"110001\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"DL\"\n    },\n    \"updated_on\": 1773350466,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"MASTER\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"errorCode\": \"NA\",\n    \"force_recurring\": false,\n    \"created_on\": 1773350466,\n    \"merchantRef\": \"69b32e42250ac73495aefd50\",\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"e-commerce\",\n                \"quantity\": 1.0,\n                \"price\": 10.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 10.0,\n        \"requestAmount\": 10.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"brand\",\n        \"brand_name\": \"brand\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1773350466\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"5949f2ac-b5a3-4ee4-b585-ad4cf9a6db18\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": false,\n    \"reference_generated\": \"PS1060\",\n    \"issued\": \"2026-03-12\",\n    \"due\": 1773350466,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"extraFee\": \"0\",\n    \"paidOn\": 0,\n    \"receivedAmt\": 0.0,\n    \"taxAmount\": 0.0,\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"sessionId\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0.0,\n    \"success_redirect\": \"https://google.com/\",\n    \"failure_redirect\": \"https://facebook.com/\",\n    \"pending_redirect\": \"https://paysecure.net\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"110.235.229.171\",\n    \"checkout_url\": \"https://api.choicepay.ca/payments/1b73d31d178113798afa0157c8805ef0/\",\n    \"direct_post_url\": \"https://api.choicepay.ca/api/v1/p/69b32e42250ac73495aefd50/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"c105314d-1003-442f-845c-62f5621587a5"},{"name":"S2S Payment","id":"f3dd39dd-f0a6-498d-ada5-455b0eadec8b","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer {{APIKey}}","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"Token_reference\": \"token_7178aa7208614544a285656da38ae5ac\",\n    \"cvc\": \"791\",\n    \"remember_card\": \"off\",\n    \"remote_ip\": \"157.38.242.7\",\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\n    \"accept_header\": \"text/html\",\n    \"language\": \"en-US\",\n    \"java_enabled\": false,\n    \"javascript_enabled\": true,\n    \"color_depth\": 24,\n    \"utc_offset\": 0,\n    \"screen_width\": 1920,\n    \"screen_height\": 1080\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/api/v1/p/{{brandId}}/?s2s=true","description":"<h2 id=\"s2s-payment\">S2S Payment</h2>\n<p>Process a payment using a saved card's <code>token_reference</code>. Paysecure resolves the token reference to the underlying network token and processes the payment securely. If the selected MID does not accept tokens, Paysecure automatically falls back to the card number.</p>\n<h3 id=\"s2s-input-scenarios\">S2S Input Scenarios</h3>\n<p>The S2S API accepts different input types depending on the scenario:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Scenario</th>\n<th>What to Send</th>\n<th>What Paysecure Does</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><strong>New card</strong> (first-time customer)</td>\n<td>Full card details</td>\n<td>Paysecure tokenises the card. If the MID supports tokens, the transaction uses the token; otherwise, the card number is used.</td>\n</tr>\n<tr>\n<td><strong>Returning customer</strong> (tokenised with Paysecure)</td>\n<td><code>token_reference</code> from List Saved Cards</td>\n<td>Paysecure uses the stored token and generates a new cryptogram. Falls back to card number if MID doesn't accept tokens.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"request-body\">Request Body</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Field</th>\n<th>Type</th>\n<th>Required</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><code>token_reference</code></td>\n<td>string</td>\n<td>Conditional</td>\n<td>Token reference from List Saved Cards. Required when paying with a Paysecure-tokenised card.</td>\n</tr>\n<tr>\n<td><code>cvc</code></td>\n<td>string</td>\n<td>Yes</td>\n<td>Card CVC/CVV. <strong>Required even when</strong> <strong><code>token_reference</code></strong> <strong>is provided</strong>, for 3DS authentication.</td>\n</tr>\n<tr>\n<td><code>remember_card</code></td>\n<td>string</td>\n<td>No</td>\n<td><code>\"on\"</code> to save card, <code>\"off\"</code> to skip. Use <code>\"off\"</code> with saved tokens.</td>\n</tr>\n<tr>\n<td><code>remote_ip</code></td>\n<td>string</td>\n<td>Yes</td>\n<td>Cardholder's IP address.</td>\n</tr>\n<tr>\n<td><code>user_agent</code></td>\n<td>string</td>\n<td>Yes</td>\n<td>Browser User-Agent string.</td>\n</tr>\n<tr>\n<td><code>accept_header</code></td>\n<td>string</td>\n<td>Yes</td>\n<td>Browser Accept header.</td>\n</tr>\n<tr>\n<td><code>language</code></td>\n<td>string</td>\n<td>Yes</td>\n<td>Browser language (e.g., <code>\"en-US\"</code>).</td>\n</tr>\n<tr>\n<td><code>java_enabled</code></td>\n<td>boolean</td>\n<td>Yes</td>\n<td>Java enabled in browser.</td>\n</tr>\n<tr>\n<td><code>javascript_enabled</code></td>\n<td>boolean</td>\n<td>Yes</td>\n<td>JavaScript enabled in browser.</td>\n</tr>\n<tr>\n<td><code>color_depth</code></td>\n<td>integer</td>\n<td>Yes</td>\n<td>Screen colour depth.</td>\n</tr>\n<tr>\n<td><code>utc_offset</code></td>\n<td>integer</td>\n<td>Yes</td>\n<td>UTC timezone offset (minutes).</td>\n</tr>\n<tr>\n<td><code>screen_width</code></td>\n<td>integer</td>\n<td>Yes</td>\n<td>Screen width (px).</td>\n</tr>\n<tr>\n<td><code>screen_height</code></td>\n<td>integer</td>\n<td>Yes</td>\n<td>Screen height (px).</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"token-reference-in-response\">Token Reference in Response</h3>\n<ul>\n<li><p><strong>Scenario 1</strong> (New card via S2S): <code>token_reference</code> returned in Check Status and Webhook.</p>\n</li>\n<li><p><strong>Scenario 2</strong> (Existing <code>token_reference</code>): <code>token_reference</code> returned in response and Webhook.</p>\n</li>\n</ul>\n<h3 id=\"important-notes\">Important Notes</h3>\n<ul>\n<li><p>CVC is <strong>required</strong> even when using a <code>token_reference</code>.</p>\n</li>\n<li><p>All browser fields are required for 3D Secure authentication.</p>\n</li>\n<li><p>Response follows the standard Paysecure payment response format.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc","id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc","name":"APIs","type":"folder"}},"urlObject":{"path":["api","v1","p","{{brandId}}",""],"host":["https://api.paysecure.net/api/v1"],"query":[{"description":{"content":"<p>Must be \"true\" for server-to-server requests.</p>\n","type":"text/plain"},"key":"s2s","value":"true"}],"variable":[]}},"response":[{"id":"fb376bbd-42a2-49bd-ac9a-44abd3b10ebd","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer {{APIKey}}","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"Token_reference\": \"token_7178aa7208614544a285656da38ae5ac\",\n    \"cvc\": \"791\",\n    \"remember_card\": \"off\",\n    \"remote_ip\": \"157.38.242.7\",\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\n    \"accept_header\": \"text/html\",\n    \"language\": \"en-US\",\n    \"java_enabled\": false,\n    \"javascript_enabled\": true,\n    \"color_depth\": 24,\n    \"utc_offset\": 0,\n    \"screen_width\": 1920,\n    \"screen_height\": 1080\n}","options":{"raw":{"language":"json"}}},"url":{"raw":"https://api.paysecure.net/api/v1/api/v1/p/6980e509b5e99e61f3bd4ccf/?s2s=true","host":["https://api.paysecure.net/api/v1"],"path":["api","v1","p","6980e509b5e99e61f3bd4ccf",""],"query":[{"key":"s2s","value":"true"}]}},"status":"OK","code":200,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json"}],"cookie":[],"responseTime":null,"body":"{\n    \"status\": \"pending\",\n    \"callback_url\": \"http://18.214.100.20/api/v1/payment/64b034ecc6dccf7d329d9eb3/\",\n    \"method\": \"GET\"\n}"}],"_postman_id":"f3dd39dd-f0a6-498d-ada5-455b0eadec8b"},{"name":"Delete Token","id":"c00406a7-2363-497a-a8f9-e24ff49ece25","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"DELETE","header":[{"key":"Authorization","value":"Bearer {{APIKey}}","type":"text"}],"url":"https://api.paysecure.net/api/v1/tokens/v1/deleteToken/{{token_reference}}","description":"<h2 id=\"delete-token\">Delete Token</h2>\n<p>Permanently delete a saved card and deactivate the associated network token. <strong>This action is irreversible.</strong></p>\n<h3 id=\"path-parameters\">Path Parameters</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th>Type</th>\n<th>Required</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td><code>token_reference</code></td>\n<td>string</td>\n<td>Yes</td>\n<td>The <code>token_reference</code> of the saved card to delete. Obtained from the List Saved Cards API.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"important-notes\">Important Notes</h3>\n<ul>\n<li><p>Deleting a token is <strong>permanent</strong>. The <code>token_reference</code> can no longer be used for payments.</p>\n</li>\n<li><p>The associated network token is deactivated with the card network.</p>\n</li>\n<li><p>If the customer wants to pay with this card again, they will need to re-enter their card details.</p>\n</li>\n</ul>\n<h3 id=\"when-to-delete\">When to Delete</h3>\n<ul>\n<li><p>Customer explicitly requests removal of their saved card.</p>\n</li>\n<li><p>GDPR or data retention compliance when a customer closes their account.</p>\n</li>\n<li><p>Consider implementing a \"Remove Card\" option in your account management UI.</p>\n</li>\n</ul>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc","id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc","name":"APIs","type":"folder"}},"urlObject":{"path":["tokens","v1","deleteToken","{{token_reference}}"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"b5ffe6b9-4c2e-4473-93cc-7f84e89d9011","name":"Success","originalRequest":{"method":"DELETE","header":[{"key":"Authorization","value":"Bearer {{APIKey}}","type":"text"}],"url":"https://api.paysecure.net/api/v1/tokens/v1/deleteToken/token_4ccea9d67d274f3db6e0be6156e09d06"},"status":"OK","code":200,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Token deleted successfully\"\n}"},{"id":"1c7055c7-bfda-4004-82ec-d5dbab92abda","name":"Failure","originalRequest":{"method":"DELETE","header":[{"key":"Authorization","value":"Bearer {{APIKey}}","type":"text"}],"url":"https://api.paysecure.net/api/v1/tokens/v1/deleteToken/token_4ccea9d67d274f3db6e0be6156e09d06"},"status":"Bad Request","code":400,"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json"}],"cookie":[],"responseTime":null,"body":"{\n  \"message\": \"token_reference does not exist in the system\",\n  \"code\": \"token_reference_invalid\"\n}"}],"_postman_id":"c00406a7-2363-497a-a8f9-e24ff49ece25"},{"name":"PayOut","id":"5dce8bfc-1152-4e7a-8fa1-4e0686d873fe","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"rahul@gmail.com\",\n        \"country\": \"GB\",\n        \"city\": \"London\",\n        \"stateCode\": \"QLD\",\n        \"full_name\": \"Rahul Jain\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"zip_code\": \"W1S 3BE\",\n        \"phone\": \"+44 9876543210\",\n        \"gender\": \"M\",\n        \"date_of_birth\": \"1970-07-10\"\n    },\n    \"purpose\": \"Testing cards payout\",\n    \"currency\": \"GBP\",\n    \"merchantRef\": \"YOUR ORDER ID\", // optional\n    \"payoutMethod\": \"PAYOUT-CARDS\",\n    \"amount\": 100.0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"extraParam\": {\n        \"token_reference\": \"token_ref\"\n    }\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/","description":"<h2 id=\"overview\">Overview</h2>\n<p>The <strong>Original Credit Transaction (OCT)</strong>, commonly referred to as <strong>Push to Card</strong>, enables merchants to facilitate near-instantaneous fund transfers directly to a customer’s eligible Visa or Mastercard debit or credit card. Unlike traditional refund processes that can only return funds from a previous purchase, OCT allows for independent disbursements of funds to a cardholder's account.</p>\n<p>This feature is designed for high-velocity industries that require frictionless, real-time payouts, such as:</p>\n<ul>\n<li><p><strong>Gaming &amp; Betting:</strong> Real-time withdrawal of player winnings.</p>\n</li>\n<li><p><strong>Marketplaces:</strong> Payouts to sellers or service providers.</p>\n</li>\n<li><p><strong>Corporate Disbursements:</strong> Instant insurance claims, rebates, or compensation payments.</p>\n</li>\n<li><p><strong>Merchant Settlements:</strong> Faster access to processed funds for sub-merchants.</p>\n</li>\n</ul>\n<p>By utilizing the Paysecure <code>/payout</code> API with the <code>PAYOUT-CARDS</code> method, you benefit from a unified orchestration layer that handles the complexities of card network routing, ensuring high success rates and global reach while maintaining the same security standards as your standard payment integrations.</p>\n<hr />\n<h2 id=\"integration-steps\">Integration Steps</h2>\n<ol>\n<li><p><strong>Enable OCT:</strong> Ensure \"Push to Card\" permissions are enabled for your merchant account in the Paysecure Merchant Portal.</p>\n</li>\n<li><p><strong>Collect Card Details:</strong> Use a secure method to collect the recipient's card number and expiry date or can you Paysecure's cashier to do that.</p>\n</li>\n<li><p><strong>Execute Payout:</strong> Call the <code>/payout</code> endpoint with the OCT-specific payout method.</p>\n</li>\n<li><p><strong>Handle Webhooks:</strong> Listen for the <code>paid</code> or <code>failure</code> events to update your internal records.</p>\n</li>\n</ol>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Required</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>Yes</td>\n<td>The customer's email.  <br />Please send it in small case.</td>\n</tr>\n<tr>\n<td>client.phone</td>\n<td>Yes</td>\n<td>The customer's phone number along with the country code.  <br />Example: +91 9634088651</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>Yes</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>Yes</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Optional</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>Optional</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>Optional</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>currency</td>\n<td>Yes</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>amount</td>\n<td>Yes</td>\n<td>amount in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>payoutMethod</td>\n<td>Optional</td>\n<td>example: PAYOUT-CARDS</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>Yes</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>Yes</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>Yes</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n<tr>\n<td>Purpose</td>\n<td>Optional</td>\n<td>The purpose of doing a payout.</td>\n</tr>\n<tr>\n<td>extraParam.token_reference</td>\n<td>Yes</td>\n<td>Paysecure Token</td>\n</tr>\n</tbody>\n</table>\n</div><p>Note:</p>\n<p>If the merchant is not PCI DSS compliant then they will need to use our <strong>cashier</strong> and we will show the user all the saved cards for him/her. Based on the card chosen, Paysecure will pick up the token_reference from our Back end.</p>\n<p>If the merchant is PCI DSS compliant then they can use the payout API and send the token reference as shown above.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc","id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc","name":"APIs","type":"folder"}},"urlObject":{"path":["payout",""],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"8ec5cdbc-8d83-4d22-9b76-fee002dea3c6","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Accept","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\n    \"client\": {\n        \"email\": \"rahul@gmail.com\",\n        \"country\": \"GB\",\n        \"city\": \"London\",\n        \"stateCode\": \"QLD\",\n        \"full_name\": \"Rahul Jain\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"zip_code\": \"W1S 3BE\",\n        \"phone\": \"+44 9876543210\",\n        \"gender\": \"M\",\n        \"date_of_birth\": \"1970-07-10\"\n    },\n    \"purpose\": \"Testing cards payout\",\n    \"currency\": \"GBP\",\n    \"merchantRef\": \"YOUR ORDER ID\", // optional\n    \"payoutMethod\": \"PAYOUT-CARDS\",\n    \"amount\": 100.0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\",\n    \"extraParam\": {\n        \"token_reference\": \"token_ref\"\n    }\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/payout/"},"status":"Unauthorized","code":401,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Fri, 13 Mar 2026 00:01:17 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"3ef27476-f274-4f6a-bb18-4c37e01d6dc2"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 05a63efd5ebb043211ccf075f3a8aa68.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"Iw6KuTkxZqm0RH8GJOXAh7uLEPJ6wj8OJbaFWdN_qDx31b5TSinnIA=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=g%2FW8jRMDFXKvTeXNugr1sgR4%2FoTXfyEHsscr3hqeIr2aPhFEVlSs%2FGiTjFw09%2BReVDjxT2esg2Wg0fdBf4oD3snlEv4p1JkITe2l7oLC%2Bkg%3D\"}]}"},{"key":"CF-RAY","value":"9db6c366997196a2-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"payoutId\": \"6977137755e0628e3600c562\",\n    \"client\": {\n        \"email\": \"rahul@gmail.com\",\n        \"country\": \"GB\",\n        \"city\": \"London\",\n        \"stateCode\": \"QLD\",\n        \"full_name\": \"Rahul Jain\",\n        \"street_address\": \"10 New Burlington Street Apt. 214\",\n        \"zip_code\": \"W1S 3BE\",\n        \"phone\": \"+44 9876543210\",\n        \"gender\": \"M\",\n        \"date_of_birth\": \"1970-07-10\"\n    },\n    \"updated_on\": 1769411447,\n    \"extraParam\": {\n        \"token_reference\": \"token_ref\"\n    },\n    \"payoutMethod\": \"PAYOUT-CARDS\",\n    \"amountUnit\": \"MAJOR\",\n    \"amount\": 100.0,\n    \"errorMsg\": \"\",\n    \"purpose\": \"Testing cards payout\",\n    \"created_on\": 1769411447,\n    \"merchantRef\": \"YOUR ORDER ID\",\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1769411447\n        },\n        {\n            \"status\": \"payout_in_process\",\n            \"timestamp\": 1769411447\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1769411447\n        },\n\n    ],\n    \"currency\": \"GBP\",\n    \"extraFee\": \"0\",\n    \"paymentOn\": 0,\n    \"checkout_url\": \"https://test4.paymentsclub.net/payout/092e59f94279a3742fa3715fe9a2112a/\",\n    \"taxAmount\": 0.0,\n    \"taxPercent\": 0.0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"success_callback\": \"https://your.success.callback.com\",\n    \"failure_callback\": \"https://your.failure.callback.com\"\n    \"redirectType\": \"POST\",\n    \"sessionId\": \"\",\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"trxMethod\": \"CARDS\",\n    \"success_callback\": \"\",\n    \"failure_callback\": \"\"\n}"}],"_postman_id":"5dce8bfc-1152-4e7a-8fa1-4e0686d873fe"}],"id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc","description":"<p>Network tokenisation in Paysecure uses four APIs. Together they cover the complete flow: retrieving saved cards, initiating a purchase (with card saving), processing payments with saved tokens, and deleting tokens.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"7cae9127-6d7b-4189-81bd-bf69ccd9e2f8","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"cd17c780-b9c3-43a7-960e-dc8516f9c15c","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"9eaccd60-5727-4f43-bcc2-6a0579b1d5dc"},{"name":"FAQs","item":[],"id":"c0435364-8906-401c-997c-b63043d2476d","description":"<p><strong>Q1: Do I need to change my existing integration to use network tokenisation?</strong><br />No. If you already use the Paysecure Purchase API and the S2S API with token_reference, your integration is already compatible. You just need to enable and configure network tokenisation in your Dashboard (see Section 3).</p>\n<p><strong>Q2: What is a token_reference?</strong><br />A token_reference (e.g., token_7178aa7208614544a285656da38aefac) is Paysecure’s internal identifier for a saved card. You use it to charge the saved card or delete it. It is not the card number or the network token — Paysecure manages those internally.</p>\n<p><strong>Q3: Does the token_reference expire?</strong><br />No. The token_reference does not expire. It remains valid as long as the saved card has not been deleted.</p>\n<p><strong>Q4: What happens when a customer’s card expires or is replaced?</strong></p>\n<p>The card network automatically updates the data linked to the token. Your token_reference stays the same, and payments continue to work without action from you or the customer.</p>\n<p><strong>Q5: Is CVC required even when using a token_reference?</strong><br />Yes. CVC is required even when a token_reference is provided. This is needed for 3D Secure authentication on customer-initiated transactions.</p>\n<p><strong>Q6: What if a card doesn’t support network tokenisation?</strong><br />Paysecure handles this automatically. If a card is not eligible, or if the selected MID does not accept tokens, Paysecure falls back to the card number. The API response and flow remain the same.</p>\n<p><strong>Q7: How long does the token service setup take?</strong><br />After saving your configuration in Dashboard → Global Settings → Paysecure Token Service, the status changes to Pending. It may take up to 1 hour to update to Active. Do not use tokenisation APIs until the status is Active.</p>\n<p><strong>Q8: Are email addresses case-sensitive for token lookup?</strong><br />Yes. Email addresses are case-sensitive. Ensure consistent formatting (always lowercase) when creating and retrieving tokens to avoid duplicate or missing entries.</p>\n<p><strong>Q9: How do I delete a saved card?</strong><br />Use the Delete Token API (DELETE /tokens/v1/deleteToken/{token_reference}). This permanently removes the card and deactivates the network token.</p>\n<p><strong>Q10: Is there an additional cost?</strong><br />Pricing details are communicated by your Paysecure account manager. Some card networks offer reduced interchange fees for tokenised transactions, which may offset service costs.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"2399e7de-3be6-4067-b759-584600c6a15e","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"68dff017-1d52-447f-b188-5b16769d8f33","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"c0435364-8906-401c-997c-b63043d2476d"}],"id":"be48a6aa-d0a0-4506-af8d-67662cbf10c1","description":"<h2 id=\"overview\">Overview</h2>\n<p>Paysecure supports Network Tokenisation to help merchants process card payments with improved security, higher authorisation rates, and seamless card lifecycle management.</p>\n<p>Network tokenisation works entirely behind the scenes. When a cardholder saves their card during a purchase, Paysecure securely provisions a network token and returns a <code>token_reference</code>. You use this reference for all future payments — you never handle actual card numbers or network tokens directly.</p>\n<h2 id=\"benefits\">Benefits</h2>\n<ul>\n<li><p><strong>Higher Approval Rates</strong> — Payments made with network tokens are recognised as more secure by issuers.</p>\n</li>\n<li><p><strong>Automatic Card Updates</strong> — Card replacements are handled silently by the card network.</p>\n</li>\n<li><p><strong>Stronger Security</strong> — Each token is merchant-specific and protected by a per-transaction cryptogram.</p>\n</li>\n<li><p><strong>Reduced PCI Burden</strong> — Store <code>token_reference</code> instead of card numbers.</p>\n</li>\n<li><p><strong>Zero Integration Overhead</strong> — Your existing API integration works as-is.</p>\n</li>\n</ul>\n<h2 id=\"api-flow\">API Flow</h2>\n<p>Network tokenisation is fully managed by Paysecure. The integration follows the standard Paysecure payment APIs:</p>\n<h3 id=\"the-merchant-flow\">The Merchant Flow</h3>\n<ol>\n<li><p>Call the List Saved Cards API to check if the customer has saved cards</p>\n</li>\n<li><p>If no saved cards exist, initiate a new payment via the Purchase + S2S API<br /> → If the merchant opts to save the customer card, Paysecure provisions a network token<br /> → Customer completes payment<br /> → A token_reference is generated and linked to the customer and card</p>\n</li>\n<li><p>For returning customers with saved cards:<br /> → Display saved cards using cardlast4 from List Saved Cards<br /> → Customer selects a card and provides CVC<br /> → Submit token_reference + CVC via the purchase + S2S API</p>\n</li>\n<li><p>To remove a saved card, call the Delete Token API.</p>\n</li>\n</ol>\n<p>Network tokenisation happens behind the scenes with no additional API calls and no changes to your existing flow.</p>\n<ol>\n<li><p><strong>List Saved Cards</strong> — Check if the customer has saved cards</p>\n</li>\n<li><p><strong>Purchase</strong> — Initiate a new payment (customer can save card during checkout)</p>\n</li>\n<li><p><strong>S2S Payment</strong> — Charge a saved card using <code>token_reference</code></p>\n</li>\n<li><p><strong>Delete Token</strong> — Remove a saved card permanently</p>\n</li>\n</ol>\n<h3 id=\"key-takeaway\">Key Takeaway</h3>\n<p>You never see or handle the actual network token. Paysecure abstracts it entirely behind the token_reference. Your integration stays simple while your customers get the security and reliability benefits of network tokenisation.</p>\n<h2 id=\"environments\">Environments</h2>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Environment</th>\n<th>Base URL</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Sandbox</td>\n<td><code>https://api.paysecure.net/api/v1</code>  <br />Note: set the Sandbox flag true (checked) in your merchant account. As shown in the image below</td>\n</tr>\n<tr>\n<td>Production</td>\n<td><code>https://api.paysecure.net/api/v1</code></td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"87fd9e61-4d7e-447a-8bd6-a24d7ef07461","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"52da2e30-185b-41f9-8291-66c6291f395e","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"be48a6aa-d0a0-4506-af8d-67662cbf10c1"},{"name":"Pre Authorization","item":[{"name":"Prerequisites","item":[],"id":"2683726c-8a68-4bb9-a9a0-af0c985d4439","description":"<p>Before integrating the pre-authorisation flow, ensure you have the following:</p>\n<h3 id=\"21-account-setup\"><strong>2.1 Account Setup</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Requirement</strong></th>\n<th><strong>Details</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Paysecure Merchant Account</td>\n<td>An active merchant account with API access enabled.</td>\n</tr>\n<tr>\n<td>API Key</td>\n<td>Your unique API key, available from Dashboard → API Keys.</td>\n</tr>\n<tr>\n<td>Brand ID</td>\n<td>Your brand identifier, found in Dashboard → Account Settings.</td>\n</tr>\n<tr>\n<td>Webhook URL (Recommended)</td>\n<td>A publicly accessible HTTPS endpoint to receive transaction status updates.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"22-environments\"><strong>2.2 Environments</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Environment</th>\n<th>Base URL</th>\n<th>Notes</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Sandbox</td>\n<td><a href=\"https://api.paysecure.net/api/v1\">https://api.paysecure.net/api/v1</a></td>\n<td>Set the Sandbox flag to true in your merchant account.</td>\n</tr>\n<tr>\n<td>Production</td>\n<td><a href=\"https://api.paysecure.net/api/v1\">https://api.paysecure.net/api/v1</a></td>\n<td>Live transactions. Ensure KYB verification is complete.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"23-authentication\"><strong>2.3 Authentication</strong></h3>\n<p>All API requests must include your API key in the request header.<br />Paysecure uses bearer token authentication.</p>\n<p>Authorization: Bearer {your_api_key}</p>\n<p>Content-Type: application/json</p>\n<p>Important: Never expose your API key in client-side code or public repositories. All API calls must be made server-to-server.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"23e5caae-c7a0-4d04-8c2a-926ce2d256b8","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"7afafd55-891a-45c0-a494-cea843b03742","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"2683726c-8a68-4bb9-a9a0-af0c985d4439"},{"name":"Payment Flow Overview","item":[],"id":"8cf39b20-9a88-4c08-a6db-4f33b9d1742e","description":"<p>The pre-authorisation and capture flow involves three distinct stages. Below is a high-level summary of each path the transaction can follow after authorisation.</p>\n<h2 id=\"31-flow-summary\">3.1 Flow Summary</h2>\n<p>Step 1 - The merchant sends a pre-authorisation request to reserve funds on the customer’s card. If successful, the transaction enters an AUTHORISED state.</p>\n<p>Step 2a (Capture Path) - The merchant sends a capture request for the full or partial authorised amount. On success, the transaction moves to CAPTURED and funds are settled.</p>\n<p>Step 2b (Void Path) - If the merchant no longer needs to collect the payment, they send a void request. The hold is released and the transaction moves to VOIDED.</p>\n<h2 id=\"32-state-transition-diagram\"><strong>3.2 State Transition Diagram</strong></h2>\n<p>The following diagram describes all possible states:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>From State</strong></th>\n<th><strong>Action</strong></th>\n<th><strong>To State (Terminal)</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>CREATED</td>\n<td>Pre-Authorise</td>\n<td>PREAUTHORIZED</td>\n<td>Funds are held on the customer’s card.</td>\n</tr>\n<tr>\n<td>PREAUTHORIZED</td>\n<td>Capture (Full)</td>\n<td>PAID</td>\n<td>Full authorised amount is settled.</td>\n</tr>\n<tr>\n<td>PREAUTHORIZED</td>\n<td>Capture (Partial)</td>\n<td>PARTIALLY_CAPTURED</td>\n<td>Part of the authorised amount is settled; remainder released.</td>\n</tr>\n<tr>\n<td>PREAUTHORIZED</td>\n<td>Void</td>\n<td>CANCELLED</td>\n<td>Hold is released. No funds are collected.</td>\n</tr>\n<tr>\n<td>PREAUTHORIZED</td>\n<td>(Expiry)</td>\n<td>EXPIRED</td>\n<td>Authorisation window elapsed without capture. Funds auto-released. 30 days default.</td>\n</tr>\n<tr>\n<td>PAID</td>\n<td>Refund</td>\n<td>REFUNDED</td>\n<td>Post-capture return of funds (separate API).</td>\n</tr>\n<tr>\n<td>PARTIALLY_CAPTURED</td>\n<td>Refund</td>\n<td>PARTIALLY_REFUNDED</td>\n<td>Post partial capture return of funds (separate API).</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>ℹ️ Note</strong></p>\n<p>Once a transaction is PAID or VOIDED, it cannot be reversed through this flow. Use the Refund API for post-capture reversals.</p>\n<h2 id=\"33-authorisation-validity-periods\"><strong>3.3 Authorisation Validity Periods</strong></h2>\n<p>Card networks enforce maximum hold periods. If you do not capture within the validity window, the authorisation expires automatically and funds are released.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Card Scheme</strong></th>\n<th><strong>Standard Hold Period</strong></th>\n<th><strong>Extended Hold (if available)</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Visa</td>\n<td>7 days</td>\n<td>Up to 30 days (select MCCs)</td>\n</tr>\n<tr>\n<td>Mastercard</td>\n<td>7 days</td>\n<td>Up to 30 days (select MCCs)</td>\n</tr>\n<tr>\n<td>American Express</td>\n<td>7 days</td>\n<td>Up to 30 days</td>\n</tr>\n<tr>\n<td>Discover</td>\n<td>10 days</td>\n<td><strong>N/A</strong></td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>⚠️ Best Practice</strong></p>\n<p>Capture as soon as the order is ready to ship or the service is delivered. Delaying capture increases the risk of authorisation expiry and declines.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"1bbbaf8b-2f97-4320-8115-6ed4546a7e7a","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"6d329421-4b0f-4e2f-a280-15a39ee00819","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"8cf39b20-9a88-4c08-a6db-4f33b9d1742e"},{"name":"APIs","item":[{"name":"Purchase","id":"3cfc6863-5331-4b97-bd2a-5e4146fc3455","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"example@paysecure.net\",\r\n        \"country\": \"IN\",\r\n        \"city\": \"123\",\r\n        \"stateCode\": \"ca\",\r\n        \"street_address\": \"test test\",\r\n        \"zip_code\": \"234567\",\r\n        \"phone\": \"+91 9999999999\"\r\n    },\r\n    \"purchase\": {\r\n        \"products\": [\r\n            {\r\n                \"name\": \"dk\",\r\n                \"price\": \"10\"\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"created\",\r\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\r\n    \"skip_capture\": true,\r\n    \"merchantRef\": \"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases","description":"<p>Use this endpoint to authorise a payment without capturing it. This places a temporary hold on the customer’s funds for the specified amount.</p>\n<p>To Initiate a payment, the very first call to make is <code>/purchases</code> with the required data in the request body.</p>\n<p>To generate a Purchase, you are required to provide the <code>Brand ID</code> (in the request body) and <code>API key</code> (in the header) Both can be located in the Dashboard section of your merchant account login.</p>\n<p>The request body structure is shown on the request body of the example request shown here.</p>\n<p>The following (see table below) are the mandatory parameters that are required to create a purchase request.</p>\n<h3 id=\"mandatory-parameters-in-the-request-body\"><strong>Mandatory parameters in the request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>client.email</td>\n<td>The customer's email.</td>\n</tr>\n<tr>\n<td>client.city</td>\n<td>The customer's city.</td>\n</tr>\n<tr>\n<td>client.country</td>\n<td>ISO-3166 Country Code. Must be upper case. Example “SG” (Alpha2)</td>\n</tr>\n<tr>\n<td>client.stateCode</td>\n<td>Example “AL”, “XZ”. Must be in upper case.</td>\n</tr>\n<tr>\n<td>Client.street_address</td>\n<td>The customer's address.</td>\n</tr>\n<tr>\n<td>client.zip_code</td>\n<td>The customer's ZIP or postal code. If country=US, zip format must be NNNNN or NNNNN-NNNN.</td>\n</tr>\n<tr>\n<td>purchase.currency</td>\n<td>ISO 4217 code for currency you want to send the transaction in.  <br />  <br />Please note, the currency has to be enabled by the account manager for your account.</td>\n</tr>\n<tr>\n<td>purchase.products</td>\n<td>An object which contains the list of products which the customer is buying.</td>\n</tr>\n<tr>\n<td>purchase.products.name</td>\n<td>The name of the product.</td>\n</tr>\n<tr>\n<td>purchase.products.price</td>\n<td>Price in decimal format.  <br />example 1:  <br />EUR 5 , should be sent as 5.00  <br />  <br />example 2:  <br />USD 10 and 37 cents , should be sent as 10.37</td>\n</tr>\n<tr>\n<td>brand_id</td>\n<td>Obtain from Dashboard section of your merchant account login.</td>\n</tr>\n<tr>\n<td>success_redirect</td>\n<td>URL to send the user if the transactions is successful.</td>\n</tr>\n<tr>\n<td>pending_redirect</td>\n<td>URL to send the user if the transactions is in pending.</td>\n</tr>\n<tr>\n<td>failure_redirect</td>\n<td>URL to send the user if the transactions is unsuccessful.</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"additional-parameters-for-this-usecase\"><strong>Additional parameters for this usecase:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Parameter</strong></th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>skip_capture</td>\n<td>true</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"essential-optional-parameters\">Essential Optional Parameters</h2>\n<h3 id=\"merchantref\">merchantRef</h3>\n<p>The <code>merchantRef</code> parameter, although not mandatory, is strongly advised for merchants to specify. Its inclusion offers two significant advantages for the merchant:</p>\n<ol>\n<li><p><strong>Prevention of Duplicate Requests:</strong> When a <code>merchantRef</code> is utilized, it acts as a unique identifier. This means that if a second purchase request is made using the same <code>merchantRef</code> (reference number), the system will recognize it and prevent duplicate transactions from occurring. This prevents unintended or duplicate purchases.</p>\n</li>\n<li><p><strong>Facilitation of Transaction Retrieval:</strong> In situations where the response from the initial purchase request times out or the 'purchaseId' isn't received, having the <code>merchantRef</code> allows the merchant to retrieve detailed transaction information. This ensures they can track and access the specific purchase details related to that reference, even if the immediate response was not received.</p>\n</li>\n</ol>\n<p>However, if the merchant does not specify the 'merchantRef' parameter, the platform will automatically assign and use an internal 'purchaseId' as a reference for that transaction.</p>\n<p>Upon successul create on a Purchase you'd get a <code>\"purchaseId\"</code> . Use this ID for the next step in Server to server call by calling <code>p/{purchaseId}/?s2s=true .</code></p>\n<h3 id=\"paymentmethod\">paymentMethod</h3>\n<p>The <code>paymentMethod</code> parameter identifies which payment solution merchant wants to use to perform a transaction. If parameter is provided, than Paysecure will perform direct payment with the selected payment method instead of loading Paysecure URL.</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<h3 id=\"possible-error-messages\">Possible Error Messages</h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Allowed Limit for this card for particular time period has been consumed</td>\n</tr>\n<tr>\n<td>some Mandatory Parameter are missing</td>\n</tr>\n<tr>\n<td>Invalid format of Date_of_Birth [allowed format: yyyy-mm-dd]</td>\n</tr>\n<tr>\n<td>Invalid Email Format</td>\n</tr>\n<tr>\n<td>Please submit Valid Alpha2 Country Code Ex:(AF,IN) in \\\"country\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass Valid State Code</td>\n</tr>\n<tr>\n<td>Please pass valid street address in \\\"street_address\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid city name in \\\"city\\\" parameter</td>\n</tr>\n<tr>\n<td>Please pass valid postal Code name in \\\"zip_code\\\" parameter</td>\n</tr>\n<tr>\n<td>You are not Allowed for Live Transaction</td>\n</tr>\n<tr>\n<td>Merchant Limit is not set</td>\n</tr>\n<tr>\n<td>Minimum amount is not set for this merchant</td>\n</tr>\n<tr>\n<td>Brand not found !</td>\n</tr>\n<tr>\n<td>Your charges setting is incomplete .Plese Contact to Administrator.</td>\n</tr>\n<tr>\n<td>Only {{currencyCode}} currency is allowed.</td>\n</tr>\n<tr>\n<td>Transaction amount must be equal or greater to minimum trans amount</td>\n</tr>\n<tr>\n<td>Invalid_Parameter  <br />You'd usually get it when one or more mandatory parameters are not present in the request.</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"1c3ca4df-2fd4-4653-8212-3c38aaf644f6","name":"Purchase","originalRequest":{"method":"POST","header":[],"body":{"mode":"raw","raw":"{\r\n    \"client\": {\r\n        \"email\": \"example@paysecure.net\",\r\n        \"country\": \"IN\",\r\n        \"city\": \"123\",\r\n        \"stateCode\": \"ca\",\r\n        \"street_address\": \"test test\",\r\n        \"zip_code\": \"234567\",\r\n        \"phone\": \"+91 9999999999\"\r\n    },\r\n    \"purchase\": {\r\n        \"products\": [\r\n            {\r\n                \"name\": \"dk\",\r\n                \"price\": \"10\"\r\n            }\r\n        ]\r\n    },\r\n    \"status\": \"created\",\r\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\r\n    \"skip_capture\": true,\r\n    \"merchantRef\": \"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\r\n    \"success_redirect\": \"https://your.success.redirect.com\",\r\n    \"pending_redirect\": \"https://your.pending.redirect.com\",\r\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\r\n    \"success_callback\": \"https://your.success.callback.com\",\r\n    \"failure_callback\": \"https://your.failure.callback.com\"\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases"},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Thu, 13 Jul 2023 17:22:14 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"purchaseId\": \"64b032c3c6dccf7d329d9e7e\",\n    \"client\": {\n        \"bank_account\": \"\",\n        \"bank_code\": \"\",\n        \"email\": \"dev@paysecure.net\",\n        \"phone\": \"\",\n        \"full_name\": \"\",\n        \"date_of_birth\": \"\",\n        \"personal_code\": \"\",\n        \"street_address\": \"test test\",\n        \"country\": \"IN\",\n        \"city\": \"123\",\n        \"zip_code\": \"234567\",\n        \"shipping_street_address\": \"\",\n        \"shipping_country\": \"\",\n        \"shipping_city\": \"\",\n        \"shipping_zip_code\": \"\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"legal_name\": \"\",\n        \"brand_name\": \"\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\",\n        \"stateCode\": \"ca\"\n    },\n    \"updated_on\": 1689268934,\n    \"type\": \"purchase\",\n    \"force_recurring\": false,\n    \"created_on\": 1689268934,\n    \"purchase\": {\n        \"currency\": \"USD\",\n        \"products\": [\n            {\n                \"name\": \"dk\",\n                \"quantity\": 1,\n                \"price\": 10,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 10,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1,\n        \"request_client_details\": [],\n        \"timezone\": \"America/Edmonton\",\n        \"email_message\": \"\"\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {\n                \"bank_account\": \"\",\n                \"bank_code\": \"\"\n            }\n        ],\n        \"legal_name\": \"shoes\",\n        \"brand_name\": \"shoes\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {},\n        \"country\": \"\",\n        \"attempts\": []\n    },\n    \"status\": \"CREATED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1689268934\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"bd69e8a5-adcf-40de-9e43-2b87cb129a5e\",\n    \"is_recurring_token\": false,\n    \"reference_generated\": \"PS161\",\n    \"merchantRef\":\"d9db7ec0-f94c-4a9d-8883-54c19c222d81\",\n    \"issued\": \"2023-07-13\",\n    \"due\": 1689268934,\n    \"refund_upto\": 0,\n    \"cc_descriptor\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 0,\n    \"success_redirect\": \"https://your.success.redirect.com\",\n    \"failure_redirect\": \"https://your.failure.redirect.com\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"149.86.53.48\",\n    \"checkout_url\": \"http://18.214.100.20/payments/64b032c3c6dccf7d329d9e7e/\",\n    \"direct_post_url\": \"http://18.214.100.20/api/v1/p/64b032c3c6dccf7d329d9e7e/\"\n}"}],"_postman_id":"3cfc6863-5331-4b97-bd2a-5e4146fc3455"},{"name":"S2S","id":"d9538905-94df-4a1b-bfac-5fc10364f631","protocolProfileBehavior":{"disableBodyPruning":true,"disableUrlEncoding":false},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"cardholder_name\": \"dk\",\r\n    \"card_number\": \"4111111111111111\",\r\n    \"expires\": \"10/23\",\r\n    \"cvc\": \"345\",\r\n    \"remember_card\": \"on\",\r\n    \"remote_ip\": \"157.38.242.7\",\r\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\r\n    \"accept_header\": \"text/html\",\r\n    \"language\": \"en-US\",\r\n    \"java_enabled\": false,\r\n    \"javascript_enabled\": true,\r\n    \"color_depth\": 24,\r\n    \"utc_offset\": 0,\r\n    \"screen_width\": 1920,\r\n    \"screen_height\": 1080\r\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/p/64bff4fff63e36669499e9c8/?s2s=true","description":"<p>This API would be the 2nd in sequence to call if the call to <code>/purchases/</code> was successful in step 1. and you want to do the transaction via Server-to-Server mode.</p>\n<p>The request body would contain the details of the card that's to be transacted upon.</p>\n<h3 id=\"mandatory-parameters-in-request-body\"><strong>Mandatory parameters in request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>remote_ip</td>\n<td>IP address of the customer’s device used for transaction. Helps in fraud checks and risk scoring. Ex- 157.38.242.7</td>\n</tr>\n<tr>\n<td>user_agent</td>\n<td>Full browser and operating system details captured from HTTP header. EX- Chrome/5.0 (X11; Linux x86_64)</td>\n</tr>\n<tr>\n<td>accept_header</td>\n<td>Browser’s accepted content types (from HTTP header). Used for validating request origin and device info. EX- text/html</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Note:</strong><br />If you want to use token_reference for doing a card transaction, please have a look at Network Tokenisation Section.</p>\n<h3 id=\"essential-parameters-in-request-body\"><strong>Essential parameters in request body:</strong></h3>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>cardholder_name</td>\n<td>Name of the cardholder</td>\n</tr>\n<tr>\n<td>card_number</td>\n<td>The card numbers Must be 10-20 characters.</td>\n</tr>\n<tr>\n<td>expires</td>\n<td>must be greater than the current month/year.</td>\n</tr>\n<tr>\n<td>cvc</td>\n<td>3 or 4 digit</td>\n</tr>\n</tbody>\n</table>\n</div><p>**<br />Other optional parameters in request body:**</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Notes</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>language</td>\n<td>Preferred language of the user’s browser . EX - en-US</td>\n</tr>\n<tr>\n<td>java_enabled</td>\n<td>Indicates if Java is enabled in the browser. Helps PSPs in device profiling. Ex- true/false</td>\n</tr>\n<tr>\n<td>javascript_enabled</td>\n<td>Indicates if JavaScript is enabled in the client browser. Used for 3DS or risk-based checks. Ex- true</td>\n</tr>\n<tr>\n<td>color_depth</td>\n<td>Bit depth of the display screen. Ex- 24</td>\n</tr>\n<tr>\n<td>utc_offset</td>\n<td>Difference in minutes between local time and UTC. Used for location and timezone checks. Ex- 330</td>\n</tr>\n<tr>\n<td>screen_width</td>\n<td>Width of the device screen in pixels. Used in device profiling. Ex- 1920</td>\n</tr>\n<tr>\n<td>screen_height</td>\n<td>Height of the device screen in pixels. Ex- 1080</td>\n</tr>\n</tbody>\n</table>\n</div><h3 id=\"successful-response\">Successful Response</h3>\n<p>If all the details are correct you'll get a 202 response with staus as Pending</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"status\": \"pending\",\n    \"callback_url\": \"https://paysecure.net/payment/63bd0bf80fb42a076e8a4dd1/\",\n    \"method\": \"GET\"\n}\n\n</code></pre>\n<p>If the response code is 202, after receiving the response body, direct the customer to the callback_url provided in the response.</p>\n<h3 id=\"errors\">Errors</h3>\n<p>If there are any errors then it'll be in the format of :</p>\n<pre class=\"click-to-expand-wrapper is-snippet-wrapper\"><code class=\"language-json\">{\n    \"message\": \"descriptive error message\",\n    \"code\": \"error_code\"\n}\n\n</code></pre>\n<p>Please see the Status Code section for further details.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Error Messages</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Client Ip could not be matched with Merchant Ip</td>\n</tr>\n<tr>\n<td>Invalid Card Information</td>\n</tr>\n<tr>\n<td>Card is Blocked</td>\n</tr>\n<tr>\n<td>Different Type of key used to create purchase and payment</td>\n</tr>\n<tr>\n<td>You charges setting is incomplete .Plese Contact to adminstrartor.</td>\n</tr>\n<tr>\n<td>Allowed Attempt for this Transaction has been consumed</td>\n</tr>\n<tr>\n<td>Invalid Card Expiry(Valid Format:MM/YY) must be greator than current month/year</td>\n</tr>\n<tr>\n<td>Customer profile is Blocked</td>\n</tr>\n<tr>\n<td>Customer/Card not allowed for transaction</td>\n</tr>\n</tbody>\n</table>\n</div>","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","name":"APIs","type":"folder"}},"urlObject":{"path":["p","64bff4fff63e36669499e9c8",""],"host":["https://api.paysecure.net/api/v1"],"query":[{"key":"s2s","value":"true"}],"variable":[]}},"response":[{"id":"6a141509-8901-4324-ab0c-b62f06716981","name":"Success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"cardholder_name\": \"dk\",\r\n    \"card_number\": \"411111111111111\",\r\n    \"expires\": \"10/23\",\r\n    \"cvc\": \"345\",\r\n    \"remember_card\": \"on\",\r\n    \"remote_ip\": \"157.38.242.7\",\r\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\r\n    \"accept_header\": \"text/html\",\r\n    \"language\": \"en-US\",\r\n    \"java_enabled\": false,\r\n    \"javascript_enabled\": true,\r\n    \"color_depth\": 24,\r\n    \"utc_offset\": 0,\r\n    \"screen_width\": 1920,\r\n    \"screen_height\": 1080\r\n}","options":{"raw":{"language":"json"}}},"url":{"raw":"https://api.paysecure.net/api/v1/p/64bff4fff63e36669499e9c8/?s2s=true","host":["https://api.paysecure.net/api/v1"],"path":["p","64bff4fff63e36669499e9c8",""],"query":[{"key":"s2s","value":"true"}]}},"status":"Accepted","code":202,"_postman_previewlanguage":"json","header":[{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"1; mode=block"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"X-Frame-Options","value":"DENY"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Date","value":"Thu, 13 Jul 2023 17:31:55 GMT"},{"key":"Keep-Alive","value":"timeout=60"},{"key":"Connection","value":"keep-alive"}],"cookie":[],"responseTime":null,"body":"{\n    \"status\": \"pending\",\n    \"callback_url\": \"http://18.214.100.20/api/v1/payment/64b034ecc6dccf7d329d9eb3/\",\n    \"method\": \"GET\"\n}"},{"id":"02e1a20a-605a-46d8-bf09-2417fd2fe45a","name":"Failure","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json","type":"text"},{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{\r\n    \"cardholder_name\": \"dk\",\r\n    \"card_number\": \"4111111111111111\",\r\n    \"expires\": \"10/23\",\r\n    \"cvc\": \"345\",\r\n    \"remember_card\": \"on\",\r\n    \"remote_ip\": \"157.38.242.7\",\r\n    \"user_agent\": \"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36\",\r\n    \"accept_header\": \"text/html\",\r\n    \"language\": \"en-US\",\r\n    \"java_enabled\": false,\r\n    \"javascript_enabled\": true,\r\n    \"color_depth\": 24,\r\n    \"utc_offset\": 0,\r\n    \"screen_width\": 1920,\r\n    \"screen_height\": 1080\r\n}","options":{"raw":{"language":"json"}}},"url":{"raw":"https://api.paysecure.net/api/v1/p/64bff4fff63e36669499e9c8/?s2s=true","host":["https://api.paysecure.net/api/v1"],"path":["p","64bff4fff63e36669499e9c8",""],"query":[{"key":"s2s","value":"true"}]}},"status":"Unauthorized","code":401,"_postman_previewlanguage":null,"header":[{"key":"Date","value":"Tue, 06 Jan 2026 05:57:10 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"cc434220-0bcd-42c7-9078-53503b81a221"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 9bce423254194c16408d5cf7234126e2.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"FgTt6KEGIk0CH79DQDOvB1tYb1pGfaz0ryIVmQ0CCpDShyhsJGuAkA=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=9SnHJOEjnd1y7hArGsRLWmrk8H9ExaiR%2Fc%2BQMWhAvHlNPYCNEjS60wTjIyODXpca0ZD9%2BalkhLJ63boMGg%2B8iI6eFtXfW%2BxwGaBP1p1ZcwpA\"}]}"},{"key":"CF-RAY","value":"9b98f9f4684505e7-IAD"},{"key":"alt-svc","value":"h3=\":443\"; ma=86400"}],"cookie":[],"responseTime":null,"body":"{\n    \"message\": \"Authorization header missing\",\n    \"code\": \"authentication_failed\"\n}"}],"_postman_id":"d9538905-94df-4a1b-bfac-5fc10364f631"},{"name":"Capture","id":"58359799-0077-4e5d-9d67-a1908cf26679","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n    \"merchant_reference\": \"64534345\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/69cd26b053d7b783ebf6b6e9/capture","description":"<p>After a successful pre-authorisation, use this endpoint to capture (settle) the held funds. You may capture the full authorised amount or a partial amount.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","69cd26b053d7b783ebf6b6e9","capture"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"6b653ffa-4198-40f7-83fe-ad46c726500e","name":"Capture","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"},{"key":"Authorization","value":"Bearer Token"}],"body":{"mode":"raw","raw":"{\n    \"merchant_reference\": \"64534345\"\n}","options":{"raw":{"language":"json"}}},"url":"https://api.paysecure.net/api/v1/purchases/69cd26b053d7b783ebf6b6e9/capture"},"status":"Internal Server Error","code":500,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Wed, 01 Apr 2026 17:16:51 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"72818dba-381a-449a-8351-390453ddbf72"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 3578d122de1401ebc52a7afd35dd5d0c.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"zEG99N28vChcugkKEe-mJxhNgum-PAK1lcn_2mKqagcBd5deWquIjw=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=EnQbeJo0VkBTF%2BqefkY%2BZ1OejkL%2BkIkR76eA5%2FtL3qaxYlOL1ehFjmSIpGl5i91OldfFB41NXeRXp3E43WxFSEhlUj7OgOqbI6eYZs%2B%2BcUBdewUDmvk46tJrDA5WO53Bib8q\"}]}"},{"key":"CF-RAY","value":"9e593e77fb953ec9-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"purchaseId\": \"69cd361053d7b783ebf7324d\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"kailashvishnoi126741@paysecure.co\",\n        \"full_name\": \"akshaya singhal\",\n        \"date_of_birth\": \"1800-01-01\",\n        \"street_address\": \"123\",\n        \"country\": \"ZM\",\n        \"city\": \"jaipur\",\n        \"zip_code\": \"234567\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"CA\"\n    },\n    \"updated_on\": 1775056447,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"MASTER,VISA,VIRTUAL-IBAN,CRYPTO-WALLET,MAYA,GCASH,QRPH,BANKTRANSFER,NETBANKING,UPI-QR,PAYPLAY,UPI-INTENT,MOBILEMONEY,GOOGLEPAY,APPLEPAY\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"errorCode\": \"NA\",\n    \"force_recurring\": false,\n    \"created_on\": 1775056400,\n    \"extraParam\": {\n        \"aft\": {\n            \"account_owner_address1\": \"test\",\n            \"account_owner_address2\": \"test\",\n            \"account_owner_street\": \"test\",\n            \"account_owner_postal_code\": \"123\",\n            \"account_owner_city\": \"test\",\n            \"account_owner_country\": \"UK\",\n            \"merchant_postal_code\": \"123\",\n            \"merchant_state\": \"FRA\",\n            \"acceptor_legal_name\": \"test\",\n            \"sender_address\": \"test\",\n            \"sender_city\": \"test\",\n            \"sender_state\": \"RJ\",\n            \"sender_country\": \"FRA\",\n            \"sender_name\": \"test\",\n            \"sender_account_number\": \"test\",\n            \"recipient_name\": \"test\",\n            \"bai\": \"AA\"\n        }\n    },\n    \"merchantRef\": \"69cd361053d7b783ebf7324d\",\n    \"purchase\": {\n        \"currency\": \"EUR\",\n        \"products\": [\n            {\n                \"name\": \"gaming cards\",\n                \"quantity\": 1.0,\n                \"price\": 10.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 10.0,\n        \"requestAmount\": 10.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 10.0,\n        \"currency\": \"EUR\",\n        \"net_amount\": 10.0,\n        \"fee_amount\": 0.0,\n        \"pending_amount\": 0.0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1775056410,\n        \"remote_paid_on\": 1775056410\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"ECOMTEST1\",\n        \"brand_name\": \"ECOMTEST1\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"12\",\n            \"amount\": 10.0,\n            \"card_issuer\": \"ING BELGIUM, S.A.\",\n            \"masked_pan\": \"46401701****6658\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"BE\",\n            \"card_type\": \"CREDIT\",\n            \"cardholder_name\": \"Sank\",\n            \"expiry_year\": \"28\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"223.235.99.134\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"BE\",\n                \"processing_time\": 1775056410,\n                \"extra\": {\n                    \"expiry_month\": \"12\",\n                    \"amount\": 10.0,\n                    \"card_issuer\": \"ING BELGIUM, S.A.\",\n                    \"masked_pan\": \"46401701****6658\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"BE\",\n                    \"card_type\": \"CREDIT\",\n                    \"cardholder_name\": \"Sank\",\n                    \"expiry_year\": \"28\"\n                }\n            }\n        ]\n    },\n    \"status\": \"PAID\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1775056400\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1775056410\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1775056410\n        },\n        {\n            \"status\": \"3DS success\",\n            \"timestamp\": 1775056424\n        },\n        {\n            \"status\": \"preauthorized\",\n            \"timestamp\": 1775056428\n        },\n        {\n            \"status\": \"capture_in_process\",\n            \"timestamp\": 1775056447\n        },\n        {\n            \"status\": \"paid\",\n            \"timestamp\": 1775056447\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"bab077d5-df4d-4fda-8c6c-2f78d97c9a16\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": true,\n    \"reference_generated\": \"PS1673\",\n    \"issued\": \"2026-04-01\",\n    \"due\": 1775056400,\n    \"refund_upto\": 1776089649,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"extraFee\": \"0\",\n    \"pix_payload\": {},\n    \"payInDetails\": {},\n    \"paidOn\": 1775056449,\n    \"receivedAmt\": 0.0,\n    \"captureTxns\": [\n        {\n            \"captureId\": \"41e31f9f-1e98-4f4d-b48c-7d1ed488fc3f\",\n            \"purchaseId\": \"69cd361053d7b783ebf7324d\",\n            \"amount\": 10.0,\n            \"fxAmount\": 10.0,\n            \"status\": \"PAID\",\n            \"pspReference\": null,\n            \"merchantReference\": \"64534345\",\n            \"createdAt\": 1775056447,\n            \"updatedAt\": 1775056447,\n            \"whiteId\": 0,\n            \"fxCurrency\": \"EUR\",\n            \"bankMid\": \"payneticsexternal3ds\",\n            \"isTest\": false,\n            \"currency\": \"EUR\",\n            \"amountInUsd\": 11.85,\n            \"merchantName\": \"KailashMerchant\",\n            \"bankName\": \"paynatics-aft_\",\n            \"bankId\": \"532\",\n            \"trxMethod\": \"CARDS\",\n            \"rollingReserve\": 0.0,\n            \"transFees\": 0.0,\n            \"mdr\": 0.0,\n            \"isSettlementPending\": 0,\n            \"parentId\": 0,\n            \"transSettlementId\": null,\n            \"errorSettlementId\": null,\n            \"merchantId\": \"589\"\n        }\n    ],\n    \"taxAmount\": 0.0,\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"sessionId\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 10.0,\n    \"success_redirect\": \"https://google.com/getResponse.jsp?issucces=true\",\n    \"failure_redirect\": \"https://google.com/getResponse.jsp?issucces=false\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://www.google.com/\",\n    \"failure_callback\": \"https://staging.paysecure.net/merchant\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"223.235.99.134\",\n    \"checkout_url\": \"https://staging.paysecure.net/payments/47395a8217d29014a4af6b1c494ac06b/\",\n    \"direct_post_url\": \"https://staging.paysecure.net/api/v1/p/69cd361053d7b783ebf7324d/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"58359799-0077-4e5d-9d67-a1908cf26679"},{"name":"Cancel","id":"d4c70e6b-b091-4043-8f21-6fe02008e9b8","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer 309855a6e22c2bc9873f11ee5997cb3ff246a8e8ec4f009f2924ad7178b2ad7b"}],"url":"https://api.paysecure.net/api/v1/purchases/69ca76dbace4fa4413db928c/cancel","description":"<p>Use this endpoint to cancel an authorised payment before it has been captured. Voiding releases the held funds back to the customer immediately.</p>\n","auth":{"type":"noauth","isInherited":true,"source":{"_postman_id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","name":"APIs","type":"folder"}},"urlObject":{"path":["purchases","69ca76dbace4fa4413db928c","cancel"],"host":["https://api.paysecure.net/api/v1"],"query":[],"variable":[]}},"response":[{"id":"33055b6b-9bec-4a36-b80f-9038f2ab3090","name":"Cancel","originalRequest":{"method":"POST","header":[{"key":"Authorization","value":"Bearer 309855a6e22c2bc9873f11ee5997cb3ff246a8e8ec4f009f2924ad7178b2ad7b"}],"url":"https://api.paysecure.net/api/v1/purchases/69ca76dbace4fa4413db928c/cancel"},"status":"Method Not Allowed","code":405,"_postman_previewlanguage":"","header":[{"key":"Date","value":"Wed, 01 Apr 2026 17:18:25 GMT"},{"key":"Content-Type","value":"application/json"},{"key":"Transfer-Encoding","value":"chunked"},{"key":"Connection","value":"keep-alive"},{"key":"Nel","value":"{\"report_to\":\"cf-nel\",\"success_fraction\":0.0,\"max_age\":604800}"},{"key":"X-Frame-Options","value":"ALLOW-FROM *"},{"key":"Referrer-Policy","value":"no-referrer"},{"key":"x-session-id","value":"1c9b7d67-8dec-4e71-b35b-7952f23b67ed"},{"key":"Vary","value":"Origin"},{"key":"Vary","value":"Access-Control-Request-Method"},{"key":"Vary","value":"Access-Control-Request-Headers"},{"key":"Server","value":"cloudflare"},{"key":"X-Content-Type-Options","value":"nosniff"},{"key":"X-XSS-Protection","value":"0"},{"key":"Cache-Control","value":"no-cache, no-store, max-age=0, must-revalidate"},{"key":"Pragma","value":"no-cache"},{"key":"Expires","value":"0"},{"key":"Strict-Transport-Security","value":"max-age=31536000 ; includeSubDomains"},{"key":"X-Cache","value":"Error from cloudfront"},{"key":"Via","value":"1.1 8bd3b44b8e417f2b75cd6e631907112a.cloudfront.net (CloudFront)"},{"key":"X-Amz-Cf-Pop","value":"IAD61-P10"},{"key":"X-Amz-Cf-Id","value":"WSuVRaHm9E64itnjsFWAyBSPCR8YOFpZr7jY-NAhT-Ae-3_bc-hNTw=="},{"key":"cf-cache-status","value":"DYNAMIC"},{"key":"Report-To","value":"{\"group\":\"cf-nel\",\"max_age\":604800,\"endpoints\":[{\"url\":\"https://a.nel.cloudflare.com/report/v4?s=%2FOrvZsMz3WoHOQDEvKgGSADamNtnaGrILftqtr5BiqYIlUvgXZT89lPPwyXtpIDJW8BNOXjG%2FgAQmYnOUsUpQZ%2BDIVJsSDsxo4FxOEgIKcxPYcG21xgzcTNpNqbnk%2Fnw%2FEki\"}]}"},{"key":"CF-RAY","value":"9e5940bd580a07ed-IAD"}],"cookie":[{"expires":"Invalid Date","domain":"","path":""}],"responseTime":null,"body":"{\n    \"purchaseId\": \"69cd36c353d7b783ebf743e9\",\n    \"client\": {\n        \"customerId\": \"NA\",\n        \"email\": \"kailashvishnoi126741@paysecure.co\",\n        \"full_name\": \"akshaya singhal\",\n        \"date_of_birth\": \"1800-01-01\",\n        \"street_address\": \"123\",\n        \"country\": \"ZM\",\n        \"city\": \"jaipur\",\n        \"zip_code\": \"234567\",\n        \"cc\": [],\n        \"bcc\": [],\n        \"stateCode\": \"CA\"\n    },\n    \"updated_on\": 1775056649,\n    \"type\": \"purchase\",\n    \"paymentMethod\": \"MASTER,VISA,VIRTUAL-IBAN,CRYPTO-WALLET,MAYA,GCASH,QRPH,BANKTRANSFER,NETBANKING,UPI-QR,PAYPLAY,UPI-INTENT,MOBILEMONEY,GOOGLEPAY,APPLEPAY\",\n    \"amountUnit\": \"MAJOR\",\n    \"errorMsg\": \"\",\n    \"errorCode\": \"NA\",\n    \"force_recurring\": false,\n    \"created_on\": 1775056579,\n    \"extraParam\": {\n        \"aft\": {\n            \"account_owner_address1\": \"test\",\n            \"account_owner_address2\": \"test\",\n            \"account_owner_street\": \"test\",\n            \"account_owner_postal_code\": \"123\",\n            \"account_owner_city\": \"test\",\n            \"account_owner_country\": \"UK\",\n            \"merchant_postal_code\": \"123\",\n            \"merchant_state\": \"FRA\",\n            \"acceptor_legal_name\": \"test\",\n            \"sender_address\": \"test\",\n            \"sender_city\": \"test\",\n            \"sender_state\": \"RJ\",\n            \"sender_country\": \"FRA\",\n            \"sender_name\": \"test\",\n            \"sender_account_number\": \"test\",\n            \"recipient_name\": \"test\",\n            \"bai\": \"AA\"\n        }\n    },\n    \"merchantRef\": \"69cd36c353d7b783ebf743e9\",\n    \"purchase\": {\n        \"currency\": \"EUR\",\n        \"products\": [\n            {\n                \"name\": \"gaming cards\",\n                \"quantity\": 1.0,\n                \"price\": 10.0,\n                \"discount\": 0,\n                \"tax_percent\": \"0.00\"\n            }\n        ],\n        \"total\": 10.0,\n        \"requestAmount\": 10.0,\n        \"language\": \"en\",\n        \"notes\": \"\",\n        \"debt\": 0,\n        \"total_formatted\": 1.0,\n        \"taxAmount\": 0.0,\n        \"taxPercent\": 0.0,\n        \"request_client_details\": [],\n        \"email_message\": \"\"\n    },\n    \"payment\": {\n        \"is_outgoing\": false,\n        \"payment_type\": \"PURCHASE\",\n        \"amount\": 10.0,\n        \"currency\": \"EUR\",\n        \"net_amount\": 10.0,\n        \"fee_amount\": 0.0,\n        \"pending_amount\": 0.0,\n        \"pending_unfreeze_on\": null,\n        \"description\": \"\",\n        \"paid_on\": 1775056600,\n        \"remote_paid_on\": 1775056600\n    },\n    \"issuer_details\": {\n        \"website\": \"\",\n        \"legal_street_address\": \"\",\n        \"legal_country\": \"\",\n        \"legal_city\": \"\",\n        \"legal_zip_code\": \"\",\n        \"bank_accounts\": [\n            {}\n        ],\n        \"legal_name\": \"ECOMTEST1\",\n        \"brand_name\": \"ECOMTEST1\",\n        \"registration_number\": \"\",\n        \"tax_number\": \"\"\n    },\n    \"transaction_data\": {\n        \"payment_method\": \"\",\n        \"flow\": \"payform\",\n        \"extra\": {\n            \"expiry_month\": \"12\",\n            \"amount\": 10.0,\n            \"card_issuer\": \"JPMORGAN CHASE BANK, N.A.\",\n            \"masked_pan\": \"42000000****0000\",\n            \"card_brand\": \"VISA\",\n            \"card_issuer_country\": \"US\",\n            \"card_type\": \"CREDIT\",\n            \"cardholder_name\": \"Sank\",\n            \"expiry_year\": \"28\"\n        },\n        \"country\": \"\",\n        \"attempts\": [\n            {\n                \"client_ip\": \"223.235.99.134\",\n                \"type\": \"execute\",\n                \"payment_method\": \"VISA\",\n                \"flow\": \"payform\",\n                \"successful\": true,\n                \"country\": \"US\",\n                \"processing_time\": 1775056600,\n                \"extra\": {\n                    \"expiry_month\": \"12\",\n                    \"amount\": 10.0,\n                    \"card_issuer\": \"JPMORGAN CHASE BANK, N.A.\",\n                    \"masked_pan\": \"42000000****0000\",\n                    \"card_brand\": \"VISA\",\n                    \"card_issuer_country\": \"US\",\n                    \"card_type\": \"CREDIT\",\n                    \"cardholder_name\": \"Sank\",\n                    \"expiry_year\": \"28\"\n                }\n            }\n        ]\n    },\n    \"status\": \"CANCELLED\",\n    \"status_history\": [\n        {\n            \"status\": \"created\",\n            \"timestamp\": 1775056579\n        },\n        {\n            \"status\": \"pending_execute\",\n            \"timestamp\": 1775056600\n        },\n        {\n            \"status\": \"payment_in_process\",\n            \"timestamp\": 1775056600\n        },\n        {\n            \"status\": \"3DS success\",\n            \"timestamp\": 1775056607\n        },\n        {\n            \"status\": \"preauthorized\",\n            \"timestamp\": 1775056611\n        },\n        {\n            \"status\": \"void_in_process\",\n            \"timestamp\": 1775056632\n        },\n        {\n            \"status\": \"preauthorized\",\n            \"timestamp\": 1775056632\n        },\n        {\n            \"status\": \"void_in_process\",\n            \"timestamp\": 1775056647\n        },\n        {\n            \"status\": \"cancelled\",\n            \"timestamp\": 1775056649\n        }\n    ],\n    \"is_test\": false,\n    \"brand_id\": \"bab077d5-df4d-4fda-8c6c-2f78d97c9a16\",\n    \"send_receipt\": false,\n    \"is_recurring_token\": false,\n    \"skip_capture\": true,\n    \"reference_generated\": \"PS1675\",\n    \"issued\": \"2026-04-01\",\n    \"due\": 1775056579,\n    \"refund_upto\": 1776089849,\n    \"cc_descriptor\": \"\",\n    \"fraudScore\": \"NA\",\n    \"trustScore\": \"NA\",\n    \"extraFee\": \"0\",\n    \"pix_payload\": {},\n    \"payInDetails\": {},\n    \"paidOn\": 0,\n    \"receivedAmt\": 0.0,\n    \"taxAmount\": 0.0,\n    \"surcharge\": 0.0,\n    \"surchargeType\": \"\",\n    \"sessionId\": \"\",\n    \"refund_availability\": \"NONE\",\n    \"refundable_amount\": 10.0,\n    \"success_redirect\": \"https://google.com/getResponse.jsp?issucces=true\",\n    \"failure_redirect\": \"https://google.com/getResponse.jsp?issucces=false\",\n    \"cancel_redirect\": \"\",\n    \"success_callback\": \"https://www.google.com/\",\n    \"failure_callback\": \"https://staging.paysecure.net/merchant\",\n    \"platform\": \"API\",\n    \"created_from_ip\": \"223.235.99.134\",\n    \"checkout_url\": \"https://staging.paysecure.net/payments/23182fc42998cb02b4a3e6aa5c3e26c8/\",\n    \"direct_post_url\": \"https://staging.paysecure.net/api/v1/p/69cd36c353d7b783ebf743e9/\",\n    \"payoutProcess\": false\n}"}],"_postman_id":"d4c70e6b-b091-4043-8f21-6fe02008e9b8"}],"id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"c7d81f35-256f-42fd-b2b8-3e6335857750","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"ac424d8b-56aa-4dba-97c3-8f327cbb3d52","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"c811e188-c0c5-4c14-8d2e-7dfb01ed7364","description":""},{"name":"Transaction Status Lifecycle","item":[],"id":"e369b83d-bb0e-4a63-9cf3-bdb5d9b9976a","description":"<p>Every payment processed through the pre-authorisation flow passes through a series of statuses. Understanding these statuses is critical for building robust integrations.</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Status</th>\n<th>Description</th>\n<th>Available Actions</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>CREATED</td>\n<td>Transactions are initiated by merchants.</td>\n<td>Open checkout url</td>\n</tr>\n<tr>\n<td>PENDING_EXECUTE</td>\n<td>Transaction is in processing</td>\n<td>Wait</td>\n</tr>\n<tr>\n<td>PAYMENT_IN_PROCESS</td>\n<td>Transaction is being processed by the payment network.</td>\n<td>Wait</td>\n</tr>\n<tr>\n<td>PREAUTHORIZED</td>\n<td>Funds have been successfully held. Ready for capture or void.</td>\n<td>Capture, Void</td>\n</tr>\n<tr>\n<td>CAPTURE_IN_PROCESS</td>\n<td>Capture has been inititated and is in process.</td>\n<td>Wait</td>\n</tr>\n<tr>\n<td>PAID</td>\n<td>Full authorised amount has been settled to the merchant.</td>\n<td>Refund, Partial Refund</td>\n</tr>\n<tr>\n<td>PARTIALLY_CAPTURED</td>\n<td>A portion of the authorised amount was captured. Remainder released.</td>\n<td>Refund (on captured amount), Partial Refund</td>\n</tr>\n<tr>\n<td>VOID_IN_PROCESS</td>\n<td>Authorisation was cancelled before capture and it is in process</td>\n<td>None</td>\n</tr>\n<tr>\n<td>CANCELLED</td>\n<td>Authorisation was cancelled before capture. Funds released.</td>\n<td>None</td>\n</tr>\n<tr>\n<td>EXPIRED</td>\n<td>Authorisation expired without capture. Funds auto-released.</td>\n<td>None</td>\n</tr>\n<tr>\n<td>ERROR</td>\n<td>A processing error occurred during the preauthorisation step</td>\n<td>Retry Preauth</td>\n</tr>\n<tr>\n<td>REFUNDED</td>\n<td>Post-capture return of funds (separate API).</td>\n<td>None</td>\n</tr>\n<tr>\n<td>PARTIAL_REFUNDED</td>\n<td>Post-capture return of partial funds (separate API).</td>\n<td>Partial Refund</td>\n</tr>\n</tbody>\n</table>\n</div>","_postman_id":"e369b83d-bb0e-4a63-9cf3-bdb5d9b9976a"},{"name":"Best Practices","item":[],"id":"77100df5-b923-4bbc-959b-952ac1279c5d","description":"<h2 id=\"capture-timing\">Capture Timing</h2>\n<p>Capture payments as soon as the goods are shipped or the service is delivered. The longer you wait, the higher the risk of authorisation expiry, customer disputes, and declined captures.</p>\n<h2 id=\"idempotency\">Idempotency</h2>\n<p>Always include the X-Idempotency-Key header for all write operations (authorise, capture, void). This protects against duplicate transactions caused by network timeouts or retries.</p>\n<h2 id=\"webhook-driven-architecture\">Webhook-Driven Architecture</h2>\n<p>Do not rely solely on synchronous API responses for business logic. Implement webhook handlers to receive real-time status updates and use them as the source of truth for transaction state in your system.</p>\n<h2 id=\"error-handling\">Error Handling</h2>\n<p>Implement retry logic with exponential backoff for 5xx errors and 429 (rate limit) responses. For 4xx errors, parse the error response body and handle each error code appropriately in your application logic.</p>\n<h2 id=\"pci-compliance\">PCI Compliance</h2>\n<p>If you are handling raw card numbers, you must be PCI DSS Level 1 certified. Paysecure strongly recommends using tokenised payment methods to minimise your PCI scope. Use the Paysecure Cashier or client-side SDK to tokenise card details before they reach your server.</p>\n<h2 id=\"reconciliation\">Reconciliation</h2>\n<p>Use the reference field on authorise, capture, and void requests to associate Paysecure transactions with your internal order system. The balances object in every response provides a real-time breakdown for reconciliation.</p>\n<h2 id=\"3d-secure\">3D Secure</h2>\n<p>Enable 3DS for all pre-authorisation requests where supported. This shifts fraud liability to the card issuer and reduces chargebacks. Paysecure supports 3DS 2.x with frictionless and challenge flows.</p>\n","auth":{"type":"noauth","isInherited":false},"event":[{"listen":"prerequest","script":{"id":"01da4652-1268-480a-afa9-6328d93c80d3","type":"text/javascript","packages":{},"requests":{},"exec":[""]}},{"listen":"test","script":{"id":"4f223372-88e7-4c6b-a1af-06aa4728390a","type":"text/javascript","packages":{},"requests":{},"exec":[""]}}],"_postman_id":"77100df5-b923-4bbc-959b-952ac1279c5d"},{"name":"Frequently Asked Questions","item":[],"id":"b5110294-659a-4cde-9cc7-dd89d4f304ff","description":"<p><strong>Q: Can I capture more than the authorised amount?</strong></p>\n<p><strong>A: No. The capture amount must be less than or equal to the authorised amount. If you need to charge more, you must create a new authorisation for the additional amount.</strong></p>\n<p><strong>Q: Can I perform multiple partial captures on a single authorisation?</strong></p>\n<p><strong>A: Yes. Paysecure supports multiple captures per authorisation. But you will need to contact the support team for enabling the same.</strong> </p>\n<p><strong>Q: What happens if I do not capture before the authorisation expires?</strong></p>\n<p><strong>A: The authorisation automatically expires and the held funds are released back to the customer. You will receive a payment.expired webhook event. You must create a new authorisation to charge the customer.</strong></p>\n<p><strong>Q: Can I void a payment after it has been captured?</strong></p>\n<p><strong>A: No. Once a payment is captured, you must use the Refund API to return funds. The void endpoint only works for payments in AUTHORISED status.</strong></p>\n<p><strong>Q: How long does a void take to reflect on the customer’s statement?</strong></p>\n<p><strong>A: Typically, the hold is removed within 1–3 business days, depending on the issuing bank. Some banks may take up to 7 days to release the hold.</strong></p>\n<p><strong>Q: Does the customer see the pre-authorisation on their statement?</strong></p>\n<p><strong>A: Yes. The customer will see a pending charge for the authorised amount. This pending charge is released upon void or expiry, or replaced by the final charge upon capture.</strong></p>\n<p><strong>Q: Can I use pre-authorisation with non-card payment methods?</strong></p>\n<p><strong>A: Pre-authorisation is primarily supported for card payments. Support for alternative payment methods varies. Check the Paysecure payment methods documentation for details.</strong></p>\n<p><strong>Q: Is 3D Secure required for pre-authorisations?</strong></p>\n<p><strong>A: 3DS is not required but is strongly recommended. It reduces fraud liability and chargeback risk. Paysecure supports 3DS on all card pre-authorisation requests.</strong></p>\n","_postman_id":"b5110294-659a-4cde-9cc7-dd89d4f304ff"}],"id":"e0357e93-f550-4936-9da9-b34ba8cff881","description":"<h1 id=\"overview\"><strong>Overview</strong></h1>\n<p>Pre-authorisation (also known as \"auth only\") is a two-step payment process where a merchant first reserves (holds) funds on a customer’s payment method without immediately capturing the amount. This allows the merchant to verify fund availability before fulfilling an order, then capture (settle) the payment at a later time — or void (cancel) the hold if the order is not fulfilled.</p>\n<h2 id=\"when-to-use-pre-authorisation\"><strong>When to Use Pre-Authorisation</strong></h2>\n<p>Pre-authorisation is ideal for scenarios where the final transaction amount may change, or where goods/services are not delivered immediately. Common use cases include:</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Use Case</strong></th>\n<th><strong>Description</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>E-Commerce</td>\n<td>Authorise at checkout; capture when the order ships. Void if the item is out of stock.</td>\n</tr>\n<tr>\n<td>Hospitality</td>\n<td>Pre-authorise the estimated room charge at check-in; adjust and capture at checkout.</td>\n</tr>\n<tr>\n<td>Car Rentals</td>\n<td>Hold the estimated rental cost; capture the final amount upon vehicle return.</td>\n</tr>\n<tr>\n<td>Subscriptions</td>\n<td>Verify the card with a pre-auth before activating a trial; capture when billing begins.</td>\n</tr>\n<tr>\n<td>Marketplaces</td>\n<td>Authorise the buyer’s funds; capture once the seller confirms dispatch.</td>\n</tr>\n</tbody>\n</table>\n</div><h2 id=\"key-concepts\"><strong>Key Concepts</strong></h2>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th><strong>Term</strong></th>\n<th><strong>Definition</strong></th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>Pre-Authorisation</td>\n<td>A transaction that reserves funds on the customer’s card without settling them. Also called \"auth only\" or \"manual capture\".</td>\n</tr>\n<tr>\n<td>Capture</td>\n<td>The action of claiming the previously authorised funds. Can be full or partial.</td>\n</tr>\n<tr>\n<td>Partial Capture</td>\n<td>Capturing less than the originally authorised amount. The remaining balance is automatically released.</td>\n</tr>\n<tr>\n<td>Void</td>\n<td>Cancelling a pre-authorised transaction before capture, releasing the held funds back to the customer.</td>\n</tr>\n<tr>\n<td>Authorisation Expiry</td>\n<td>The time window during which a pre-auth remains valid. Typically 7–30 days depending on card scheme and MCC.</td>\n</tr>\n</tbody>\n</table>\n</div>","_postman_id":"e0357e93-f550-4936-9da9-b34ba8cff881"},{"name":"Get Balance API (V2) - Orchestration","item":[{"name":"Checking Balance","id":"3ee8ba05-05b3-4ca5-aa2e-f9f96049deb0","protocolProfileBehavior":{"disableBodyPruning":true},"request":{"method":"POST","header":[{"key":"Authorization","value":"Bearer Token","type":"text"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"PAYOUT-INTERAC-ETRANSFER\"\r\n\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"/getBalance","description":"<h2 id=\"api-for-checking-available-balance\"><strong>API for checking available balance</strong></h2>\n<ol>\n<li><p>URL :- /getBalance/</p>\n</li>\n<li><p>RequestType: POST</p>\n</li>\n<li><p>Request Body</p>\n</li>\n</ol>\n<p>Note: Currency is not a mandatory parameter. If no parameter is specified then all respective currency balances would be provided, if any specific currency parameter is provided then only that currency balance would be provided.</p>\n","urlObject":{"path":["getBalance"],"host":[""],"query":[],"variable":[]}},"response":[{"id":"9bb10ce4-cea1-43ba-817d-56e1036b8e2b","name":"Checking Balance payout-success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"PAYOUT-INTERAC-ETRANSFER\"\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"/getBalance"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"paymentMethod\": \"PAYOUT-INTERAC-ETRANSFER\",\n    \"status\": \"success\",\n    \"gateways\": [\n        {\n            \"gatewayName\": \"payhost\",\n            \"status\": \"success\",\n            \"error\": null,\n            \"balances\": [\n                {\n                    \"currency\": \"CAD\",\n                    \"balance\": 808.380000\n                },\n                {\n                    \"currency\": \"USD\",\n                    \"balance\": 803.380000\n                }\n            ]\n        },\n        {\n            \"gatewayName\": \"choicepaypg\",\n            \"status\": \"success\",\n            \"error\": null,\n            \"balances\": [\n                {\n                    \"currency\": \"CAD\",\n                    \"balance\": 808.380000\n                },\n                {\n                    \"currency\": \"USD\",\n                    \"balance\": 808.380000\n                }\n            ]\n        }\n    ],\n    \"aggregatedBalances\": [\n        {\n            \"currency\": \"CAD\",\n            \"balance\": 1616.760000\n        },\n        {\n            \"currency\": \"USD\",\n            \"balance\": 1611.760000\n        }\n    ]\n}"},{"id":"a89a4e12-6976-4567-b11a-f3ed6edbcaf4","name":"Checking Balance partial-success","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"CARDS\"\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"/getBalance"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"paymentMethod\": \"CARDS\",\n    \"status\": \"partial\",\n    \"gateways\": [\n        {\n            \"gatewayName\": \"a55Mandate\",\n            \"status\": \"failed\",\n            \"error\": {\n                \"code\": \"error\",\n                \"message\": \"Bank does not provide balance\"\n            },\n            \"balances\": []\n        },\n        {\n            \"gatewayName\": \"bk_sbx_smilepayz_pix_payin\",\n            \"status\": \"success\",\n            \"error\": null,\n            \"balances\": [\n                {\n                    \"currency\": \"IDR\",\n                    \"balance\": 250000.000000\n                }\n            ]\n        },\n        {\n            \"gatewayName\": \"choicepay_pg\",\n            \"status\": \"success\",\n            \"error\": null,\n            \"balances\": [\n                {\n                    \"currency\": \"AED\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"AUD\",\n                    \"balance\": 3412.000000\n                },\n                {\n                    \"currency\": \"BRL\",\n                    \"balance\": 100.089996\n                },\n                {\n                    \"currency\": \"BTC\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"BXC\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"CAD\",\n                    \"balance\": 1000.000000\n                },\n                {\n                    \"currency\": \"CDF\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"COP\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"DKK\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"EGP\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"ETH\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"EUR\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"GBP\",\n                    \"balance\": -24.327801\n                },\n                {\n                    \"currency\": \"GHS\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"IDR\",\n                    \"balance\": 1000.000000\n                },\n                {\n                    \"currency\": \"INR\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"JPY\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"KES\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"MWK\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"MXN\",\n                    \"balance\": -4.770000\n                },\n                {\n                    \"currency\": \"NGN\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"NZD\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"RWF\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"THB\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"TZS\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"UGX\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"USD\",\n                    \"balance\": 167.457992\n                },\n                {\n                    \"currency\": \"USDC\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"USDT\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"UZS\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"XAF\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"XOF\",\n                    \"balance\": 0.000000\n                },\n                {\n                    \"currency\": \"ZAR\",\n                    \"balance\": 120.000000\n                },\n                {\n                    \"currency\": \"ZMW\",\n                    \"balance\": 0.000000\n                }\n            ]\n        },\n        {\n            \"gatewayName\": \"payhost\",\n            \"status\": \"failed\",\n            \"error\": {\n                \"code\": \"error\",\n                \"message\": \"Bank does not provide balance\"\n            },\n            \"balances\": []\n        }\n    ],\n    \"aggregatedBalances\": [\n        {\n            \"currency\": \"AED\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"AUD\",\n            \"balance\": 3412.000000\n        },\n        {\n            \"currency\": \"BRL\",\n            \"balance\": 100.089996\n        },\n        {\n            \"currency\": \"BTC\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"BXC\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"CAD\",\n            \"balance\": 1000.000000\n        },\n        {\n            \"currency\": \"CDF\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"COP\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"DKK\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"EGP\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"ETH\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"EUR\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"GBP\",\n            \"balance\": -24.327801\n        },\n        {\n            \"currency\": \"GHS\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"IDR\",\n            \"balance\": 251000.000000\n        },\n        {\n            \"currency\": \"INR\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"JPY\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"KES\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"MWK\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"MXN\",\n            \"balance\": -4.770000\n        },\n        {\n            \"currency\": \"NGN\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"NZD\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"RWF\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"THB\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"TZS\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"UGX\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"USD\",\n            \"balance\": 167.457992\n        },\n        {\n            \"currency\": \"USDC\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"USDT\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"UZS\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"XAF\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"XOF\",\n            \"balance\": 0.000000\n        },\n        {\n            \"currency\": \"ZAR\",\n            \"balance\": 120.000000\n        },\n        {\n            \"currency\": \"ZMW\",\n            \"balance\": 0.000000\n        }\n    ]\n}"},{"id":"aba4800e-4e7b-4712-a2f0-46a6b3f33f7e","name":"Checking Balance payout-error","originalRequest":{"method":"POST","header":[{"key":"Content-Type","value":"application/json"}],"body":{"mode":"raw","raw":"{ \r\n   \"paymentMethod\" : \"PAYOUT-INTERAC\"\r\n}\r\n","options":{"raw":{"language":"json"}}},"url":"/getBalance"},"_postman_previewlanguage":"json","header":[{"key":"Content-Type","value":"application/json","description":"","type":"text"}],"cookie":[],"responseTime":null,"body":"{\n    \"paymentMethod\": \"PAYOUT-INTERAC\",\n    \"status\": \"failed\",\n    \"gateways\": [\n        {\n            \"gatewayName\": \"payhost\",\n            \"status\": \"failed\",\n            \"error\": {\n                \"code\": \"error\",\n                \"message\": \"Bank does not provide balance\"\n            },\n            \"balances\": []\n        }\n    ],\n    \"aggregatedBalances\": []\n}"}],"_postman_id":"3ee8ba05-05b3-4ca5-aa2e-f9f96049deb0"}],"id":"2bbb6da7-34b9-43ef-a58f-bc4acab2a86f","description":"<p>The <strong>Get Balance API (V2)</strong> provides orchestrator-level visibility into available balances across multiple payment methods and banking partners. This version enhances the existing balance API by aggregating and returning balance details for all supported payment methods associated with all the PSPs for the merchant</p>\n<p>Overview</p>\n<ul>\n<li><p>Purpose: Retrieve available balance information across different banks/payment methods.</p>\n</li>\n<li><p>Scope: Orchestrator-level (not limited to a single merchant or payment method).</p>\n</li>\n<li><p>Enhancement over previous version:</p>\n<ul>\n<li><p>Returns balances for all payment methods linked to the orchestrator.</p>\n</li>\n<li><p>Provides both consolidated and MID-level (Merchant ID) breakdowns.</p>\n</li>\n</ul>\n</li>\n</ul>\n<p>Request Parameters</p>\n<div class=\"click-to-expand-wrapper is-table-wrapper\"><table>\n<thead>\n<tr>\n<th>Parameter</th>\n<th><strong>Type</strong></th>\n<th>Required</th>\n<th>Description</th>\n</tr>\n</thead>\n<tbody>\n<tr>\n<td>paymentMethod</td>\n<td>string</td>\n<td>yes</td>\n<td>Specifies the payment method to query. Example: \"PAYOUT-INTERAC-ETRANSFER\"</td>\n</tr>\n</tbody>\n</table>\n</div><p><strong>Behavior</strong></p>\n<ul>\n<li><p>When a valid paymentMethod is provided, the API retrieves:</p>\n<ul>\n<li><p>Balance details across all associated banks/payment methods.</p>\n</li>\n<li><p>MID-level breakdown for each bank.</p>\n</li>\n<li><p>Consolidated balance per payment method.</p>\n</li>\n</ul>\n</li>\n<li><p>The API is designed specifically for orchestrators and returns aggregated data across multiple merchants and banking integrations.</p>\n</li>\n</ul>\n<p><strong>Success Response</strong></p>\n<p>On successful retrieval, the API returns:</p>\n<ul>\n<li><p>Payment Method Details</p>\n</li>\n<li><p>List of Banks / Payment Providers</p>\n</li>\n<li><p>MID-Level Breakdown</p>\n</li>\n<li><p>Consolidated Balance</p>\n</li>\n</ul>\n<p><strong>Partial Success Response</strong></p>\n<p>A Partial Success response is returned when balance information is retrieved successfully for some payment methods or banks, while one or more fail to return balance data.</p>\n<p>This scenario typically occurs when:</p>\n<ul>\n<li><p>A merchant is associated with multiple payment methods or banking partners, and</p>\n</li>\n<li><p>At least one provider returns a valid balance, while others fail due to unavailability, timeout, or missing data.</p>\n</li>\n</ul>\n<p><strong>Return values-</strong></p>\n<ul>\n<li><p>Status as \"Partial\"</p>\n</li>\n<li><p>Payment Method Details</p>\n</li>\n<li><p>List of Banks / Payment Providers</p>\n</li>\n<li><p>MID-Level Breakdown</p>\n</li>\n<li><p>Consolidated Balance</p>\n</li>\n</ul>\n<p><strong>Error Handling</strong></p>\n<p>If balance details are not found or the request cannot be processed, the API returns:</p>\n<ul>\n<li><p>Appropriate status code</p>\n</li>\n<li><p>Error message</p>\n</li>\n</ul>\n","_postman_id":"2bbb6da7-34b9-43ef-a58f-bc4acab2a86f"}],"event":[{"listen":"prerequest","script":{"id":"9311ef66-0bf5-4cf5-8d8a-5b447a1ca21d","type":"text/javascript","requests":{},"exec":[""]}},{"listen":"test","script":{"id":"41943df1-0b12-4bec-a2bc-96cffda7c730","type":"text/javascript","requests":{},"exec":[""]}}],"variable":[{"key":"BaseURL","value":"https://api.paysecure.net/api/v1"},{"key":"StagingAPIKey","value":""},{"key":"BaseV2URL","value":""}]}