Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

The realReal-time payment services are offered to businesses that would like to allow their customers to make a payment towards their account outside of the normal billing cycles. The customers can make a real-time payment for different reasons. It could be to clear an arrear in

payment 

payment or make an advance

payment 

payment.

make

Clear an

initial

arrear in payment

towards an account 

This service needs to be enabled for the business in order that their customers avail the service. To make an advance payment, the customer’s account must be due for the next payment. There is a maximum limit for the payment amount. You have a few options to choose from. They are listed as follows: 

GetPaymentToken 

The GetPaymentToken call can mostly be offered to customers who need to make an initial payment towards the account setup with Debitsuccess. It requires the following information: 

  1. Account Reference No. 

  2. Amount 

  3. Call back URL 

  4. Create a one-off charge 

  5. Payment method type 

  6. Payment notes 

  7. Request type   

It

Using PaymentToken for account payment (REST) or GetPaymentToken (SOAP) call for real-time payments gives you a few options such as: 

  1. Receive a link to pass on to the customers to make a payment 

  2. A separate one-off charge can be created for this payment if it has been successful 

  3. Define the amount that needs to be paid 

  4. Provide a URL for the customer to be redirected to after the payment is processed (call back URL) 

  5. For each business, you You can provide a Webhook URL which, after approval, that we will store in our database after approval for each business. We will post the transaction details to this Webhook URL once as a JSON object. The transaction details are the same as what we send back for CallbackURL - the WebhookTokenthe Token, AccountReferenceNo, ExternalAccountReferenceNo, Status and Message.   

Note

The CallbackURL should not be used for payment verification as it can be altered by the user. Instead, the webhook URL should be used for payment authentication.

Info

We recommend that they store that you store the WebhookToken we provide in the response securely to authenticate the information received through the WebhookURL is from Debitsuccess.  

6.
  1. The token has a lifespan of 10 minutes. This will mean that the customer needs to access the payment form URL within 10 minutes of the token being issued. 

7.
  1. The token is for one-time usage. Once the operation has started (link is clicked), it cannot be reused.  

REST API

Use the Generate PaymentToken for account payment endpoint of Customer Services API to make a payment to an account using a credit card.

Tip

Status
colourBlue
titlePOST
https://<ServerURL>/CustomerServices/v1.0/accounts/{accountId}/paymentTokens

Provide the following:

  • amount Amount to pay.

  • callbackURL The URL the customer needs to be redirected to after the operation.

  • createOneOffCharge ​set to False so that the amount will be allocated to the account balance.

  • paymentNote Any notes to be recorded against the payment.

SOAP API

GetPaymentToken

The GetPaymentToken call can mostly be offered to customers who need to make an initial payment towards the account setup with Debitsuccess. It requires the following information: 

  1. Account Reference No. 

  2. Amount 

  3. Call back URL 

  4. Create a one-off charge- ​set to False so that the amount will be allocated to the account balance. 
    For the Gateway model, the CreateOneOffCharge parameter has to be set to true.

  5. Payment method type 

  6. Payment notes 

  7. Request type     

Info

We recommend that this message should be used in conjunction with the message GetCardPaymentStatusForCustomerAccount for confirmation of payment. 

In the GetPaymentToken processthe GetPaymentToken process, a PayNow link is generated (the link is in the response field a:PaymentFormURL) and that can be shared with the customer to process a payment. This will ensure that you do not have to handle the credit card information of the customer. 

Sample Request
Code Block
languagexml
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:deb="Debitsuccess.WebServices.WCF" xmlns:deb1="http://schemas.datacontract.org/2004/07/Debitsuccess.WebServices.Core" xmlns:deb2="http://schemas.datacontract.org/2004/07/Debitsuccess.WebServices.Core.RequestMessages">
   <soapenv:Header/>
   <soapenv:Body>
      <deb:GetPaymentToken>
            <deb:request>    
            <deb1:User>
               <deb1:Id></deb1:Id>
               <deb1:Password>#QualIT</deb1:Password>
               <deb1:Username>QualIT</deb1:Username>
            </deb1:User>
            <deb1:AccountReferenceNo>DEA2884229</deb1:AccountReferenceNo>
            <deb2:Amount>6</deb2:Amount>
            <deb2:CallBackUrl>http://www.abc.com</deb2:CallBackUrl>
            <deb2:CreateOneOffCharge>false</deb2:CreateOneOffCharge>
            <deb2:PayMethodType>CreditCard</deb2:PayMethodType>
            <deb2:PaymentNote></deb2:PaymentNote>
            <deb2:RequestType>RealTimePayment</deb2:RequestType>
         </deb:request>
      </deb:GetPaymentToken>
   </soapenv:Body>
</soapenv:Envelope>
Sample Response
Code Block
languagexml
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
   <s:Header>
      <ActivityId CorrelationId="ebe8875e-91bb-4442-8c87-35cf30062cf7" xmlns="http://schemas.microsoft.com/2004/09/ServiceModel/Diagnostics">00000000-0000-0000-0000-000000000000</ActivityId>
   </s:Header>
   <s:Body>
      <GetPaymentTokenResponse xmlns="Debitsuccess.WebServices.WCF">
         <GetPaymentTokenResult xmlns:a="http://schemas.datacontract.org/2004/07/Debitsuccess.WebServices.Core.ResponseMessages" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
            <DateCreated xmlns="http://schemas.datacontract.org/2004/07/Debitsuccess.WebServices.Core">2020-09-22T08:35:44.5866836+12:00</DateCreated>
            <Id xmlns="http://schemas.datacontract.org/2004/07/Debitsuccess.WebServices.Core">3472ecbb-5845-4e87-92d8-96675e3167bd</Id>
            <ResponseNotes xmlns="http://schemas.datacontract.org/2004/07/Debitsuccess.WebServices.Core">
               <ResponseMessageNote>
                  <Code>00</Code>
                  <Note>Success</Note>
                  <NoteType>Info</NoteType>
               </ResponseMessageNote>
            </ResponseNotes>
            <Status xmlns="http://schemas.datacontract.org/2004/07/Debitsuccess.WebServices.Core">Succeed</Status>
            <a:AccountId>c48ae86c-5202-4d59-a580-a499ce3a561a</a:AccountId>
            <a:PaymentFormURL>https://OC-QA-ChaosRiders.debitsuccess.com/PayNow/T/fjDd9MhY</a:PaymentFormURL>
            <a:Token>fjDd9MhY</a:Token>
            <a:ValidTo>2020-09-22T08:45:44.977003+12:00</a:ValidTo>
            <a:WebhookToken>Tjn3yXOe</a:WebhookToken>
         </GetPaymentTokenResult>
      </GetPaymentTokenResponse>
   </s:Body>
