Deposit

On this page, we’ll dive into the different deposit endpoints you can use to manage deposit transactions programmatically. You can deposit both fiat and cryptocurrency.

The deposit model

The deposit model is the data structure that represents a deposit transaction in Rampable. The following attributes are associated with the deposit model:

Properties

  • Name
    depositId
    Type
    string
    Description

    Unique identifier for the deposit transaction.

  • Name
    depositType
    Type
    string
    Description

    The type of deposit (e.g., fiat or crypto).

  • Name
    userId
    Type
    string
    Description

    Unique identifier for the user making the deposit.

  • Name
    inputCurrency
    Type
    string
    Description

    The currency used for the deposit (e.g., IDR).

  • Name
    inputAmount
    Type
    number
    Description

    The amount of the deposit in the input currency.

  • Name
    exchangeRate
    Type
    number
    Description

    The exchange rate applied to the deposit.

  • Name
    output
    Type
    object
    Description

    The output details of the deposit transaction.

  • Name
    output.balanceType
    Type
    string
    Description

    The type of balance (e.g., fiat or crypto).

  • Name
    output.currency
    Type
    string
    Description

    The currency of the output (e.g., IDR).

  • Name
    output.amount
    Type
    number
    Description

    The amount of the output.

  • Name
    fee
    Type
    object
    Description

    The fee details associated with the deposit.

  • Name
    fee.amount
    Type
    number
    Description

    The amount of the fee.

  • Name
    fee.percentage
    Type
    number
    Description

    The percentage of the fee.

  • Name
    fee.currency
    Type
    string
    Description

    The currency of the fee.

  • Name
    paymentFiat
    Type
    object
    Description

    The payment details for fiat transactions.

  • Name
    paymentFiat.bankName
    Type
    string
    Description

    The name of the bank used for the payment.

  • Name
    paymentFiat.bankCode
    Type
    string
    Description

    The code of the bank used for the payment.

  • Name
    paymentFiat.accountName
    Type
    string
    Description

    The name on the bank account.

  • Name
    paymentFiat.accountNumber
    Type
    string
    Description

    The bank account number. If we using VA or Bank transfer, this field will be filled.

  • Name
    paymentFiat.qrCode
    Type
    string
    Description

    The QR code for the payment. If we using QRIS, this field will be filled.

  • Name
    paymentFiat.checkoutUrl
    Type
    string
    Description

    The checkout URL for the payment. If we using EWallet, this field will be filled.

  • Name
    paymentCrypto
    Type
    object
    Description

    The payment details for crypto transactions.

  • Name
    paymentCrypto.payoutWallet
    Type
    string
    Description

    The wallet address used for the payment.

  • Name
    paymentCrypto.network
    Type
    string
    Description

    The network used for the payment.

  • Name
    status
    Type
    string
    Description

    The status of the deposit transaction. This can be either pending, expired or completed.

  • Name
    activityHistory
    Type
    array
    Description

    A history of activities related to the deposit.

  • Name
    activityHistory.activity
    Type
    string
    Description

    The activity description.

  • Name
    activityHistory.status
    Type
    string
    Description

    The status of the activity.

  • Name
    activityHistory.description
    Type
    string
    Description

    A description of the activity.

  • Name
    activityHistory.updatedAt
    Type
    string
    Description

    The timestamp of the activity update.

  • Name
    reference
    Type
    string
    Description

    This can be the client transaction ID for the deposit transaction.

  • Name
    bankNote
    Type
    string
    Description

    Bank note from user to easier match the deposit transaction.

  • Name
    expiredAt
    Type
    string
    Description

    The expiration timestamp of the deposit transaction.

  • Name
    createdAt
    Type
    string
    Description

    The timestamp when the deposit transaction was created.

  • Name
    updatedAt
    Type
    string
    Description

    The timestamp when the deposit transaction was last updated.


GET/v1/deposit

List all deposit transactions

This endpoint allows you to retrieve a paginated list of all your deposit transactions. By default, a maximum of ten deposit transactions are shown per page.

Query Params attributes

  • Name
    limit
    Type
    integer
    Description

    Limit the number of deposit transactions returned.

  • Name
    page
    Type
    integer
    Description

    Specify the page number of the deposit transactions to retrieve.

  • Name
    sort
    Type
    string
    Description

    Sort the deposit transactions by a specific field. You can sort by createdAt or updatedAt. By default, deposit transactions are sorted by createdAt. You can also sort in reverse order by adding a hyphen (-) before the field you want to sort by.

  • Name
    status
    Type
    string
    Description

    Filter deposit transactions by status. This can be either pending, expired or completed.

  • Name
    depositType
    Type
    string
    Description

    Filter deposit transactions by deposit type. This can be either fiat or crypto.

