Integration Guide
Step 5: Integration Use-Cases
CoinPayments offers different integration options to suit various business needs, whether you're processing crypto payments for products, services, or other use cases. With these flexible solutions, you can choose from:
- Integrated Checkout Flow: A pre-built, ready-to-use payment flow designed to handle the checkout process with minimal setup. Ideal for a range of integrations including invoicing, payment buttons, e-commerce plugins, and API-generated invoices.
- White-labeled Checkout Flow: A customizable solution available through the CoinPayments API, allowing you to deliver a fully branded checkout experience with their own branding.
In this guide, we'll explore these use cases in detail, including:
- How to implement the Integrated Checkout Flow for different integration types.
- How to create a White-labeled Checkout Flow for a personalized customer experience.
By the end of this guide, you'll have a clear understanding of the capabilities of each integration type and how to apply them effectively to your business operations.
Integrated Checkout Flow
The Integrated Checkout Flow is a pre-built solution offered by CoinPayments, providing a seamless and efficient payment process for businesses. This flow requires minimal setup and is available across a variety of integration types.
Supported Integration Types
- Invoicing Tool: Generate invoices for one-time or recurring payments.
- Pre-generated Payment Buttons: Allow quick payments for fixed-price items or services.
- E-Commerce Plugins: Use for invoicing in supported online store platforms. -API-Generated Invoices and Payment Buttons: Automate and customize the checkout process using API integrations.
Checkout for Existing Solutions
Checkout for Invoicing Tool, Pre-generated Payment Buttons, and e-Commerce Plugins
Invoice or Payment Button Generation
Payment Generation
- When buyers receive an invoice generated via the CoinPayments Invoicing UI or e-commerce plugin and click on the "Pay Using CoinPayments" button, they are redirected to the CoinPayments integrated checkout flow.
- Also, clicking a pre-generated payment button redirects your client to the CoinPayments integrated checkout flow.
Email Entry for Refunds
The buyer provides their email address for potential refunds and clicks Continue.

Payment Currency Selection
- At the checkout step, buyers choose from multiple cryptocurrency options, each with accurate conversion rates for the order amount, giving the flexibility to pay with the currency of their choice.

- CoinPayments locks crypto rates for one hour, ensuring price stability during the payment process.

Payment Completion
- Buyers can make payments by scanning the provided QR code or copying the temporary payment address.
- Email notifications update you and the buyer on the payment status, including confirmation.

Transaction Monitoring
- Check the Transactions section to track the payment status, even before full blockchain confirmation.

- You can also check more detailed information about the invoice/payment by clicking on the transaction.

Checkout for API-Generated Invoices
The CoinPayments API offers powerful tools for businesses to automate payment processing. Using API-generated invoices and payment buttons, you can integrate seamless checkout flows tailored to specific use cases, such as subscription models or online purchases.
Use Case: Subscription Payments with API-Generated InvoicesLet us consider a subscription use case, where you have a platform that provides services with a subscription payment model. Every month you need to send out invoices to your users with the reminder to pay for the subscription and ability to collect this payment in crypto.
CoinPayments API can automate the invoicing process. Here's how it works:
Generate Invoice
Use the createInvoice endpoint to create an invoice with the following details:
- Services for which the invoice is issued.
- Customer details (e.g., name, payment address, and email, if available).
- Cost of services.
Exclude Certain Attributes
When creating the invoice, ensure that the payment object together with paymentCurrency and refundEmail attributes are excluded unless whitelabeling is required.
"payment": { 
	"paymentCurrency": "4:0xdac17f958d2ee523a2206206994597c13d831ec7" 
	"refundEmail": "jane_doe@hotmail.com" 
}Receive Invoice Details
As a response to the createInvoice endpoint, you will receive:
- An Invoice ID to check status updates.
- A link to the invoice document with the active Pay Using CoinPayments button, directing customers to the payment checkout flow.

Share Invoice
- Share the invoice link with the customer, or if email delivery is enabled, they will receive the link automatically via email.
- Additionally, as a response to the createInvoice endpoint, you will receive a direct link to the checkout flow, which you can share with customers if you prefer not to send the full invoice document.