</s:Envelope>

ProcessRealTimeCardPayment 

This The ProcessRealTimeCardPayment call can be used to process a real-time card payment for the customer by themselves.  card payment on behalf of the customer.  However, it is recommended to use GetPaymentToken to adhere to PCI Compliance.

It requires the following information: 

  1. Account Reference No. 

  2. UseStoredCardDetails 

  3. AccountHolder 

  4. CVC 

  5. CardNumber 

  6. CreditCardType 

  7. ExpiryDate 

  8. Amount Create one-off charge 

  9. createOneOffCharge- ​set to False so that the amount will be allocated to account balance. 

  10. Notes   

It gives you a few options such as: 

  1. Use a card already stored against the customer’s account. 

  2. Provide a new credit card number to make a payment 

  3. A separate one-off charge can be created for this payment if it has been successful 

  4. Define the amount that needs to be paid 

Info

We recommend that this message should be used in conjunction with you refer to the TransactionStatus returned by this call. In most cases, the status will be returned immediately either as Authorised or Declined. In the case of Processing status, use the message GetCardPaymentStatusForCustomerAccount for confirmation of payment. 

Sample Request

ExternalTransactionIdentifier should be unique for the business.

Code Block
languagexml
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:deb="Debitsuccess.WebServices.WCF" xmlns:deb1="http://schemas.datacontract.org/2004/07/Debitsuccess.WebServices.Core">
   <soapenv:Header/>
   <soapenv:Body>
      <deb:ProcessRealTimeCardPayment>
         <deb:request>
            <deb1:User>
               <deb1:Password>#QualIT</deb1:Password>
               <deb1:Username>QualIT</deb1:Username>
            </deb1:User>
            <deb1:AccountReferenceNo>DEA2884229</deb1:AccountReferenceNo>
            <deb1:ExternalTransactionIdentifier>DEMO88888163-1</deb1:ExternalTransactionIdentifier>
            <deb1:AccountHolder>Test</deb1:AccountHolder>
            <deb1:Amount>10</deb1:Amount>
            <deb1:CVC>123</deb1:CVC>
            <deb1:CardNumber>4111111111111111</deb1:CardNumber>
            <deb1:CreateOneOffCharge>false</deb1:CreateOneOffCharge>
            <deb1:CreditCardType>Visa</deb1:CreditCardType>
            <deb1:ExpiryDate>2020-12-01</deb1:ExpiryDate>
            <deb1:Notes>test</deb1:Notes>
            <deb1:UseStoredCreditCard>false</deb1:UseStoredCreditCard>
         </deb:request>
      </deb:ProcessRealTimeCardPayment>
   </soapenv:Body>
</soapenv:Envelope>
Sample Response
Code Block
languagexml
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
   <s:Header>
      <ActivityId CorrelationId="bf791ebf-970c-4e15-b17e-82f78dfa5e82" xmlns="http://schemas.microsoft.com/2004/09/ServiceModel/Diagnostics">00000000-0000-0000-0000-000000000000</ActivityId>
   </s:Header>
   <s:Body>
      <ProcessRealTimeCardPaymentResponse xmlns="Debitsuccess.WebServices.WCF">
         <ProcessRealTimeCardPaymentResult xmlns:a="http://schemas.datacontract.org/2004/07/Debitsuccess.WebServices.Core" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
            <a:DateCreated>2020-09-23T07:16:27.2812805+12:00</a:DateCreated>
            <a:Id>9d399b3a-9398-4161-b273-a5d632ab88c7</a:Id>
            <a:ResponseNotes>
               <a:ResponseMessageNote>
                  <a:Code>00</a:Code>
                  <a:Note>Success</a:Note>
                  <a:NoteType>Info</a:NoteType>
               </a:ResponseMessageNote>
            </a:ResponseNotes>
            <a:Status>Succeed</a:Status>
            <a:PayerAuthenticationRequest i:nil="true"/>
            <a:PayerAuthenticationUrl i:nil="true"/>
            <a:PaymentGatewayResponse i:nil="true"/>
            <a:TransactionStatus>Authorised</a:TransactionStatus>
         </ProcessRealTimeCardPaymentResult>
      </ProcessRealTimeCardPaymentResponse>
   </s:Body>
</s:Envelope>

Make an advance payment

This service needs to be enabled for the business so that their customers can avail the service. There is a maximum limit of $2000 for the advance payment amount. 

The customer will NOT be allowed to make a new real-time payment if:

  1. There is a billing due today

  2. The account is closed

The REST and SOAP API calls mentioned in the above sections can be used to make an advance payment.

Filter by label (Content by label)
showLabelsfalse
showSpacefalse
excerptTypesimple
cqllabel in ( "processrealtimecardpayment" , "getpaymenttoken" )

On this page:

Table of Contents