Request

GET
/v1/deposit
curl -X GET "https://sandbox.rampable.co/v1/deposit?limit=10&page=1&sort=createdAt&status=pending&depositType=fiat" \
-H "Authorization: Bearer YOUR_ACCESS_TOKEN" \

Response

{
  "statusCode": 200,
  "message": "getDepositListHandler successfully",
  "data": {
      "docs": [
          {
              "output": {
                  "balanceType": "fiat",
                  "currency": "IDR",
                  "amount": 4980
              },
              "paymentFiat": {
                  "bankName": "Bank Sinarmas",
                  "bankCode": "bank_sinarmas",
                  "accountName": "Rampable",
                  "accountNumber": "123123123"
              },
              "fee": {
                  "amount": 5020,
                  "percentage": 50.2,
                  "currency": "IDR"
              },
              "depositId": "24f8d87a-ee5c-42b6-81b1-0a2706430bd7",
              "depositType": "fiat",
              "userId": "6724548c8638b44fd6f6f0f3",
              "inputCurrency": "IDR",
              "exchangeRate": 1,
              "inputAmount": 10000,
              "activityHistory": [
                  {
                      "activity": "Paid by Payee",
                      "status": "pending",
                      "description": "Waiting for payment",
                      "updatedAt": "2024-11-01T10:27:35.024Z",
                      "_id": "6724ad17edf5d43f1026ace2"
                  }
              ],
              "status": "completed",
              "reference": "1234567890",
              "bankNote": "Payment for order 123",
              "expiredAt": "2024-11-01T10:32:35.024Z",
              "createdAt": "2024-11-01T10:27:35.040Z",
              "updatedAt": "2024-11-02T06:57:15.690Z",
              "id": "6724ad17edf5d43f1026ace1"
          }
      ],
      "totalDocs": 1,
      "offset": 0,
      "limit": 10,
      "totalPages": 1,
      "page": 1,
      "pagingCounter": 1,
      "hasPrevPage": false,
      "hasNextPage": true,
      "prevPage": null,
      "nextPage": 2
  }
}

GET/v1/deposit/:depositId

Deposit details

This endpoint retrieves the details of a specific deposit transaction.

Request

GET
/v1/deposit/:depositId
curl -X GET "https://sandbox.rampable.co/v1/deposit/24f8d87a-ee5c-42b6-81b1-0a2706430bd7" \
-H "Authorization: Bearer YOUR_ACCESS_TOKEN" \

Response

  {
      "statusCode": 200,
      "message": "getDepositDetailHandler successfully",
      "data": {
          "output": {
              "balanceType": "fiat",
              "currency": "IDR",
              "amount": 15049.82
          },
          "paymentFiat": {
              "bankName": "Bank Sinarmas",
              "bankCode": "bank_sinarmas",
              "accountName": "Rampable",
              "accountNumber": "123123123"
          },
          "fee": {
              "amount": 5040.18,
              "percentage": 25.088003982080636,
              "currency": "IDR"
          },
          "depositId": "21817b75-5175-4a4a-bb0e-b6d4e2fb49fb",
          "depositType": "fiat",
          "userId": "6724548c8638b44fd6f6f0f3",
          "inputCurrency": "IDR",
          "exchangeRate": 1,
          "inputAmount": 20090,
          "activityHistory": [
              {
                  "activity": "Paid by Payee",
                  "status": "pending",
                  "description": "Waiting for payment",
                  "updatedAt": "2024-11-09T12:51:36.925Z",
                  "_id": "672f5ad8b6778faec15f6269"
              }
          ],
          "status": "completed",
          "reference": "1234567890",
          "bankNote": "Payment for order 123",
          "expiredAt": "2024-11-09T12:56:36.925Z",
          "createdAt": "2024-11-09T12:51:36.935Z",
          "updatedAt": "2024-11-09T12:51:46.194Z",
          "id": "672f5ad8b6778faec15f6268"
      }
  }

POST/v1/deposit/fiat

Deposit Fiat

This endpoint initiates a fiat deposit transaction. To initiate a deposit, you must provide the amount, inputCurrency, outputCurrency, balanceType, and paymentMethod.

Required attributes

  • Name
    inputAmount
    Type
    number
    Description

    The amount of the offramp in the input currency.

  • Name
    inputCurrency
    Type
    string
    Description

    The fiat currency of the deposit.

  • Name
    outputCurrency
    Type
    string
    Description

    The output currency (fiat or crypto) of the deposit.

  • Name
    balanceType
    Type
    string
    Description

    The type of balance (e.g., fiat).

  • Name
    paymentMethod
    Type
    string
    Description

    The payment method used for the transaction. You can get the payment method code from the payment methods endpoint.

