Notus API
Transfers

Create Transfer

This endpoint provides a real-time quote for a token transfer, including the estimated amount of the token, fees, and other relevant details.

POST
/api/v1/crypto/transfer
x-api-key<token>

In: header

amountstring

The amount to be transferred, expressed as a decimal string.

chainIdnumber

The blockchain network where the transfer executes. Supported chains:

  • Arbitrum One: 42161
  • Avalanche: 43114
  • Base: 8453
  • BNB Smart Chain: 56
  • Ethereum: 1
  • OP Mainnet: 10
  • Polygon: 137
  • Gnosis: 100
gasFeePaymentMethodstring

Defines how the fee will be paid: "ADD_TO_AMOUNT" adds it to the input amount, while "DEDUCT_FROM_AMOUNT" subtracts it from the input amount.

Value in"ADD_TO_AMOUNT" | "DEDUCT_FROM_AMOUNT"
payGasFeeTokenstring

The token address (in hexadecimal format) used to pay the transaction fee.

Match^0x[a-fA-F0-9]{40}$
tokenstring

The address (in hexadecimal format) of the token being transferred.

Match^0x[a-fA-F0-9]{40}$
walletAddressstring

The wallet address (in hexadecimal format) initiating the swap.

Match^0x[a-fA-F0-9]{40}$
toAddressstring

The wallet address (in hexadecimal format) receiving the transfer.

Match^0x[a-fA-F0-9]{40}$
transactionFeePercent?number

Percentage fee to be charged (0 to 99%). The fee is deducted from the input token and sent to the treasuryAddress if configured.

Rangevalue <= 99.99
metadata?object

Custom metadata for the transaction. Key-value pairs with string values. Max 1KB size.

Empty Object

Response Body

curl -X POST "https://api.notus.team/api/v1/crypto/transfer" \
  -H "Content-Type: application/json" \
  -d '{
    "amount": "string",
    "chainId": 0,
    "gasFeePaymentMethod": "ADD_TO_AMOUNT",
    "payGasFeeToken": "string",
    "token": "string",
    "walletAddress": "string",
    "toAddress": "string"
  }'
const body = JSON.stringify({
  "amount": "string",
  "chainId": 0,
  "gasFeePaymentMethod": "ADD_TO_AMOUNT",
  "payGasFeeToken": "string",
  "token": "string",
  "walletAddress": "string",
  "toAddress": "string"
})

fetch("https://api.notus.team/api/v1/crypto/transfer", {
  body
})
package main

import (
  "fmt"
  "net/http"
  "io/ioutil"
  "strings"
)

func main() {
  url := "https://api.notus.team/api/v1/crypto/transfer"
  body := strings.NewReader(`{
    "amount": "string",
    "chainId": 0,
    "gasFeePaymentMethod": "ADD_TO_AMOUNT",
    "payGasFeeToken": "string",
    "token": "string",
    "walletAddress": "string",
    "toAddress": "string"
  }`)
  req, _ := http.NewRequest("POST", url, body)
  req.Header.Add("Content-Type", "application/json")
  res, _ := http.DefaultClient.Do(req)
  defer res.Body.Close()
  body, _ := ioutil.ReadAll(res.Body)

  fmt.Println(res)
  fmt.Println(string(body))
}
import requests

url = "https://api.notus.team/api/v1/crypto/transfer"
body = {
  "amount": "string",
  "chainId": 0,
  "gasFeePaymentMethod": "ADD_TO_AMOUNT",
  "payGasFeeToken": "string",
  "token": "string",
  "walletAddress": "string",
  "toAddress": "string"
}
response = requests.request("POST", url, json = body, headers = {
  "Content-Type": "application/json"
})

print(response.text)
import java.net.URI;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.net.http.HttpResponse.BodyHandlers;
import java.time.Duration;
import java.net.http.HttpRequest.BodyPublishers;

var body = BodyPublishers.ofString("""{
  "amount": "string",
  "chainId": 0,
  "gasFeePaymentMethod": "ADD_TO_AMOUNT",
  "payGasFeeToken": "string",
  "token": "string",
  "walletAddress": "string",
  "toAddress": "string"
}""");
HttpClient client = HttpClient.newBuilder()
  .connectTimeout(Duration.ofSeconds(10))
  .build();

HttpRequest.Builder requestBuilder = HttpRequest.newBuilder()
  .uri(URI.create("https://api.notus.team/api/v1/crypto/transfer"))
  .header("Content-Type", "application/json")
  .POST(body)
  .build();

try {
  HttpResponse<String> response = client.send(requestBuilder.build(), BodyHandlers.ofString());
  System.out.println("Status code: " + response.statusCode());
  System.out.println("Response body: " + response.body());
} catch (Exception e) {
  e.printStackTrace();
}
using System;
using System.Net.Http;
using System.Text;

var body = new StringContent("""
{
  "amount": "string",
  "chainId": 0,
  "gasFeePaymentMethod": "ADD_TO_AMOUNT",
  "payGasFeeToken": "string",
  "token": "string",
  "walletAddress": "string",
  "toAddress": "string"
}
""", Encoding.UTF8, "application/json");

var client = new HttpClient();
var response = await client.PostAsync("https://api.notus.team/api/v1/crypto/transfer", body);
var responseBody = await response.Content.ReadAsStringAsync();
{
  "transfer": {
    "metadata": {
      "key": "value"
    },
    "quoteId": "string",
    "userOperationHash": "string",
    "walletAddress": "string",
    "token": "string",
    "amountToSend": "string",
    "amountToSendUSD": "string",
    "amountToBeReceived": "string",
    "amountToBeReceivedUSD": "string",
    "chain": 0,
    "estimatedGasFees": {
      "payGasFeeToken": "string",
      "maxGasFeeToken": "string",
      "gasFeeTokenAmount": "string",
      "gasFeeTokenAmountUSD": "string",
      "maxGasFeeNative": "string"
    },
    "estimatedCollectedFee": {
      "collectedFeeToken": "string",
      "collectedFee": "string",
      "collectedFeePercent": "string",
      "notusCollectedFee": "string",
      "notusCollectedFeePercent": "string"
    },
    "toAddress": "string",
    "expiresAt": 0
  }
}
{
  "statusCode": 400,
  "id": "NOT_AUTHORIZED_TOKENS",
  "message": "The tokens '[0x]' are not authorized yet."
}
{
  "statusCode": 404,
  "id": "ACCOUNT_ABSTRACTION_ADDRESS_NOT_REGISTERED_WITH_PROJECT",
  "message": "The requested wallet \"undefined\" is not registered with the project"
}