Quickstart guide
This is a quick step-by-step guide on how to integrate the Swipelux Crypto Rails into your service. We'll take you through all of the necessary steps to have you transfer value in no time.
Prerequisites
- Terminal or command line: You'll need a terminal to run curl commands. Mac and Linux come with one pre-installed. Windows users can use PowerShell or Windows Subsystem for Linux (WSL).
Start building
Request access
Contact us at support@swipelux.com to request access to the platform.
We'll grant you a secret API key to use in your service. The API key should be kept secure and never exposed publicly. We recommend storing it as an environment variable or in a secure configuration management system.
Discover the API
You can explore our API endpoints by starting with creating your first customer.
Onboard your first customer
Once you've received your API key, you can start making requests to our API.
As the first step, you'll need to create a Customer object that represents a user in your service. The Customer object stores essential information about your users, including their:
- Personal details (name, email, phone number)
- Date of birth
- Residential address
- Identity documents for KYC verification
Here's how to create your first customer:
curl https://wallet.swipelux.com/v1/customers \
--request POST \
--header 'Content-Type: application/json' \
--header 'X-API-Key: YOUR_SECRET_API_KEY' \
--data '{
"firstName": "John",
"lastName": "Doe",
"email": "john.doe@example.com",
"phone": "+1234567890",
"birthDate": "1990-01-01",
"residentialAddress": {
"streetLine1": "123 Main St",
"city": "San Francisco",
"state": "CA",
"postalCode": "94101",
"country": "USA"
},
"identifyingInformation": [
{
"type": "drivers_license",
"issuingCountry": "USA",
"frontSideImage": ""
}
]
}'
You have to provide at least one identifying document for KYC checks. The document images (frontSideImage
and backSideImage
) should be provided as Base64-encoded strings using the Data URI scheme format (e.g. data:image/jpeg;base64,...
).
See Preparing identifying documents guide to see how to implement such encoding.
Upon customer creation, we will handle all KYC for the customer and return a status field that denotes the KYC status for the customer.
{
"id": "cus_cK69MttD5nAUAbud1B",
"firstName": "John",
"lastName": "Doe",
"email": "john.doe@example.com",
"phone": "+1234567890",
"status": "approved",
"metadata": null,
"createdAt": "2025-04-29T10:13:07.826Z",
"updatedAt": "2025-04-29T10:13:07.826Z"
}
Create customer wallets
⚠️ Important: Customers must have at least one wallet before creating any transfers. Create wallets for the chains you plan to use:
curl https://wallet.swipelux.com/v1/customers/cus_cK69MttD5nAUAbud1B/wallets \
--request POST \
--header 'Content-Type: application/json' \
--header 'X-API-Key: YOUR_SECRET_API_KEY' \
--data '{ "chains": ["base"] }'
Response:
{
"wallets": [
{
"id": "wlt_abc123def456",
"currency": "USDC",
"chain": "base"
}
]
}
Wallets return only their id
(identifier), not wallet addresses. This provides better security and abstraction.
Create the first transfer
Once you have a customer with an active KYC status, you can use Transfers API to initiate money movement from fiat to crypto or crypto to crypto. Here's one example that creates an on-ramp transfer from USD to the customer's own wallet.
curl https://wallet.swipelux.com/v1/transfers \
--request POST \
--header 'Content-Type: application/json' \
--header 'X-API-Key: YOUR_SECRET_API_KEY' \
--data '{
"from": {
"identifier": "cus_cK69MttD5nAUAbud1B",
"amount": "50",
"rail": "card",
"currency": "USD"
},
"to": {
"identifier": "cus_cK69MttD5nAUAbud1B"
}
}'
The amount
denotes the fiat amount to exchange from, i.e. your customer will pay 50 USD to get ~48 USDC (based on the exchange rate + additional fees). Choose from any of our supported payment rails.
The following request will return a response like this:
{
"id": "tr_nEZHWur1pBSAKY7NlV",
"from": {
"identifier": "cus_cK69MttD5nAUAbud1B",
"amount": "50",
"rail": "card",
"currency": "USD"
},
"to": {
"identifier": "cus_cK69MttD5nAUAbud1B"
},
"state": "awaiting_funds",
"url": "https://track.swipelux.com?specificSettings={...}",
"createdAt": "2025-04-29T10:54:08.724Z",
"updatedAt": "2025-04-29T10:54:08.724Z"
}
With this response, you can now redirect your users to the provided url
for them to complete their payment.
Check customer's balance
After the payment is completed, the customer will receive the funds in their own wallet. We automatically create and securely store wallets for all your customers, so you don't have to worry about wallet management.
curl https://wallet.swipelux.com/v1/customers/cus_cK69MttD5nAUAbud1B/balances \
--header 'Content-Type: application/json' \
--header 'X-API-Key: YOUR_SECRET_API_KEY'
{
"balance": 48.5
}
The balance represents the total networth across all wallets on all supported blockchain networks in USD.
Congratulations!
You've converted and moved your dollars from fiat to crypto. You can now reference subsequent guides to gain a deeper understanding of the various concepts we support.