close
    Contents

    Interac Online

    Interac Online is a transaction method available to Canadian merchants only. It allows customers to authenticate direct debits without sharing their debit card details with the merchant. An Interac payment flow is similar to the 3D Secure payment flow. It has three steps:

    1. Submit an initial Interac payment request to us. You will receive an Interac response with redirect code.
    2. Redirect the customer to the bank portal using redirect code received from initial request. The customer logs in to approve the payment and the bank redirects the customer back to your site with success/failure information.
    3. Submit final payment request to us.

    In addition to this guide feel free to check out our Payment APIs Demo implementation on GitHub.

    APIs

    • Initial request: POST https://api.na.bambora.com/v1/payments
    • Final request: POST https://api.na.bambora.com/v1/payments/{id}/continue

    Step 1: Submit initial request

    Send a request to our Payments API to initiate the Interac process. The response from this request will provide you with the redirect HTML code that you render to the customer in order to redirect them to the banking portal.

    POST /v1/payments
    
    curl https://api.na.bambora.com/v1/payments
    -H "Authorization: Passcode MzAwMjAwNTc4OjRCYU..."
    -H "Content-Type: application/json"
    -d '{
          "order_number":"MyOrderId-01234",
          "amount":100.00,
          "payment_method":"interac"     
        }'
    

    Response

    // Response object (JSON)
    {
      merchant_data (string, max length 32): ,
      contents (string): ,
      links (JSON):
    }
    

    Before returning the response to your users HTML client, you will need to save the merchant_data string in the users session. This value can be used as the {id} value when creating your 'continue' endpoint URL for the final request in step 3.

    The response from the Payments API has HTML in the contents field. You should return this HTML to the user, and your response should include the "Referrer-Policy" header (see Browser Referrer Policy below). This HTML "redirects" the user to the Interac login page, by causing their browser to submit a form. On the Interac login page, the customer will log onto their bank account and approve the payment. An approved or declined payment will forward the customer back to the Funded or Non-funded URLs (respectively) on your website.

    <!-- Sample URL Decoded Response -->
    
    <HTML>
    <HEAD></HEAD>
    <BODY>
    <FORM action="https://iOnlinegateway.asp" method=POST id=frmIOnline name=frmIOnline>
    <input type="hidden" name="IDEBIT_MERCHNUM" value="12345678911">
    <input type="hidden" name="IDEBIT_AMOUNT" value="10000">
    <input type="hidden" name="IDEBIT_TERMID" value="12345678">
    <input type="hidden" name="IDEBIT_CURRENCY" value="CAD">
    <input type="hidden" name="IDEBIT_INVOICE" value="">
    <input type="hidden" name="IDEBIT_MERCHDATA" value="2F86D946-5531-4495-9D82D7E6D83BA93">
    <input type="hidden" name="IDEBIT_FUNDEDURL" value="http://www.myCompany.asp?funded=1">
    <input type="hidden" name="IDEBIT_NOTFUNDEDURL" value="http.www.myCompany.asp?funded=0">
    <input type="hidden" name="merchant_name" value="Test Company">
    <input type="hidden" name="referHost" value="http://www.myCompany.asp">
    <input type="hidden" name="referHost2" value="">
    <input type="hidden" name="referHost3" value="www.myCompany.asp">
    <input type="hidden" name="IDEBIT_MERCHLANG" value="en">
    <input type="hidden" name="IDEBIT_VERSION" value="1">
    </FORM>
    <SCRIPT language="JavaScript">document.frmIOnline.submit();</SCRIPT>
    </BODY>
    </HTML>
    

    Browser Referrer Policy

    When you redirect the customer to Interac, Interac verifies that the redirect was from a trusted source. It does this by comparing the HTTP "Referer" header passed by the customer's browser to the "referring URL" configured on your Interac account. This "referring URL" is the full URL of the page on your server that is redirecting to Interac. You are asked to provide it during the setup of your Interac Online payment method with Bambora. If the "Referer" header does not match this URL exactly, your customer will be declined from continuing with their payment.

    Major browsers have been working towards changing their default Referrer Policy from "no-referrer-when-downgrade" to "strict-origin-when-cross-origin" to improve default security. With this new default, if your referring URL is for instance "https://www.my-company.com/pages/ionline", the "Referer" header would only be "https://www.my-company.com", and therefore not match the referring URL. In order to have the browser include the full URL in the "Referer" header, you must set the "Referrer-Policy" response header to a value of "no-referrer-when-downgrade". This ensures that your Interac Online integration properly supports referring host validation.

    To validate that your integration is correctly setting the Referrer Policy and passing the correct URL in the "Referer" header, you can use your browser's network tools to view the values being passed in the redirection to Interac.

    Step 2: Redirect request

    If the transaction is cancelled or declined at any point, the bank forwards a response to the merchant’s Non-funded URL. Otherwise, the bank response is forwarded to the merchant’s Funded URL. The Funded and Non-funded URLs are values the merchant must provide to us before account activation. These values are stored internally by us. Contact our customer support team to set these URLs.

    When you receive a redirect back from the bank site on your Funded URL you must gather the idebit_ variables they pass to use in the 'interac_response' objects properties shown for the final request in step 3.

    InteracResponse {
      funded (string, max length 20): ,
      idebit_track2 (string, max length 256): ,
      idebit_isslang (string, max length 2): ,
      idebit_version (number, max length 1): ,
      idebit_issconf (string, max length 32): ,
      idebit_issname (string, max length 32): ,
      idebit_amount (number, max length 9): ,
      idebit_invoice (string, max length 20):
    }
    

    Step 3: Submit final request

    The final step is to submit a request to our continue endpoint to complete the transaction. The {id} in the URL should be the merchant_data from the first response (Step 2).

    Note: The idebit_amount is in cents.

    POST /v1/payments/{id}/continue
    Content-Type: application/json
    
    curl https://api.na.bambora.com/v1/payments/{id}/continue
    -H "Authorization: Passcode MzAwMjAwNTc4OjRCYU..."
    -H "Content-Type: application/json"
    -d '{
          "payment_method": "interac",
          "interac_response": {
            "idebit_track2": "<string, max length 256)" ,
            "idebit_isslang": "<string, max length 2)" ,
            "idebit_version": "<number, max length 1)" ,
            "idebit_issconf": "<string, max length 32)" ,
            "idebit_issname": "<string, max length 32)" ,
            "idebit_amount": "<number, max length 9)" ,
            "idebit_invoice": "<string, max length 20)"
          }
        }'
    

    Final Response

    PaymentResponse {
      payment_method (string): ,
      id (number, max length 9): ,
      approved (number, max length 1): ,
      message_id (number, max length 3): ,
      message (string, max length 32): ,
      auth_code (string, max length 32): ,
      created (date): ,
      order_number (string, max length 30): ,
      type (string, max length 16): ,
      interac_online (json):
      {
        idebit_issconf (string, max length 32): ,
        idebit_issname (string, max length 32): 
      } ,
      links (json):
    }