Telesales
Telesales is an alternative way of initiating the Affirm checkout.
Overview
The Telesales Checkout API is an efficient method for initiating the Affirm checkout process. This user-friendly feature enables telesales agents to kick-start the checkout process for customers, seamlessly integrating the experience with the in-store flow.
How it works
Customer flow
When a customer completes a checkout, it triggers a browser redirect along with a webhook request that contains the checkout_token for authorization.
Security
We prioritize privacy and security for our customers. Therefore, the Telesales API requires customers to apply using their own device. When an API request is submitted, Affirm sends a text message or email to the provided phone number or email address, containing a link to the customer’s online application.
Using Webhooks
For added efficiency and reliability, you can provide Affirm with a webhook address for server-to-server confirmation of the checkout_token after the customer confirms their loan. While Affirm continues to POST the token to the user_confirmation_url
, using a webhook can minimize the risk of client/browser errors and expedite the payment status update in your telesales system.
Integration Steps
Step 1: Add Affirm as a payment option in your Telesales flow
When customers choose to pay with Affirm over the phone, your telesales agents select Affirm as a payment option from your frontend or from the agent dashboard. For details, see the sample frontend template and instructions.
Step 2: Call the /store API to initiate Affirm Checkout Call
When a customer selects Affirm, send the order and customer details to Affirm’s /store API. This prompts Affirm to send the customer a text or email containing the link to finish their checkout with Affirm. See the example below: \
POST /api/v2/checkout/store HTTP/1.1
Host: sandbox.affirm.com
Content-Type: application/json
{
"merchant": {
"public_api_key": "PUBLIC_API_KEY",
"user_cancel_url": "https://www.cancelurl.com",
"user_confirmation_url": "https://www.confirmationurl.com",
"user_confirmation_url_action": "POST",
"name": "Telesales Affirm demo"
},
"billing":{
"name":{
"full": "John Doe"
},
"address":{
"line1": "325 Pacific Ave",
"city": "San Francisco",
"state": "CA",
"zipcode": "94112",
"country": "USA"
},
"phone_number": "4155552222",
"email": "[email protected]"
},
"metadata": {
"entity_name": "Vignan 1234",
"store_location": "Denver"
},
"order_id": "your_order_identifier_ABC_123",
"total": 5000
}
Testing
The Store API sends SMS text messages only in the Affirm Live environment. During Sandbox environment testing, you can use only email messages to receive the Checkout URL to complete your Affirm purchase.
In the response, you receive the redirect_url
that the customer was sent and an Affirm checkout_id
, which is used for authorization.
Step 3: Receive Order Confirmation via Webhook
After a user receives and confirms their loan, Affirm's server is notified of that event. The checkout_id
is POSTed back to your server at the webhook URL that you provide your Technical Account Manager.
Webhook Configuration
You must configure a webhook URL to complete the in-store integration. You can contact Affirm through your Account team or the support widget.
Call Affirm’s /transactions API and pass the checkout_id
to the transaction_id
parameter and authorize the order. The order must be authorized securely before saving the order or updating the order's status on the agent’s dashboard.
Step 4: Update the Agent Frontend
Update your agent frontend that the order has been authorized. At this step, the telesales agent can proceed with finalizing the order for the customer.
Step 5: Capture and Manage the Order
With the persistent id
received from authorization, you can initiate different transaction actions, such as capturing the order on fulfillment or issuing a refund depending on your internal processes.
Updated 28 days ago