Optional attributes

  • Name
    reference
    Type
    string
    Description

    This can be the client transaction ID for the deposit transaction.

  • Name
    bankNote
    Type
    string
    Description

    Bank note from user to easier match the deposit transaction.

Request

POST
/v1/deposit/fiat
curl --location \
https://sandbox.rampable.co/v1/deposit/fiat \
--header 'x-client-secret: ••••••' \
--header 'Content-Type: application/json' \
--header 'Authorization: ••••••' \
--data '{
  "inputAmount": 10000,
  "inputCurrency": "IDR",
  "outputCurrency": "IDR",
  "balanceType": "fiat",
  "paymentMethod": "bank_sinarmas",
  "reference": "1234567890",
  "bankNote": "Payment for order 123"
}'

Response using VA or Bank Transfer

{
    "statusCode": 201,
    "message": "Fiat deposit created",
    "data": {
        "depositId": "4b509748-b2c2-4334-a251-8b0d79e5b750",
        "depositType": "fiat",
        "userId": "6719f68dd07aef516b9158ba",
        "inputCurrency": "IDR",
        "inputAmount": 10000,
        "exchangeRate": 1,
        "output": {
            "balanceType": "fiat",
            "currency": "IDR",
            "amount": 4980
        },
        "fee": {
            "amount": 5020,
            "percentage": 50.2,
            "currency": "IDR"
        },
        "paymentFiat": {
            "bankName": "Bank Sinarmas",
            "bankCode": "bank_sinarmas",
            "accountName": "Rampable",
            "accountNumber": "00000000"
        },
        "status": "pending",
        "activityHistory": [
            {
                "activity": "Paid by Payee",
                "status": "pending",
                "description": "Waiting for payment",
                "updatedAt": "2024-10-30T12:05:44.650Z"
            }
        ],
        "reference": "1234567890",
        "bankNote": "Payment for order 123",
        "expiredAt": "2024-10-30T12:10:44.650Z",
        "createdAt": "2024-10-30T12:05:44.653Z",
        "updatedAt": "2024-10-30T12:05:44.653Z"
    }
}

Response using QRIS

{
  "statusCode": 201,
  "message": "Fiat deposit created",
  "data": {
    "depositId": "5d2df3ab-2f73-4a20-9b4c-f329bc1b10e6",
    "depositType": "fiat",
    "userId": "673c6c1454d8550b2d139779",
    "inputCurrency": "IDR",
    "inputAmount": 15002,
    "exchangeRate": 1,
    "output": {
      "balanceType": "fiat",
      "currency": "IDR",
      "amount": 14896.986
    },
    "fee": {
      "amount": 105.014,
      "percentage": 0.7,
      "currency": "IDR"
    },
    "paymentFiat": {
      "bankName": "QRIS",
      "bankCode": "qris",
      "qrData": "000THIS IS A DUMMY QR00012345000GO TO SIMULATE PAGE ON DASHBOARD TO COMPLETE PAYMENT00012345000COM.PROVIDER.WWW00012345000ID.CO.QRIS.WWW000123000THIS IS A DUMMY QR00012345000GO TO SIMULATE PAGE ON DASHBOARD TO COMPLETE PAYMENT00012345.0001234ID1234Durianpay1234KOTA JAKARTA12345000"
    },
    "status": "pending",
    "activityHistory": [
      {
        "activity": "Paid by Payee",
        "status": "pending",
        "description": "Waiting for payment",
        "updatedAt": "2024-12-01T06:41:07.919Z",
        "_id": "674c05037b94b795a8440a0d"
      }
    ],
    "reference": "1",
    "bankNote": "bankNote1",
    "expiredAt": "2024-12-01T10:41:07.919Z",
    "createdAt": "2024-12-01T06:41:07.952Z",
    "updatedAt": "2024-12-01T06:41:07.952Z"
  }
}

HTTP Status 400 Example

Error Response

{
    "statusCode": 400,
    "error": "Not Found",
    "message": "Payment method not found"
}

PATCH/v1/deposit/:depositId/cancel

Cancel Deposit

This endpoint is used to cancel a deposit.

Request

PATCH
/v1/deposit/:depositId/cancel
curl --location \
  https://sandbox.rampable.co/v1/deposit/:depositId/cancel \
  --request PATCH \
  --header 'x-client-secret: ••••••' \
  --header 'Content-Type: application/json' \
  --header 'Authorization: ••••••' \

