Storing cardholder information using E-xact’s hosted payment page (HCO) and API

Created by Richard Moore, Modified on Thu, 15 Aug, 2024 at 2:52 PM by Richard Moore


Storing cardholder information using E-xact’s hosted payment page (HCO)


Once you have a payment page configured on your account (instructions found here: https://hostedcheckout.zendesk.com/hc/en-us/articles/114094066114) the next step is to use it to store credit card data; this data can be used to make subsequent tagged, or recurring transactions.


The two x_type transactions that can be used to create Recurring Seed transactions are AUTH_TOKEN or PURCHASE_TOKEN: 



  • AUTH_TOKEN is a Pre-authorization transaction that returns a transaction tag which can be used by the API to perform additional transactions for that cardholder. 


  • PURCHASE_TOKEN will capture funds and return a transaction tag which can be used by the API to perform additional transactions for that cardholder. 


 
Here is an example of an AUTH_TOKEN transaction made using the Hosted Payment Page (HCO):



<form action="https://rpm.demo.e-xact.com/payment" method="post">


  <input name="x_login" value="WSP-RICHA-iZIoDgA7aw" type="hidden">


  <input name="x_type" value="AUTH_TOKEN" type="hidden">


  <input name="x_test_request" value="TRUE" type="hidden">


  <input name="x_amount" value="0.01" type="hidden">


  <input name="x_fp_sequence" value="12345" type="hidden">


  <input name="x_fp_timestamp" value="1723757397" type="hidden">


  <input name="x_po_num" value="PO12345" type="hidden">


  <input name="x_invoice_num" value="Invoice100" type="hidden">


  <input name="x_fp_hash" value="5d23b44f27cf62bde8ac60da612d4994671310aa" type="hidden">


  <input name="x_show_form" value="PAYMENT_FORM" type="hidden">


  <input value="Checkout" type="submit">


</form>





Note: This example shows the endpoint to E-xact’s demo environment. If you are making a transaction in the production environment you must use ‘https://checkout.e-xact.com/payment’.

 


Once this transaction has been executed—if the transaction was approved—the response data will contain both an Authorization Number, and a Tag Number. These two values are required in
order to make the subsequent Tagged Transactions using the API. See the example of a raw transaction response, below. We have emboldened the Authorization Number (x_auth_code), and the Tag Number (x_trans_id):

           x_response_code=1&amp;x_response_subcode=S&amp;x_response_reason_code=1&amp;x_response_reason_text=Transaction+has+been+approved&amp;x_auth_code=ET187443&amp;x_avs_code=&amp;x_trans_id=2151376984&amp;x_invoice_num=Invoice100&amp;x_description=&amp;x_amount=0.01&amp;x_method=&amp;x_type=AUTH_TOKEN&amp;x_cust_id=&amp;x_first_name=&amp;x_last_name=&amp;x_company=&amp;x_address=&amp;x_city=&amp;x_state=&amp;x_zip=&amp;x_country=&amp;x_phone=&amp;x_fax=&amp;x_email=&amp;x_ship_to_first_name=&amp;x_ship_to_last_name=&amp;x_ship_to_company=&amp;x_ship_to_address=&amp;x_ship_to_city=&amp;x_ship_to_state=&amp;x_ship_to_zip=&amp;x_ship_to_country=&amp;x_tax=&amp;x_duty=&amp;x_freight=&amp;x_tax_exempt=&amp;x_po_num=PO12345&amp;x_reference_3=&amp;x_cvv2_resp_code=M&amp;x_cavv_response=1&amp;exact_ctr=%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D+TRANSACTION+RECORD+%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%0ARichard%27s+DEMO%0A123+test+st%0Atestville%2C+AB+t2a0l3%0ACanada%0A%0A%0ATYPE%3A+Pre-Authorization%0A%0AACCT%3A+Visa++%24+0.01+CAD%0A%0ACARD+NUMBER+%3A+%23%23%23%23%23%23%23%23%23%23%23%234242%0ADATE%2FTIME+++%3A+15+Aug+24+14%3A49%3A14%0AREFERENCE+%23+%3A+001+000108+M%0AAUTHOR.+%23+++%3A+ET187443%0ATRANS.+REF.+%3A+Invoice100%0A%0A++++Approved+-+Thank+You+000%0A%0A++++%0A%0A%0APlease+retain+this+copy+for+your+records.%0A%0ACardholder+will+pay+above+amount+to+card%0Aissuer+pursuant+to+cardholder+agreement.%0A%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D&amp;exact_issname=&amp;exact_issconf=&amp;exact_wsp_version=1.7&amp;x_SHA1_Hash=12fd20bd37a0d0ac3967588bd6829c1747d8e2cb&amp;x_login=WSP-RICHA-iZIoDgA7aw&amp;x_test_request=TRUE&amp;x_fp_sequence=12345&amp;x_fp_timestamp=1723757723&amp;x_show_form=PAYMENT_FORM&amp;Transaction_Type=40&amp;DollarAmount=0.01&amp;SurchargeAmount=0&amp;Card_Number=%23%23%23%23%23%23%23%23%23%23%23%234242&amp;Transaction_Tag=2151376984&amp;Authorization_Num=ET187443&amp;Expiry_Date=1028&amp;CardHoldersName=Exact+Test&amp;CVD_Presence_Ind=0&amp;ZipCode=&amp;Tax1Amount=&amp;Tax1Number=&amp;Tax2Amount=&amp;Tax2Number=&amp;Secure_AuthRequired=0&amp;Secure_AuthResult=0&amp;Ecommerce_Flag=0&amp;XID=&amp;CAVV_Algorithm=0&amp;Reference_No=Invoice100&amp;Customer_Ref=PO12345&amp;Reference_3=&amp;Language=0&amp;Client_IP=&amp;Client_Email=&amp;Transaction_Error=false&amp;Transaction_Approved=YES&amp;EXact_Resp_Code=00&amp;EXact_Message=Transaction+Normal&amp;Bank_Resp_Code=000&amp;Bank_Message=Approved&amp;Bank_Resp_Code_2=&amp;SequenceNo=000108&amp;AVS=&amp;CVV2=M&amp;Retrieval_Ref_No=0793723&amp;CAVV_Response=1&amp;MerchantName=Richard%27s+DEMO&amp;MerchantAddress=123+test+st&amp;MerchantCity=testville&amp;MerchantProvince=Alberta&amp;MerchantCountry=Canada&amp;MerchantPostal=t2a0l3&amp;TransactionCardType=VISA

__________________________________________________

Using the API and Transaction Tags to make Tagged Transactions

 

Once you have the Authorization and Tag Numbers (whether they were created from a previous API or HCO transaction) you are ready to make a Tagged Transaction. 

There are three types of Tagged Transactions: Tagged Purchase (30), Tagged Pre-Authorization (31), and Tagged Completion (32). In the majority of situations, E-xact recommends the use of a Tagged Purchase (30) to make subsequent charges from a tokenized card. Here is an example of a Tagged Purchase using the API, using the Tag that we created from our original transaction:
 




purchase = {


    transaction_type: '30', 


    amount: '1.00', 


    transaction_tag: '984166872',


    authorization_num: 'ET161625'


 }



There you have it, from start to finish, a walkthrough of how to create a Recurring Seed transaction through the payment page and follow up with a Tagged Purchase transaction made through the API.

Note: you can create a Recurring Seed Transaction without the payment page. From the API, a Recurring Seed Pre-Authorization is Transaction Type ‘40’, and a Recurring Seed Purchase is Transaction Type ‘41’. The hosted payment page ensures that you, as the merchant, do not handle sensitive credit card data; if this is not a concern to your business then using the API to store the data is an alternative.

Further HCO and API information, including additional request and response fields, can be found at the following links:

HCO Integration Guide: https://support.exactpay.com/support/solutions/articles/150000065320-hosted-checkout-integration-manual

API Integration Guide: https://support.exactpay.com/support/solutions/articles/150000065331-transaction-processing-api-reference-guide


 


 

Was this article helpful?

That’s Great!

Thank you for your feedback

Sorry! We couldn't be helpful

Thank you for your feedback

Let us know how can we improve this article!

Select at least one of the reasons
CAPTCHA verification is required.

Feedback sent

We appreciate your effort and will try to fix the article