Customer profiles
The customer profiles feature is designed to store and manage customer data and payment details, facilitating faster and more efficient checkout experiences for your customers. This document provides a comprehensive guide to using the customer profiles feature.
For a detailed, step-by-step guide on integrating customer profiles, refer to the customer profiles guide in our guides section.
Customer profiles are an optional feature which is not automatically available for all IXOPAY platform clients!
If you want to get access to all IXOPAY platform features you need to upgrade your plan. Please contact your Customer Success Manager or our sales team at [email protected] for more information.
Introduction
The customer profiles API enables you to store various types of customer data, including multiple payment instruments (for multiple connectors), in a unique customer profile.
Each customer profile is automatically assigned a profileGuid by the system, and a customerIdentification is provided by you.
Typically, using the customer profiles involves the following steps:
- Creation of a customer profile:
During a customer's first purchase, a new customer profile is created via a transaction call to the desired payment method's connector.
The customerIdentificationfield must be set for this transaction.
- Retrieving a customer profile:
When the customer returns for subsequent purchases, you can retrieve the profile information using the getProfilecall.
- Executing transactions using the customer profile:
A transaction is sent using the paymentTokenof the selected payment instrument in the customer's profile.
These steps are represented in the following graph:
Use cases
The main use cases for customer profiles are:
- Sharing payment instruments between multiple merchants: This allows for a seamless checkout experience across different merchants within the same ecosystem.
- Hosted payment pages with payment method selection: By using stored payment instruments, customers can have a simplified and efficient payment experience, reducing the friction during the checkout process.
Creating a customer profile
During a transaction request that includes the customerProfileData element, you can implicitly create a new customer profile.
This request should be sent to the appropriate connector for the selected payment method.
The customerIdentification field must be set during this transaction.
The system will automatically use any data provided in the customer element for the customer profile's data.
If the transaction is a Register type or a Debit/Preauthorize type with the withRegister flag set,
the payment instrument will be stored within the customer profile for later usage on subsequent charges.
{
  "merchantTransactionId": "your-unique-identifier",
  // in this example we use the tokenized credit card from payment.js
  "transactionToken": "$CC_TOKEN",
  "description": "Purchase description shown on credit card statement.",
  "amount": "9.99",
  "currency": "EUR",
  "customer": {
    "identification": "616c6578-2e73-6d69-7468-406578616d70",
    "billingCountry": "US",
    "birthDate": "1970-01-01",
    "email": "[email protected]"
  },
  "customerProfileData": {
    "customerIdentification": "616c6578-2e73-6d69-7468-406578616d70",
    // Mark this as the preferred one for the future
    "markAsPreferred": true
  }
}
Once the transaction is successful, the system will automatically add the customer's registered payment instrument to the customer profile.
Along with this, the response of the successful transaction will also include the customerProfileData.profileGuid.
You can use this profileGuid to retrieve the full customer profile information, including the stored payment instruments, using the getProfile call.
HTTP/1.1 200 OK
Content-Type: application/json
{
  "success": true,
  "uuid": "d94c0d72f3a36e21f16e",
  "purchaseId": "20251023-d94c0d72f3a36e21f16e",
  "returnType": "FINISHED",
  "paymentMethod": "Creditcard"
  "customerProfileData": {
    "profileGuid": "CP-1234-5678-9ABC-DEF0-1234-5678",
    "customerIdentification": "616c6578-2e73-6d69-7468-406578616d70",
    "paymentToken": "pt::b639e636df17af782602"
  }
}
Using customer profiles
Once a customer profile is set up, it can be used to retrieve profile information and to execute transactions.
Retrieving profile information
You can retrieve the customer profile using the getProfile call, which returns the stored payment instruments.
The profile can be requested either via the profileGuid or via the customerIdentification.
- Request by customer identification
- Request by profile GUID
- Response
POST /api/v3/customerProfiles/$API_KEY/getProfile
Host: gateway.ixopay.com
Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQK
Content-Type: application/json
{
  "customerIdentification": "616c6578-2e73-6d69-7468-406578616d70"
}
POST /api/v3/customerProfiles/$API_KEY/getProfile
Host: gateway.ixopay.com
Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQK
Content-Type: application/json
{
  "profileGuid": "CP-1234-5678-9ABC-DEF0-1234-5678"
}
{
  "success": true,
  "profileExists": "true",
  "profileGuid": "CP-1234-5678-9ABC-DEF0-1234-5678",
  "customerIdentification": "616c6578-2e73-6d69-7468-406578616d70",
  "preferredMethod": "Creditcard",
  "customer": {
    "identification": "616c6578-2e73-6d69-7468-406578616d70",
    "billingCountry": "US",
    "birthDate": "1970-01-01",
    "email": "[email protected]"
  },
  "paymentInstruments": [
    {
      "_TYPE": "card",
      "createdAt": "2030-10-24 10:28:13",
      "method": "card",
      "paymentData": {
        "_TYPE": "paymentData.card",
        "brand": "visa",
        "cardHolder": "Alex Smith",
        "expiryMonth": 10,
        "expiryYear": 2030,
        "firstSixDigits": "411111",
        "lastFourDigits": "1111"
      },
      "paymentToken": "pt::b639e636df17af782602",
      "isPreferred": true
    }
  ]
}
Executing transactions
For transactions, the paymentToken of the selected instrument must be included within the transactionToken element of the transaction request.
You can also designate a payment instrument as the preferred one by either using the markAsPreferred flag during the transaction that registers the instrument
or specifying the paymentToken as the preferredInstrument when calling the updateProfile endpoint.
{
  "merchantTransactionId": "your-unique-identifier",
  // this is the paymentToken from the customer profile
  "transactionToken": "pt::b639e636df17af782602",
  "description": "Purchase description shown on credit card statement.",
  "amount": "9.99",
  "currency": "EUR",
  "successUrl": "https://shop.example.org/checkout/success",
  "cancelUrl": "https://shop.example.org/checkout/cancelled",
  "errorUrl": "https://shop.example.org/checkout/error",
  "callbackUrl": "https://api.example.org/callback"
}
When dealing with transaction execution and customer profiles, it's essential to bear in mind the following key points:
- If you're a merchant using multiple connectors and storing payment instruments to customer profiles, be aware that each payment instrument is tied to a specific connector. Use a meta-connector when sending the transaction request. This guarantees that the transaction is appropriately routed to the correct connector linked to the stored payment instrument.
- IXOPAY platform doesn't conduct any authentication for accessing a customer profile.
Therefore, it's important for you to ensure that only authorized users can access a particular customer profile.
You should only transmit a profileGuidorcustomerIdentificationif the user is authorized.
- During transaction execution, you have the choice to use referenceUuidinstead ofpaymentTokenfrom the payment instrument passed throughtransactionToken. However, remember thatreferenceUuidcannot be shared among multiple merchants, whilepaymentTokencan be.
- Even when using a stored customer profile, a 3-D Secure SCA flow may still be required to maintain compliance with payment security protocols.
Updating profile information
It's possible to modify the customer profile data, including marking a particular payment instrument as preferred.
- To update a customer profile, you can use the updateProfileendpoint. This call allows you to change various elements of the profile, such as contact information or customer data.
- To mark a specific payment instrument as preferred:
- You can specify the paymentTokenof the instrument in thepreferredInstrumentfield when making theupdateProfilecall.
- Alternatively, you can set the markAsPreferredflag during the transaction that registers this instrument. Within this transaction, reference the customer profile by specifying either thecustomerIdentificationorprofileGuidfields in thecustomerProfileDataelement.
 