Track Payment Status
Use the Transactions section to monitor the invoice status (transaction type: "Payment").

If webhooks are enabled, receive real-time notifications for status changes such as:
- invoiceCreated
- invoicePending
- invoicePaid
- invoiceCompleted
- invoiceCancelled
- invoiceTimedOut
- paymentCreated
- paymentTimedOut
Checkout for API-Generated Payment Buttons
Let us consider a couple of other cases:
a. Imagine you run an online shop and want to accept crypto payments for your goods or services. To make the process quick and seamless for your clients, you can add a Buy-Now button next to each item. Using the CoinPayments API, you can enable your clients to complete their purchases with just a few clicks.
b. Imagine you run a charity organization that collects online donations for a set amount. Alternatively, you might be offering one-time services at a fixed price and want to give your customers a simple way to make payments.
Here's how the process works:
Generate Payment Button
- Use the createBuyNowButtonendpoint to generate an HTML code snippet.
- When creating the button, specify the product or service details, including the amount and cost.
Use-Case A
- For use-case a. set the button type to "permanent" - this will allow reuse of the same button by different customers multiple times. Each button click generates a new invoice under the hood.
{ 
	... 
	"type": "permanent" 
	... 
}Use-Case B
- For use-case b. set the button type to “singleInvoice“ - this will allow to attribute a single invoice created under the hood to the deal. If the buyer tries to pay and fails for the first time, when re-clicking the button, the same invoice will be pulled out to allow the buyer to complete the payment.
{
	...
	"type": "singleInvoice"
	...
}Add Button to Website
Copy and paste the generated HTML code into your website where you want the Buy-Now button to appear.

When open via browser, the code above will display a button

Payment Flow
When clients click the Buy Now button, they are redirected to the CoinPayments checkout page to complete the transaction.
Track Payment Status
The payment will be logged in the Transactions section of your CoinPayments dashboard with the type marked as "Payment".

If webhooks are set up, you'll receive notifications for each payment status update (e.g., invoiceCreated, invoicePending, invoicePaid, invoiceCompleted, etc.).
White-Labeled Checkout
The Whitelabeled Checkout Flow allows you to fully customize the payment process using the CoinPayments API, enabling you to offer a branded experience on your platform. This method is ideal for businesses that want to keep the checkout process entirely within their own ecosystem.
Custom Checkout for Online Stores
For an online shop accepting cryptocurrency payments, the White-labeled Checkout Flow ensures that your customers can browse, shop, and pay without leaving your branded environment. Here's how it works:
Customer Initiates Checkout
- Your customer selects products/services, adds them to the cart, and proceeds to checkout.
- At checkout, they provide details like name, shipping method, payment address, and email, then click Pay.
Generate Invoice
Use the createInvoice and include the customer's email as the RefundEmail for handling overpayments or refunds:
{ 
	... 
	"Payment": { 
		"RefundEmail": "jane_doe@hotmail.com" 
	}
	...
} Receive Invoice Details
The createInvoice response includes:
- invoiceIdto get payment address and check payment status
- A list of supported payment currencies, amounts, and fees.
- A payment expiration timestamp.
Generate Payment Address
When the customer selects their payment currency, use the getPaymentAddressByCurrency endpoint to generate a payment address for the selected currency.
Provide Payment Details
As a result, buyer is presented with the following data:
- Selected payment currency.
- Payment address.
- Total cryptocurrency amount to deposit.
- Payment timer for completing the transaction.
Optional: Pre-Define Payment Currency
If you want to accept payments in a specific cryptocurrency, provide id of the PaymentCurrency in the Payment entity of the createInvoice request and trigger getPaymentAddressByCurrency endpoint together with createInvoice endpoint:
{ 
	... 
	"Payment": { 
		"RefundEmail": "jane_doe@hotmail.com", 
		"PaymentCurrency": "4:0xdac17f958d2ee523a2206206994597c13d831ec7" 
	} 
	...
}The indication of the cryptocurrency id will trigger creation of the invoice together with payment and HotWallet (address for buyer). In the createInvoice response you will receive a link to the CoinPayments checkout app:
{
	"invoices": [ 
        { 
            ...
            "checkoutLink": "https://checkout.coinpayments.net/checkout/?invoice-id=56284ebf-8daf-4eed-a3a4-00a3ba255788", 
    		... 
    	} 
  	] 
} With this link buyer will get directly to the checkout page with the payment address, QR code and timer for payment.