Response

{
  "statusCode": 200,
  "message": "Deposit cancelled"
}

PATCH/v1/deposit/:depositId

[DEV] Update status

This endpoint is used to update the status of a deposit. Work only on sandbox environment. Will send webhook to the user.

Required attributes

  • Name
    status
    Type
    string
    Description

    The status of the deposit.

Request

PATCH
/v1/deposit/:depositId
curl --location --request PATCH 'https://sandbox.rampable.co/v1/deposit/24f8d87a-ee5c-42b6-81b1-0a2706430bd7' \
--header 'x-client-secret: ••••••' \
--header 'Content-Type: application/json' \
--header 'Authorization: ••••••' \
--data '{
    "status" : "completed"
}'

Response

{
  "statusCode": 200,
  "message": "Deposit updated",
  "data": {
    "depositId": "24f8d87a-ee5c-42b6-81b1-0a2706430bd7",
    "depositType": "fiat",
    "userId": "6724548c8638b44fd6f6f0f3",
    "inputCurrency": "IDR",
    "inputAmount": 10000,
    "exchangeRate": 1,
    "output": {
      "balanceType": "fiat",
      "currency": "IDR",
      "amount": 4980
    },
    "fee": {
      "amount": 5020,
      "percentage": 50.2,
      "currency": "IDR"
    },
    "paymentFiat": {
      "bankName": "Bank Sinarmas",
      "bankCode": "bank_sinarmas",
      "accountName": "Rampable",
      "accountNumber": "123123123"
    },
    "paymentCrypto": {},
    "status": "completed",
    "activityHistory": [
      {
        "activity": "Paid by Payee",
        "status": "pending",
        "description": "Waiting for payment",
        "updatedAt": "2024-11-01T10:27:35.024Z",
        "_id": "6724ad17edf5d43f1026ace2"
      }
    ],
    "expiredAt": "2024-11-01T10:32:35.024Z",
    "createdAt": "2024-11-01T10:27:35.040Z",
    "updatedAt": "2024-11-02T06:56:39.934Z"
  }
}

### HTTP Status 400 Example

```json {{ title: 'Error Response' }}
{
    "statusCode": 400,
    "error": "Bad Request",
    "message": "Deposit not found"
}

GET/v1/deposit/payment-method

Deposit Fiat Payment Method

This endpoint is used to get the list of available payment methods for fiat deposit.

Request

GET
/v1/deposit/payment-method
curl --location --request GET 'https://sandbox.rampable.co/v1/deposit/payment-method' \
--header 'x-client-secret: ••••••' \
--header 'Authorization: ••••••'

Response

    {
      "statusCode": 200,
      "message": "getDepositPayment executed successfully",
      "data": [
          {
              "depositPaymentType": "qris",
              "bankName": "QRIS",
              "bankCode": "qris",
              "minimumAmount": 10000,
              "maximumAmount": 500000,
              "isActive": true
          },
          {
              "depositPaymentType": "va",
              "bankName": "VA BNI",
              "bankCode": "va_bni",
              "minimumAmount": 10000,
              "maximumAmount": 250000000,
              "isActive": true
          },
          {
              "depositPaymentType": "va",
              "bankName": "VA BRI",
              "bankCode": "va_bri",
              "minimumAmount": 10000,
              "maximumAmount": 250000000,
              "isActive": true
          },
          {
              "depositPaymentType": "va",
              "bankName": "VA BSI",
              "bankCode": "va_bsi",
              "minimumAmount": 10000,
              "maximumAmount": 250000000,
              "isActive": true
          },
          {
              "depositPaymentType": "va",
              "bankName": "VA CIMB",
              "bankCode": "va_cimb",
              "minimumAmount": 10000,
              "maximumAmount": 250000000,
              "isActive": true
          },
          {
              "depositPaymentType": "va",
              "bankName": "VA DANAMON",
              "bankCode": "va_danamon",
              "minimumAmount": 10000,
              "maximumAmount": 250000000,
              "isActive": true
          },
          {
              "depositPaymentType": "va",
              "bankName": "VA MANDIRI",
              "bankCode": "va_mandiri",
              "minimumAmount": 10000,
              "maximumAmount": 250000000,
              "isActive": true
          },
          {
              "depositPaymentType": "va",
              "bankName": "VA PERMATA",
              "bankCode": "va_permata",
              "minimumAmount": 10000,
              "maximumAmount": 250000000,
              "isActive": true
          }
      ]
    }

Was this page helpful?