Swipelux

Quickstart guide

This is a quick step-by-step guide on how to integrate the Swipelux Wallet Infrastructure into your service. We'll take you through all of the necessary steps to have you to accept payments in no time.

Prerequisites

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.

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.

Response body
{
  "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 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 USDC using the debit/credit card payment method.

curl https://wallet.swipelux.com/v1/transfers \
  --request POST \
  --header 'Content-Type: application/json' \
  --header 'X-API-Key: YOUR_SECRET_API_KEY' \
  --data '{
    "onBehalfOf": "cus_cK69MttD5nAUAbud1B",
    "amount": "50.0",
    "source": {
      "paymentRail": "card",
      "currency": "USD"
    },
    "destination": {
      "currency": "USDC"
    }
  }'

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).

The following request will return a response like this:

Response body
{
  "id": "tr_nEZHWur1pBSAKY7NlV",
  "onBehalfOf": "cus_cK69MttD5nAUAbud1B",
  "state": "awaiting_funds",
  "amount": "50",
  "source": {
    "currency": "USD",
    "paymentRail": "card"
  },
  "destination": {
    "currency": "USDC"
  },
  "sourceInstructions": {
    "signedUrl": "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 signedUrl for them to complete your order.

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'
Response body
{
  "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.

On this page