Monitor Payment Status
Use the getPaymentStatus endpoint to track:
- Payment status.
- Amount detected and confirmed on the blockchain.
- Amount detected but not yet confirmed.
Alternatively, if webhooks are set up, CoinPayments will notify you of status changes (e.g., invoiceCreated, invoicePending, invoicePaid, invoiceCompleted, etc.).
Commercial Deposits and Balances
Commercial deposits allow merchants to receive funds for services such as subscription payments or gambling accounts. With CoinPayments API, merchants can manage and sweep these deposits using various types of addresses tailored to their specific needs.
Types of Commercial Addresses
CoinPayments provides flexibility in managing commercial funds through three types of addresses: UTXO Addresses, Temporary Account-Based Addresses, and Permanent Account-Based Addresses. Each address type caters to different business needs, offering options for fund management, fee optimization, and customer-specific deposits.
UTXO Addresses
UTXO (Unspent Transaction Output) addresses are designed for accumulating funds and minimizing network fees by allowing bulk withdrawals. They are particularly beneficial for merchants who process large volumes of transactions or manage multiple customer accounts.
- UTXO addresses can be permanently assigned to a merchant or specific customer for ongoing use, ensuring seamless fund management without additional reassignment.
- By consolidating transactions into bulk withdrawals, UTXO addresses significantly reduce service and network fees.
- UTXO addresses created through the API are considered permanent addresses, offering long-term flexibility for businesses managing commercial deposits.
Temporary Account-Based Addresses
A temporary address is an address that is not specifically assigned to any user of the CoinPayments platform. Such address exists in CoinPayments pool of addresses and is temporarily used for a particular commercial deposit.
- CoinPayments randomly issues temporary addresses when a merchant requests a deposit in a particular currency.
- These addresses remain assigned to the merchant for a set period set by CoinPayments before returning to the pool. The lease period is automatically renewed if a deposit is made within this timeframe.
- Funds deposited to temporary addresses are automatically consolidated into the merchant's corresponding wallet balance.
- Since these addresses are not permanently assigned, customers must verify the correct address before sending funds to merchants.
- CoinPayments does not charge fees for consolidating funds from temporary addresses into the wallet balance.
Permanent Account-Based Addresses
The merchant can decide to use permanent account-based addresses if it is important to manage funds/balances deposited by their customers individually.
- Permanent addresses are assigned to specific clients indefinitely, enabling merchants to track individual deposits and balances more efficiently.
- Balances are always swept in full to minimize the chances of small, unwithdrawable amounts being left due to network fees.
The tradeoff of the permanent address vs. temporary address design is fees. To be able to use the funds from permanent addresses, merchant must consolidate addresses balances at some wallet balance of the currency. For this each new commercial address created within the API wallet must be activated.
- A one-time activation fee is charged during the first withdrawal to consolidate funds from the address to the primary wallet.
- Subsequent withdrawals incur standard network (transfer) fees.
- Although the initial activation fee may result in higher upfront costs, repeated withdrawals from consolidated balances are more economical compared to withdrawals from temporary addresses.
- Merchants can decide when to sweep funds from permanent addresses to their wallet balance.
- Consolidation ensures that funds are available for further use while optimizing costs.
Simplify Commercial Wallet Top-up
A common case for merchants is to use wallets and addresses created via API for receiving payments from customers, e.g. top-up a subscription or casino account. You can simplify the deposit process for the customer by incorporating transaction details such as deposit amount, currency, and address into a QR code. This will decrease the possibility of an error when sending funds.
Below is an example script you can use to generate a QR code for deposits:
<div id="canvas"></div>
<script type="text/javascript" src="https://unpkg.com/qr-code-styling@1.5.0/lib/qr-code-styling.js"></script>
<script type="text/javascript">
    const generateQRData = (currency, address, tag, amount) => {
        switch (currency.name) {
            case 'Bitcurrency SV':
                return `bitcurrency:${address}?sv&amount=${amount}`;
            case 'Tether USD (Omni)':
                return `bitcurrency:${address}?amount=${amount}&req-asset=${currency.id}`;
            case 'BinanceCoin':
                return `bnb:${address}?sv&amount=${amount}&req-asset=${currency.id}`;
            case 'Tether USD (ERC20)':
                return `ethereum:${address}?value=${amount}&req-asset=${currency.id.slice(currency.id.indexOf(':') + 1)}`;
            case 'Tether USD (TRC20)':
                return `tron:${address}?value=${amount}&req-asset=${currency.id.slice(currency.id.indexOf(':') + 1)}`;
            default:
                return `${currency?.name?.toLowerCase().replace(/ /g, '')}:${address}?amount=${amount}${tag ? `&tag=${tag}` : ''}`;
        }
    };
 
    const color = "#2A5ED5";
    const corner = "#000000";
    const margin = 5;
 
    const qrCode = new QRCodeStyling({
        width: 200,
        height: 200,
        dotsOptions: {
            color: color,
            type: "square"
        },
        backgroundOptions: {
            color: "transparent",
            gradient: null
        },
        cornersSquareOptions: {
            type: "square",
            color: corner
        },
        cornersDotOptions: {
            type: "square",
            color: corner
        },
        imageOptions: {
            crossOrigin: "anonymous",
            imageSize: 0.5,
            margin: margin
        }
    });
 
    qrCode.append(document.querySelector('#canvas'));
    qrCode.update({
        data: generateQRData(currency, address, tag, amount)
    });