- You can specify the 
Remember to ensure that the appropriate meta-connector is used during these transactions. This guarantees that the transaction request is correctly forwarded to the correct connector tied to the stored payment instrument.
After updating, you can verify the changes by performing a getProfile call.
Deleting profile information
You have the ability to permanently delete customer profiles using the deleteProfile API call.
The profile can be specified by either the profileGuid or customerIdentification.
- Request by customer identification
- Request by profile GUID
- Response
{
  "customerIdentification": "616c6578-2e73-6d69-7468-406578616d70"
}
{
  "profileGuid": "CP-1234-5678-9ABC-DEF0-1234-5678"
}
{
  "success": true
}
Please exercise caution when deleting profiles as this action is irreversible. Once a profile is deleted, all related customer data and payment details stored within that profile will be lost.
Managing payment instruments
Customer profiles allow dynamic management of stored payment instruments. New payment instruments can be attached to a customer profile or detached from them when no longer needed.
A successful deregister API call on register/withRegister transactionUuid will,
if attached, automatically detach the payment instrument from the customer profile.
Attaching a payment instrument
A previously registered payment instrument can be attached to a customer profile without initiating a new transaction using the
attachPaymentInstrument  call.
- The referenced transaction must be a successful register/withRegister transaction.
- The connector of the referenced transaction must match the connector of the API key.
- The connector of the referenced transaction and API key must belong to the same customer profile container.
- The referenced transaction must not be deregistered.
- The referenced transaction must not be attached to a customer profile.
- Request by customer identification
- Request by profile GUID
- Request by customer identification and createProfileIfNotExists
- Response
POST /api/v3/customerProfiles/$API_KEY/attachPaymentInstrument
Host: gateway.ixopay.com
Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQK
Content-Type: application/json
{
  "transactionUuid": "d94c0d72f3a36e21f16e",
  "customerIdentification": "616c6578-2e73-6d69-7468-406578616d70"
}
POST /api/v3/customerProfiles/$API_KEY/attachPaymentInstrument
Host: gateway.ixopay.com
Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQK
Content-Type: application/json
{
  "transactionUuid": "d94c0d72f3a36e21f16e",
  "profileGuid": "CP-1234-5678-9ABC-DEF0-1234-5678",
}
POST /api/v3/customerProfiles/$API_KEY/attachPaymentInstrument
Host: gateway.ixopay.com
Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQK
Content-Type: application/json
{
  "transactionUuid": "d94c0d72f3a36e21f16e",
  "customerIdentification": "616c6578-2e73-6d69-7468-406578616d70",
  "createProfileIfNotExists": true
}
{
  "success": true,
  "message": "Payment instrument successfully attached to customer profile.",
  "profileGuid": "CP-1234-5678-9ABC-DEF0-1234-5678",
  "paymentToken": "pt::b639e636df17af782602"
}
Field descriptions
| Field | Type | Description | 
|---|---|---|
| transactionUuid | required string | If provided, attaches the payment instrument to the specified existing profile. | 
| profileGuid | optional string? | If provided, attaches the payment instrument to the specified existing profile. | 
| customerIdentification | optional string? | If provided, the system will search for an existing profile. If none exists and createProfileIfNotExists is true, a new profile will be created. Payment instrument will be attached to the newly created profile. | 
| createProfileIfNotExists | optional boolean? | Flag to indicate whether to create a new profile if customerIdentification doesn't match any existing one. | 
Either profileGuid or customerIdentification must be provided.
If both parameters are omitted, the request will fail.
Detaching a payment instrument
Detaching removes a payment instrument from a customer profile, rendering it unusable for future transactions associated with that profile.
The referenced transaction must be attached to the customer profile provided in the request.
- Request by customer identification
- Request by profile GUID
- Response
POST /api/v3/customerProfiles/$API_KEY/detachPaymentInstrument
Host: gateway.ixopay.com
Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQK
Content-Type: application/json
{
  "transactionUuid": "d94c0d72f3a36e21f16e",
  "customerIdentification": "616c6578-2e73-6d69-7468-406578616d70",
}
POST /api/v3/customerProfiles/$API_KEY/detachPaymentInstrument
Host: gateway.ixopay.com
Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQK
Content-Type: application/json
{
  "transactionUuid": "d94c0d72f3a36e21f16e",
  "profileGuid": "CP-1234-5678-9ABC-DEF0-1234-5678"
}
{
  "success": true,
  "message": "Payment instrument successfully detached from customer profile.",
  "profileGuid": "CP-1234-5678-9ABC-DEF0-1234-5678"
}
Field descriptions
| Field | Type | Description | 
|---|---|---|
| transactionUuid | required string | UUID of the successful transaction that registered the payment instrument.. | 
| profileGuid | optional string? | If provided, customer profile from which to detach the payment instrument. | 
| customerIdentification | optional string? | If provided, customer identification profile from which to detach the payment instrument. | 
Either profileGuid or customerIdentification must be provided.
If both parameters are omitted, the request will fail.
A successful detachPaymentInstrument API call will
not automatically deregister the payment instrument.
This has to be done separately with a deregister transaction.
Customer profile containers
In the customer profiles feature, the customer profile containers play a central role. Initially, a tenant doesn't have a customer profile container; it needs to be created first. These containers serve as storage for the customer profiles.
One of the most powerful attributes of customer profile containers is their ability to be shared across sub-tenants. This sharing capability enables multiple merchants within the same ecosystem to access shared customer profiles, delivering a seamless and consistent shopping experience for the customers.
The ability to share customer profiles across multiple merchants is a significant advantage of the customer profiles feature. The primary benefit is that customers only need to enter and store their payment information once with a single merchant. Then, when they shop with a different merchant within the same ecosystem that shares customer profiles, they can leverage their stored profile, eliminating the need to re-enter their payment information.
It's important to note that each customerIdentification must be unique per customer profile container.
Furthermore, a tenant can opt to disable customer profile containers for sub-tenants if needed.
Upon its creation, a customer profile container is not automatically associated with any specific function. There are two main methods to utilize a customer profile container:
- Implement a global setting that assigns the customer profile container to all connectors of a given tenant. This setting is specific to a tenant and is not passed down to sub-tenants.
- Associate the customer profile container with each individual connector that should employ the customer profiles.
false