Crypto off-ramp
The crypto off-ramp flow allows a user to sell cryptocurrency and convert it into fiat, which can then be transferred to their linked debit cards.
Bootstrap token payload
- Schema
- Example
partner
(optional): Partner object.continueUrl
(optional): URL to redirect the user to after the order is placed and the funds were received.continueUrlTarget
(optional): In which tab should thecontinueUrl
be opened.new-tab
: Open in a new tab.same-tab
: Open in the same tab or iframe (default).parent-tab
: Useful only in an iframe: open in the tab that contains the iframe.
displayName
(optional): Partner name to be displayed to the user.fee
(optional): An object configuring the partner fee to be charged.percentage
: Percentage of the total source amount (the maximum allowed value is "5").
refund
(optional): An object configuring the refund details. The asset and network of the refund will be the same as the source asset and network.address
: Address to which the refund will be sent.tag
(optional): Tag of the crypto transaction, used to complement theaddress
.type
: Tag type (e.g.:memo
ordestination-tag
).value
: Tag value.
priority
(optional): Priority of the crypto transaction (e.g.:fast
will enable instant send forDash
transactions). Defaults tonormal
.
source
(optional): An object configuring the asset and amount to be sold.allowedAssets
(optional): Set of cryptoassets that the user can set as source asset.amount
(optional): Amount to be sold.asset
: Cryptoasset the user will send.editMode
(optional): Controls what values the user can change on the widget.all-editable
: The user can changeamount
,asset
andnetwork
on the widget. (default)only-amount
: The user can only change the amount on the widget.
network
(optional): Network of the receiving asset.walletSendUrl
(optional): URL to redirect the user to send the crypto from their wallet. It will include order details as query parameters liketopper_order_address
,topper_order_amount
,topper_order_asset_code
,topper_order_asset_network
,topper_order_tag_type
,topper_order_tag_value
, and others. Placeholders{topper_*}
can be used on the given URL for dynamic value replacement, useful for deep linking (e.g:https://partner.app/send?amount={topper_order_amount}&address={topper_order_address}
).walletSendUrlTarget
(optional): In which tab should thewalletSendUrl
be opened.new-tab
: Open in a new tab.same-tab
: Open in the same tab or iframe (default).parent-tab
: Useful only in an iframe: open in the tab that contains the iframe.
target
(optional): An object configuring the amount and asset to be paid.amount
(optional): Amount the user will receive.asset
: Currency code in the ISO 4217 format used to receive the funds.
At least one of source.amount
or target.amount
must be provided, but not both.
The supported values for target.asset
, source.asset
, source.network
, source.tag
can be found using our REST API, via the assets endpoint.
If source.allowedAssets
is set, and you define source.asset
with an asset that is not allowed, the bootstrap will fail.
If source.allowedAssets
is set and source.asset
is not, the source.asset
will default to the first asset on source.allowedAssets
.
In the sandbox
environment, Topper has limited funds on testnets. If you make an order that needs to be refunded using an asset we have no funds for, the order will be stuck indefinitely trying to create the blockchain transaction.
We recommend that you use XRP
for testing purposes when integrating Topper since we have a larger quantity of them. If you prefer to test with another asset and network, please reach out to us beforehand so that we can guarantee funds on our pool and give you a smoother integration experience.
{
"iat": 1679538023,
"jti": "4b552af1-1592-42f8-bbc9-dac28e2b4000",
"sub": "b9fe022b-f436-49e1-bb89-6f2e8eabf336",
"partner": {
"continueUrl": "https://example.com",
"continueUrlTarget": "new-tab",
"displayName": "ACME",
"fee": {
"percentage": "1"
}
},
"refund": {
"address": "0xb794f5ea0ba39494ce839613fffba74279579268",
"priority": "normal"
},
"source": {
"allowedAssets": [
"BTC",
{
"asset": "ETH",
"networks": [ "ethereum", "arbitrum" ]
},
{ "asset": "XRP" }
]
"amount": "1",
"asset": "ETH",
"editMode": "all-editable",
"network": "ethereum",
"walletSendUrl": "https://example.com",
"walletSendUrlTarget": "new-tab"
},
"target": {
"asset": "USD",
}
}
Events
order:crypto-offramp:committed
Triggered when a user has placed an order.
- Schema
- Example
id
: UUID of the order.status
: Status of the order (processing
).createdAt
: Timestamp at which the order was created.updatedAt
: Timestamp at which the order was last updated.origin
: Object containing information about what the user will send.amount
: Amount the user will send.rate
: Rate used to calculate the amount.asset
: Cryptoasset the user will send.network
: Network of the sending asset.depositAddress
: Object containing information related to the deposit.expiredAt
: Timestamp at which the deposit expires.remindAt
: Timestamp at which the user is reminded.tag
: Tag of the crypto transaction, used to complement the address.type
: Tag type.value
: Tag value.
value
: Address to which the user sends the funds.
destination
: Object containing information about what the user will receive.amount
: Amount the user will receive.rate
: Rate used to calculate the amount.asset
: Currency code in the ISO 4217 format used to receive the funds.paymentMethod
: Object containing information about the payment method used.type
: Type of payment method.
fees
: Array containing fees associated with the order.amount
: Amount user was charged for this fee.asset
: Asset used to charge the fee.normalized
: Amount in USD that the user was charged for this fee.type
: Type of fee (network
,deposit
orpartner
).
widget
: Widget associated with the session.id
UUID of the widget.name
: Name of the widget.flow
: Flow associated with the widget.
The values for destination.paymentMethod.type
can be found using our REST API, via the payment methods endpoint.
{
"name": "order:crypto-offramp:committed",
"id": "00a991cf-a870-43af-88b8-43c51532831d",
"bootstrapTokenId": "141bfa06-481e-4684-96eb-cec4ad529616",
"data": {
"id": "966b8e24-6a65-442a-942e-577f16288789",
"status": "processing",
"createdAt": "2023-06-12T17:21:21.240Z",
"updatedAt": "2023-06-12T17:21:21.240Z",
"origin": {
"amount": "0.047116964221968237",
"rate": "0.00056488387749632223",
"asset": "ETH",
"network": "ethereum",
"depositAddress": {
"expiredAt": "2023-06-12T17:21:21.240Z",
"remindAt": "2023-06-12T17:21:21.240Z",
"value": "0xb794F5eA0ba39494cE839613fffBA74279579268"
}
},
"destination": {
"amount": "100.00",
"rate": "1770.27534301775263314892",
"asset": "USD",
"paymentMethod": {
"type": "credit-card"
}
},
"fees": [
{
"amount": "2.42",
"asset": "USD",
"normalized": "2.42",
"type": "deposit"
},
{
"amount": "1.00",
"asset": "USD",
"normalized": "1.00",
"type": "partner"
}
],
"widget": {
"id": "998544f2-5b01-4062-9394-22827ff5db6c",
"name": "ACME",
"flow": "crypto_offramp"
}
}
}
order:crypto-offramp:funds-sent
Triggered when a user has sent funds for their order.
- Schema
- Example
id
: UUID of the order.status
: Status of the order (processing
).createdAt
: Timestamp at which the order was created.updatedAt
: Timestamp at which the order was last updated.origin
: Object containing information about what the user sent.amount
: Amount the user sent.rate
: Rate used to calculate the amount.asset
: Cryptoasset the user sent.network
: Network of the sending asset.depositAddress
: Object containing information related to the deposit.expiredAt
: Timestamp at which the deposit expires.remindAt
: Timestamp at which the user is reminded.tag
: Tag of the crypto transaction, used to complement the address.type
: Tag type.value
: Tag value.
value
: Address to which the user sends the funds.
destination
: Object containing information about what the user will receive.amount
: Amount the user will receive.rate
: Rate used to calculate the amount.asset
: Currency code in the ISO 4217 format used to receive the funds.paymentMethod
: Object containing information about the payment method used.type
: Type of payment method.
fees
: Array containing fees associated with the order.amount
: Amount user was charged for this fee.asset
: Asset used to charge the fee.normalized
: Amount in USD that the user was charged for this fee.type
: Type of fee (network
,deposit
orpartner
).
widget
: Widget associated with the session.id
UUID of the widget.name
: Name of the widget.flow
: Flow associated with the widget.
The values for destination.paymentMethod.type
can be found using our REST API, via the payment methods endpoint.
{
"name": "order:crypto-offramp:funds-sent",
"id": "00a991cf-a870-43af-88b8-43c51532831d",
"bootstrapTokenId": "141bfa06-481e-4684-96eb-cec4ad529616",
"data": {
"id": "966b8e24-6a65-442a-942e-577f16288789",
"status": "processing",
"createdAt": "2023-06-12T17:21:21.240Z",
"updatedAt": "2023-06-12T17:21:21.240Z",
"origin": {
"amount": "0.047116964221968237",
"rate": "0.00056488387749632223",
"asset": "ETH",
"network": "ethereum",
"depositAddress": {
"expiredAt": "2023-06-12T17:21:21.240Z",
"remindAt": "2023-06-12T17:21:21.240Z",
"value": "0xb794F5eA0ba39494cE839613fffBA74279579268"
}
},
"destination": {
"amount": "100.00",
"rate": "1770.27534301775263314892",
"asset": "USD",
"paymentMethod": {
"type": "credit-card"
}
},
"fees": [
{
"amount": "2.42",
"asset": "USD",
"normalized": "2.42",
"type": "deposit"
},
{
"amount": "1.00",
"asset": "USD",
"normalized": "1.00",
"type": "partner"
}
],
"widget": {
"id": "998544f2-5b01-4062-9394-22827ff5db6c",
"name": "ACME",
"flow": "crypto_offramp"
}
}
}
order:crypto-offramp:funds-received
Triggered when a user has sent funds for their order and we have received them.
- Schema
- Example
id
: UUID of the order.status
: Status of the order (processing
).createdAt
: Timestamp at which the order was created.updatedAt
: Timestamp at which the order was last updated.origin
: Object containing information about what the user sent.amount
: Amount the user sent.rate
: Rate used to calculate the amount.asset
: Cryptoasset the user sent.network
: Network of the sending asset.depositAddress
: Object containing information related to the deposit.expiredAt
: Timestamp at which the deposit expires.remindAt
: Timestamp at which the user is reminded.tag
: Tag of the crypto transaction, used to complement the address.type
: Tag type.value
: Tag value.
value
: Address to which the user sends the funds.
destination
: Object containing information about what the user will receive.amount
: Amount the user will receive.rate
: Rate used to calculate the amount.asset
: Currency code in the ISO 4217 format used to receive the funds.paymentMethod
: Object containing information about the payment method used.type
: Type of payment method.
fees
: Array containing fees associated with the order.amount
: Amount user was charged for this fee.asset
: Asset used to charge the fee.normalized
: Amount in USD that the user was charged for this fee.type
: Type of fee (network
,deposit
orpartner
).
widget
: Widget associated with the session.id
UUID of the widget.name
: Name of the widget.flow
: Flow associated with the widget.
The values for destination.paymentMethod.type
can be found using our REST API, via the payment methods endpoint.
{
"name": "order:crypto-offramp:funds-received",
"id": "00a991cf-a870-43af-88b8-43c51532831d",
"bootstrapTokenId": "141bfa06-481e-4684-96eb-cec4ad529616",
"data": {
"id": "966b8e24-6a65-442a-942e-577f16288789",
"status": "processing",
"createdAt": "2023-06-12T17:21:21.240Z",
"updatedAt": "2023-06-12T17:21:21.240Z",
"origin": {
"amount": "0.047116964221968237",
"rate": "0.00056488387749632223",
"asset": "ETH",
"network": "ethereum",
"depositAddress": {
"expiredAt": "2023-06-12T17:21:21.240Z",
"remindAt": "2023-06-12T17:21:21.240Z",
"value": "0xb794F5eA0ba39494cE839613fffBA74279579268"
}
},
"destination": {
"amount": "100.00",
"rate": "1770.27534301775263314892",
"asset": "USD",
"paymentMethod": {
"type": "credit-card"
}
},
"fees": [
{
"amount": "2.42",
"asset": "USD",
"normalized": "2.42",
"type": "deposit"
},
{
"amount": "1.00",
"asset": "USD",
"normalized": "1.00",
"type": "partner"
}
],
"widget": {
"id": "998544f2-5b01-4062-9394-22827ff5db6c",
"name": "ACME",
"flow": "crypto_offramp"
}
}
}
order:crypto-offramp:completed
Triggered when a user's order has completed.
- Schema
- Example
id
: UUID of the order.status
: Status of the order (completed
).createdAt
: Timestamp at which the order was created.updatedAt
: Timestamp at which the order was last updated.origin
: Object containing information about what the user sent.amount
: Amount the user sent.rate
: Rate used to calculate the amount.asset
: Cryptoasset the user sent.network
: Network of the sending asset.depositAddress
: Object containing information related to the deposit.expiredAt
: Timestamp at which the deposit expires.remindAt
: Timestamp at which the user is reminded.tag
: Tag of the crypto transaction, used to complement the address.type
: Tag type.value
: Tag value.
value
: Address to which the user sends the funds.
destination
: Object containing information about what the user received.amount
: Amount the user received.rate
: Rate used to calculate the amount.asset
: Currency code in the ISO 4217 format used to receive the funds.paymentMethod
: Object containing information about the payment method used.type
: Type of payment method.
fees
: Array containing fees associated with the order.amount
: Amount user was charged for this fee.asset
: Asset used to charge the fee.normalized
: Amount in USD that the user was charged for this fee.type
: Type of fee (network
,deposit
orpartner
).
widget
: Widget associated with the session.id
UUID of the widget.name
: Name of the widget.flow
: Flow associated with the widget.
The values for destination.paymentMethod.type
can be found using our REST API, via the payment methods endpoint.
{
"name": "order:crypto-offramp:completed",
"id": "00a991cf-a870-43af-88b8-43c51532831d",
"bootstrapTokenId": "141bfa06-481e-4684-96eb-cec4ad529616",
"data": {
"id": "966b8e24-6a65-442a-942e-577f16288789",
"status": "processing",
"createdAt": "2023-06-12T17:21:21.240Z",
"updatedAt": "2023-06-12T17:21:21.240Z",
"origin": {
"amount": "0.047116964221968237",
"rate": "0.00056488387749632223",
"asset": "ETH",
"network": "ethereum",
"depositAddress": {
"expiredAt": "2023-06-12T17:21:21.240Z",
"remindAt": "2023-06-12T17:21:21.240Z",
"value": "0xb794F5eA0ba39494cE839613fffBA74279579268"
}
},
"destination": {
"amount": "100.00",
"rate": "1770.27534301775263314892",
"asset": "USD",
"paymentMethod": {
"type": "credit-card"
}
},
"fees": [
{
"amount": "2.42",
"asset": "USD",
"normalized": "2.42",
"type": "deposit"
},
{
"amount": "1.00",
"asset": "USD",
"normalized": "1.00",
"type": "partner"
}
],
"widget": {
"id": "998544f2-5b01-4062-9394-22827ff5db6c",
"name": "ACME",
"flow": "crypto_offramp"
}
}
}
order:crypto-offramp:failed
Triggered when a user's order has failed.
- Schema
- Example
id
: UUID of the order.status
: Status of the order (failed
).createdAt
: Timestamp at which the order was created.updatedAt
: Timestamp at which the order was last updated.origin
: Object containing information about what the user sent.amount
: Amount the user sent.rate
: Rate used to calculate the amount.asset
: Cryptoasset the user sent.network
: Network of the sending asset.depositAddress
: Object containing information related to the deposit.expiredAt
: Timestamp at which the deposit expires.remindAt
: Timestamp at which the user is reminded.tag
: Tag of the crypto transaction, used to complement the address.type
: Tag type.value
: Tag value.
value
: Address to which the user sends the funds.
destination
: Object containing information about what the user would have received.amount
: Amount the user would have received.rate
: Rate used to calculate the amount.asset
: Currency code in the ISO 4217 format used to receive the funds.paymentMethod
: Object containing information about the payment method used.type
: Type of payment method.
fees
: Array containing fees associated with the order.amount
: Amount user was charged for this fee.asset
: Asset used to charge the fee.normalized
: Amount in USD that the user was charged for this fee.type
: Type of fee (network
,deposit
orpartner
).
widget
: Widget associated with the session.id
UUID of the widget.name
: Name of the widget.flow
: Flow associated with the widget.
error
: Indicates specific error information.reason
: Indicates the reason for the error, possible values arefraud
.
The values for destination.paymentMethod.type
can be found using our REST API, via the payment methods endpoint.
{
"name": "order:crypto-offramp:failed",
"id": "00a991cf-a870-43af-88b8-43c51532831d",
"bootstrapTokenId": "141bfa06-481e-4684-96eb-cec4ad529616",
"data": {
"id": "966b8e24-6a65-442a-942e-577f16288789",
"status": "failed",
"createdAt": "2023-06-12T17:21:21.240Z",
"updatedAt": "2023-06-12T17:21:21.240Z",
"origin": {
"amount": "0.047116964221968237",
"rate": "0.00056488387749632223",
"asset": "ETH",
"network": "ethereum",
"depositAddress": {
"expiredAt": "2023-06-12T17:21:21.240Z",
"remindAt": "2023-06-12T17:21:21.240Z",
"value": "0xb794F5eA0ba39494cE839613fffBA74279579268"
}
},
"destination": {
"amount": "100.00",
"rate": "1770.27534301775263314892",
"asset": "USD",
"paymentMethod": {
"type": "credit-card"
}
},
"fees": [
{
"amount": "2.42",
"asset": "USD",
"normalized": "2.42",
"type": "deposit"
},
{
"amount": "1.00",
"asset": "USD",
"normalized": "1.00",
"type": "partner"
}
],
"widget": {
"id": "998544f2-5b01-4062-9394-22827ff5db6c",
"name": "ACME",
"flow": "crypto_offramp"
},
"error": {
"reason": "fraud"
}
}
}
order:crypto-offramp:refund:completed
Triggered when a user's order has been successfully refunded.
- Schema
- Example
id
: UUID of the order.status
: Status of the order (failed
).createdAt
: Timestamp at which the order was created.updatedAt
: Timestamp at which the order was last updated.origin
: Object containing information about what the user sent.amount
: Amount the user sent.rate
: Rate used to calculate the amount.asset
: Cryptoasset the user sent.network
: Network of the sending asset.depositAddress
: Object containing information related to the deposit.expiredAt
: Timestamp at which the deposit expires.remindAt
: Timestamp at which the user is reminded.tag
: Tag of the crypto transaction, used to complement the address.type
: Tag type.value
: Tag value.
value
: Address to which the user sends the funds.
destination
: Object containing information about what the user would have received.amount
: Amount the user would have received.rate
: Rate used to calculate the amount.asset
: Currency code in the ISO 4217 format used to receive the funds.paymentMethod
: Object containing information about the payment method used.type
: Type of payment method.
fees
: Array containing fees associated with the order.amount
: Amount user was charged for this fee.asset
: Asset used to charge the fee.normalized
: Amount in USD that the user was charged for this fee.type
: Type of fee (network
,deposit
orpartner
).
refund
: Object containing information about how much was refunded to the user.amount
: Amount the user received.rate
: Rate used to calculate the amount.asset
: Cryptoasset the user received.network
: Network of the receiving asset.address
: User's wallet address to receive funds.priority
: Priority of the crypto transaction.tag
: Tag of the crypto transaction, used to complement the address.type
: Tag type (e.g.:memo
ordestination-tag
).value
: Tag value.
widget
: Widget associated with the session.id
UUID of the widget.name
: Name of the widget.flow
: Flow associated with the widget.
The values for destination.paymentMethod.type
can be found using our REST API, via the payment methods endpoint.
{
"name": "order:crypto-offramp:refund:completed",
"id": "00a991cf-a870-43af-88b8-43c51532831d",
"bootstrapTokenId": "141bfa06-481e-4684-96eb-cec4ad529616",
"data": {
"id": "966b8e24-6a65-442a-942e-577f16288789",
"status": "failed",
"createdAt": "2023-06-12T17:21:21.240Z",
"updatedAt": "2023-06-12T17:21:21.240Z",
"origin": {
"amount": "0.047116964221968237",
"rate": "0.00056488387749632223",
"asset": "ETH",
"network": "ethereum",
"depositAddress": {
"expiredAt": "2023-06-12T17:21:21.240Z",
"remindAt": "2023-06-12T17:21:21.240Z",
"value": "0xb794F5eA0ba39494cE839613fffBA74279579268"
}
},
"destination": {
"amount": "100.00",
"rate": "1770.27534301775263314892",
"asset": "USD",
"paymentMethod": {
"type": "credit-card"
}
},
"fees": [
{
"amount": "2.42",
"asset": "USD",
"normalized": "2.42",
"type": "deposit"
},
{
"amount": "1.00",
"asset": "USD",
"normalized": "1.00",
"type": "partner"
}
],
"refund": {
"amount": "0.047116964221968237",
"rate": "0.00056488387749632223",
"asset": "ETH",
"network": "ethereum",
"address": "0xb794F5eA0ba39494cE839613fffBA74279579268",
"priority": "normal"
},
"widget": {
"id": "998544f2-5b01-4062-9394-22827ff5db6c",
"name": "ACME",
"flow": "crypto_offramp"
}
}
}