</script>Receive Commercial Deposits and Sweep Funds
From UTXO Addresses
UTXO (Unspent Transaction Output) addresses are highly efficient for managing commercial deposits due to their ability to accumulate funds and minimize network fees. Below is the process for setting up and using UTXO addresses for commercial deposits.
Create API Wallet
- Use the createWalletAPI endpoint to create an API wallet for the currency you want to accept or use an existing wallet.
- Ensure that the usePermanentAddressesattribute is set to false when creating a new wallet.
Generate Deposit Address
Use the createAddress API endpoint to create a unique address for receiving deposits.
Share Address
Provide the generated address or a QR code to customers for deposits.
Monitor Transactions
Use the getTransactions API endpoint to track incoming deposits and ensure they are successful.
Sweep Funds
Once funds are received, you can sweep them without additional effort right from the wallet balance by creating a withdrawal using the createSpendRequest endpoint.
From Temporary Addresses
The flow for receiving deposits to the temporary account-based addresses and withdrawing funds from account-based wallets is the same as for UTXO addresses. Although, there are a few things to note:
- Temporary addresses stay assigned to the wallet by default for the period of 7 days (address lease period). Once this time period expires, the address returns to the CoinPayments pool of addresses.
- In case a customer makes at least one deposit to the same address within the address lease period, the lease period renews for another 7 days.
- Received funds are automatically consolidated into the balance of the wallet the address is assigned to at that moment. That's why it is important that customers check which address they send funds to.
- CoinPayments charges no fees for consolidating funds from temporary addresses at the wallet balance.
- When withdrawing funds from such wallet, you pay only one network fee which is significantly lower compared to withdrawing funds from a number of regular account-based addresses.
From Permanent Addresses
Permanent account-based addresses offer merchants the ability to manage individual customer balances with a higher level of control. These addresses are assigned to specific customers indefinitely, making them suitable for businesses that need to track deposits and balances for each customer separately.
Below is the process to Use Permanent Account-Based Addresses
Create Permanent API Wallet
- Use the createWalletAPI endpoint to create a wallet for your desired currency.
- Set the usePermanentAddressesattribute totrueto enable the use of permanent addresses.
Generate Permanent Deposit Address
- Use the createAddressAPI endpoint to create a permanent deposit address.
- Initially, the address is inactive and although it can receive funds, it requires activation before funds can be swept from it.
- Address activation requires activation fee. Address activation takes place within the address consolidation process that will be described further.
Share Address Details
Provide the generated address or a QR code to customers for deposits.
Monitor Deposits
Once customer sends funds to an address, use the getTransactions API endpoint to track deposits and confirm successful transactions.
Activate and Consolidate Funds
Once you are ready to sweep funds from the permanent addresses, you first need to consolidate the funds from the addresses at the wallet of the same currency that does not own permanent addresses (either Primary (UI) Balance of the currency or any other API wallet of the same currency within your account that has usePermanentAddresses attribute set to false).
You have two options to consolidate addresses:
a. Use the createWalletConsolidation API endpoint to consolidate funds from the addresses that belong to one API wallet into a wallet balance. You can consolidate funds to the balance of the wallet where the addresses belong or to any other wallet of the same currency within your account:
- as walletIdStrpath parameter indicate the API wallet which addresses you want to consolidate
- as toWalletIdStrpath parameter indicate the API wallet where funds from the addresses should be consolidated. If not provided, funds will be consolidated to the Primary Balance of the currency.
- as addressIdsquery parameters indicate the addresses corresponding towalletIdStrthat should be consolidated
b. Use the createWalletsConsolidation API endpoint to consolidate funds from the addresses that belong to different API wallets of the same currency into a single wallet balance. You can consolidate funds to the balance of any wallet of the same currency within your account:
- as toWalletIdStrpath parameter indicate the API wallet where funds from the addresses should be consolidated. If not provided, funds will be consolidated to the Primary Balance of the currency.
- as walletIdand addresses request body attributes indicate wallets and their addresses that should be consolidated
Fees During Consolidation
- Activation Fee:
- For newly created, inactive addresses, an activation fee is charged during the first consolidation.
- This fee applies to enable withdrawals from the permanent address for the first time.
- Transfer Fee:
- Every time funds are consolidated (regardless of whether the address is already activated), a Transfer Fee is applied for sweeping funds from permanent addresses to the wallet balance.
- Already Activated Addresses:
- No activation fee is charged for addresses that have already been activated in a previous consolidation.
Withdraw Funds
Once funds are consolidated into your wallet, you can withdraw them using the createSpendRequest endpoint.
During withdrawal, you have the option to convert the funds into another currency. To convert funds, specify destination currency id as toCurrency request body attribute of the spend request.
To make a simple withdrawal without conversion toCurrency must be the same as the currency of the walletIdStr path parameter.
Manage Commercial Balances
How to Move Funds from Primary Balance to API Balance
CoinPayments separates funds between the Primary balance and API balances to enhance flexibility and security. This separation allows businesses to efficiently manage funds for different purposes while maintaining strict control over access.
- Primary Balance: Funds stored here can only be accessed through the Dashboard UI and are not available via API.
- API Balances: Funds in API wallets are accessible only through the API integration under which they were created, but they can also be viewed via the Dashboard UI.
This approach provides several key benefits:
- Developers have no access to the main business funds stored in the Primary balance.
- Developers can only manage funds specifically assigned to API wallets, ensuring limited exposure to sensitive funds.
- Businesses can quickly allocate and top up API wallet balances for specific purposes, such as project budgets or operational expenses.
In this tutorial you will learn how to top up your API balance via Dashboard UI.
Create API Wallet
- Use the createWalletAPI endpoint to generate an API wallet for a specific currency.
- Once created, the wallet will appear under the API Wallets tab in your Primary balance for that currency.
 
Copy API Wallet ID
For UTXO or account-based addresses with temporary wallets, copy the API wallet ID from the API Balances tab to deposit money from the Primary Balance.

Initiate Transfer
Click the Send button next to the Primary wallet balance on the Dashboard UI.

- In the pop-up form, paste the copied API wallet ID and enter the amount to transfer.
- Confirm the transfer.

Transferring Funds to API Wallets with Permanent Addresses
For API wallets using permanent addresses, funds must be deposited directly into an address within the wallet rather than into the wallet balance itself:
Generate Address
Use the createAddress API endpoint to generate a permanent address within the API wallet.

Verify Address Availability
Use the getAddress endpoint to confirm the address is ready to receive deposits.

Initiate Withdrawal
Create a withdrawal from the Primary balance via the Dashboard UI to the permanent address.

Monitor Transfer
Check the API Balances tab to confirm the funds are deposited into the API wallet associated with the permanent address.
