NAV

Introduction to Astra API

Scroll down for example requests and responses.

What is it?

Astra API is a unified API for crypto markets. The API provides direct market access (DMA), i.e. it gives you fine-grained read and write access to the underlying orderbook on many different trading venues - including centralized exchanges, DEXes, and OTC desks.

Astra API takes care of data normalization, so you don't have to implement 10 different integrations for 10 different trading venues. Instead, you can just build one integration using Astra's unified data format, and use it for every trading venue.

Who is it for?

Astra API is perfect for any business that needs to build performant, robust, and easy-to-use connections to crypto markets. This includes: trading firms, individual traders, OTC desks, institutional investors, fintech companies, brokerages, neobanks, and exchanges.

Integrating with our API is easy. Any developer can get started with Astra API in minutes, using the documentation on this page.

Supported exchanges

We currently support:

The list is growing quickly, and we plan to add support for several more exchanges and DEXes in the coming months. If there's a specific trading venue that you'd like us to prioritize, please contact us.

If you're an exchange or other trading venue, and you want us to integrate with your platform, please contact us.

Supported asset types

We currently support the following asset types for each of the above exchanges:

Supported endpoints

See below for a detailed list of the endpoints we support:

How it works

If you are using Astra API for fetching real-time market data, all you need to get started is an API key, which you can get by following the steps below.

In order to use Astra API for order management, execution, or position management, you need to first do the following for each exchange you wish to trade on:

  1. Create an account
  2. Perform KYC verification if applicable
    • This is common for centralized exchanges, but typically not for DEXes
  3. Deposit funds onto the exchange
  4. Get approved for each asset type you want to trade
    • Many exchanges will ask you to go through a quiz or signup process on their website in order to trade futures, options, and other margin products

You will then export your API keys from each exchange to use them with Astra API. More details on how to do this coming soon, once we add support for private exchange endpoints.

If you would like to self-host Astra API on your own servers, see below.

Getting Started

1. Create an account

First, create an account with us here: https://terminal.astra-api.dev/settings/apikeys. You can use your Astra account to access all of our products and services.

Astra Terminal login page

2. Create an API key

Navigate to https://terminal.astra-api.dev/settings/apikeys and create an API key. The key will only be displayed once upon creation, so make sure you save it.

Astra Terminal API keys page

3. Send your first request

Endpoints

You can use the following endpoints to access our hosted API:

Authentication

All requests to Astra API need to be authenticated

{
    "x-astra-api-key": "Bearer kadjfasfl.KjUBAhdIafaDFSCsajfaIowSADxkaw"
}

You can authenticate by specifying a header named x-astra-api-key with the value Bearer {KEY}, where you replace "KEY" with the value of your API key. For example, if the API key you created in the previous step was kadjfasfl.KjUBAhdIafaDFSCsajfaIowSADxkaw, you would include the header displayed to the right.

Requests to the public market data endpoints do not require any additional authentication beyond your Astra API key. Private endpoints also require you to provide your exchange API keys for the specific exchange(s) you are trading on. More info on how to do this will be released once we enable support for private endpoints (currently in development).

Send a request

Sample Request

curl --location 'http://prod.astra-api.dev/orderbook?market=BINANCE-SPOT-BTC-USDT' \
--header 'x-astra-api-key: Bearer {ASTRA_API_KEY}'

Sample Response

{
    "bids": [
        {"price": 51485.41, "quantity": 4.10646},
        {"price": 51485.39, "quantity": 0.00975},
        {"price": 51485.38, "quantity": 0.00975},
    ],
    "asks": [
        {"price": 51485.42, "quantity": 2.21005},
        {"price": 51485.59, "quantity": 0.77624},
        {"price": 51485.89, "quantity": 0.38811},
    ]
}

Use your favorite HTTP client to send a market data request. Here's an example curl command you can use:

Replace {ASTRA_API_KEY} with the API key that you just generated. You should receive a response with a current snapshot of the orderbook for that market!

Public REST API

Endpoint: https://prod.astra-api.dev

Authentication

Remember to specify an authentication header with your API key, as described above. Otherwise, your requests will fail.

Get Markets

Sample Request

GET /markets?exchange=BINANCE

Sample Response

[
    {
        "symbol": "BINANCE-SPOT-ETH-USDT",
        "assetType": "SPOT",
        "baseAsset": "ETH",
        "quoteAsset": "USDT"
    },
    {
        "symbol": "BINANCE-PERP-BTC-USDT",
        "assetType": "PERP",
        "baseAsset": "BTC",
        "quoteAsset": "USDT",
        "marginAsset": "USDT"
    },
    {
        "symbol": "BINANCE-PERP-BTC-USD-COINM",
        "assetType": "PERP",
        "baseAsset": "BTC",
        "quoteAsset": "USD",
        "marginAsset": "BTC"
    },
    {
        "symbol": "BINANCE-FUT-BTC-USDT-210625",
        "baseAsset": "BTC",
        "quoteAsset": "USDT",
        "marginAsset": "USDT"
    }
]

GET /markets

Returns all markets on the specified exchange that are supported by Astra, along with their associated metadata.

You can see the list of asset types we currently support here. We're working on expanding our coverage to all tradeable markets.

Request

Parameter Type Required Description
exchange Exchange True Exchange to fetch data from

Response

Type Required Description
Array<MarketMetadata> True List of markets and their associated metadata

Get Orderbook

Sample Request

GET /orderbook?market=BINANCE-SPOT-ETH-USDT

Sample Response

{
  "bids": [
    {
      "price": 1798.00,
      "quantity": 1.5,
    },
    {
      "price": 1797.01,
      "quantity": 5.0,
    }
  ],
  "asks": [
    {
      "price": 1798.00,
      "quantity": 1,
    },
    {
      "price": 1797.00,
      "quantity": 10.0,
    }
  ]
}

GET /orderbook

Returns a snapshot of the current L2 orderbook for the specified market. Bids are sorted in descending order of price, and asks are sorted in ascending order. The quantity at each price level corresponds to the aggregate of all open orders at that price.

Request

Parameter Type Required Description
market Market True Market to fetch data for

Response

Name Type Required Description
bids Array<Bid> True List of aggregated buy orders
asks Array<Ask> True List of aggregated sell orders

WebSocket API

You can use the WebSocket API to stream real-time market data.

Endpoint: wss://prod.astra-api.dev/ws

Authentication

Remember to specify an authentication header with your API key, as described above. Otherwise, your requests will fail.

Subscribing

You can have one active market data subscription per WebSocket connection. A "subscription" consists of a combination of a market and the data type you are subscribing to.

wss://prod.astra-api.dev/ws?market=BINANCE-PERP-BTC-USDT&dataType=ORDERBOOK

These are specified as query parameters in the initial connection request, as shown:

Request

Parameter Type Required Description
market Market True The market which you are requesting data for
dataType DataType True The type of market data you want to stream

Orderbook Channel

Sample Request

wss://prod.astra-api.dev/ws?market=BINANCE-PERP-BTC-USDT&dataType=ORDERBOOK

Sample Data Message

{
    "updateId": 37828320367,
    "bids": [
        {
            "price": 30708.01,
            "size": 1.26141
        },
        {
            "price": 30707.97,
            "size": 0.00571
        }
    ],
    "asks": [
        {
            "price": 30708.02,
            "size": 12.005
        },
        {
            "price": 30708.1,
            "size": 0.08388
        }
    ]
}

Streams L2 orderbook updates from the specified market.

For each exchange, we've used whichever endpoint returns the most fine-grained orderbook updates with the lowest latency. For some exchanges, this is one update per tick, and for some exchanges, batched updates are the best that is available. Contact us for more information about how this is implemented under the hood.

Message

Parameter Type Required Description
updateId u64 True Sequence ID for the orderbook update.

The exact format of this parameter may differ depending on the exchange, but it can be used to sequence updates. For any given market, updates with larger sequence IDs occurred later in time
bids Array<Bid> True List of updates to bids.

An update with parameters updateId,price and quantity means that the aggregated bid at price price was updated from its old quantity to quantity at the time indicated by the sequence number updateId
asks Array<Ask> True List of updates to asks

Trades Channel

Sample Request

wss://prod.astra-api.dev/ws?market=BINANCE-PERP-BTC-USDT&dataType=TRADE

Sample Data Message

{
    "trades": [
        {
            "price": 47104.0,
            "quantity": 0.003,
            "side": "SELL",
            "time": 1707527023484
        },
        {
            "price": 47100.1,
            "quantity": 0.0015,
            "side": "BUY",
            "time": 1707527025010
        }
    ]
}

Streams trade updates from the specified market.

For each exchange, we've used whichever endpoint returns the most fine-grained trade updates with the lowest latency. For some exchanges, this is one update per trade, and for some exchanges, batched updates are the best that is available. Contact us for more information about how this is implemented under the hood.

Message

Parameter Type Required Description
trades Array<Trade> True List of trades that have occurred since last message

Private REST API

Get Orders

GET /orders

Fetches the user's open orders for the specified market.

Get Fills

GET /fills

Fetches the user's fills for the specified market.

Get Balances

GET /balances

Fetches the user's balances of all assets on the exchange. This includes deposits, collateral and open positions.

Get Positions

GET /positions

Fetches the user's positions on the specified exchange.

Place Order

POST /orders

Place and order on the specified exchange and market.

Cancel Order

DELETE /orders

Cancels the specified order.

Schema

Exchange

Represents a trading venue supported by Astra. The full list of currently supported exchanges is:

Value
BINANCE
COINBASE
OKX
HUOBI
KUCOIN
KRAKEN

Market

Sample Data

Represents a particular market on a particular trading venue.

# Format for spot and perpetual futures markets:
{EXCHANGE}-{ASSET_TYPE}-{BASE_ASSET}-{QUOTE_ASSET}-?{DISAMBIGUATOR}

# Format for expiring futures markets:
{EXCHANGE}-{ASSET_TYPE}-{BASE_ASSET}-{QUOTE_ASSET}-{EXPIRY_SYMBOL}-?{DISAMBIGUATOR}

# Format for options markets:
{EXCHANGE}-{ASSET_TYPE}-{BASE_ASSET}-{QUOTE_ASSET}-{EXPIRY_SYMBOL}-{STRIKE_SYMBOL}-?{DISAMBIGUATOR}

Astra has developed a custom naming scheme to represent crypto markets across many diverse trading venues. Every tradeable market is assigned a "market symbol", which is a string that serves as the globally unique identifier for that market. The market symbol is also human-readable, and contains information about the exchange, base asset, quote asset, and metadata of that market.

On the right, you can see the format of market symbols for four popular asset types: spot, perpetual futures, expiring futures, and options.

"Disambiguator" is an optional parameter which is used to differentiate markets that are the same on all other parameters. For example, many exchanges have two types of futures contracts which differ in their margin behavior: those margined in USD or stablecoins (usually called "USD-margined" or "USD-M"), and those margined in the underlying base asset of the market (usually called "coin-margined" or "Coin-M"). To differentiate these, we use the "-COINM" disambiguator for coin-margined markets, and no disambiguator for USD-margined markets, which are more popular.

Here are some examples of various market symbols, along with descriptions of the markets they map to:

Market Symbol Example Description
BINANCE-SPOT-BTC-USDT Binance BTC/USDT spot market
BINANCE-PERP-BTC-USDT Binance USD-margined BTC/USDT perpetual futures
BINANCE-PERP-BTC-USD-COINM Binance coin-margined BTC/USD perpetual futures
COINBASE-SPOT-BTC-USD Coinbase BTC/USD spot market
OKX-FUT-BTC-USDT-210625 OKX BTC/USDT futures, expiring on 2021-06-25
BINANCE-OPT-BTC-USDT-210625-50000-C Binance BTC/USDT options, strike price 50000, expiring on 2021-06-25
... ...

MarketMetadata

Sample Data

{
    "symbol": "BINANCE-PERP-BTC-USD-COINM",
    "assetType": "PERP",
    "baseAsset": "BTC",
    "quoteAsset": "USD",
    "marginAsset": "BTC"
}

Metadata associated with a particular market.

Name Type Required Description
symbol Market True The market symbol, formatted as mentioned above, which uniquely identifies the market
assetType AssetType True The type of asset this market is for
baseAsset AbstractToken True For derivatives, this is the underlying asset of the instrument being bought and sold. For spot markets, this is itself the instrument being bought and sold
quoteAsset AbstractToken True Prices for this market are expressed in units of quoteAsset
marginAsset AbstractToken False The asset which is used as collateral for this market. Only exists for markets that allow margin trading

AssetType

Represents the type of asset that a particular market is for. We currently support the following asset types:

AssetType Description
SPOT A spot market
PERP A perpetual futures contract
FUT An expiring (non-perpetual) futures contract
OPT An option contract

AbstractToken

Represents an abstract "token" such as BTC, ETH, USD, USDT, etc. This will usually refer to a fungible blockchain token, but could potentially refer to other token-like assets such as equities, etc.

This representation is agnostic to implementation details such as the network and token standard, such as ERC-20 or TRC-20 or SPL.

It is also agnostic to any particular exchange's symbology. For example, Bitcoin from both Binance and BitMEX will map to an AbstractToken of BTC, even though Binance refers to Bitcoin as 'BTC' and BitMEX refers to Bitcoin as 'XBT'.

NOTE: We do incorporate the exchange's symbology into our market symbols! So our symbol for the BTC/USDT spot market on Binance is BINANCE_SPOT_BTC_USDT, while our symbol for the same market on BitMEX (once we enable support for BitMEX) will be BITMEX_SPOT_XBT_USD - because BitMEX uses 'XBT' to refer to Bitcoin and uses 'USD' rather than 'USDT' as the quote asset for this market. However, when you fetch the MarketMetadata for both these markets using our /markets endpoint, they will both have a baseAsset of BTC.

AbstractToken Description
BTC Bitcoin
ETH Ether
SOL Solana
XRP Ripple
... ...

Data Type

Value Description
ORDERBOOK Orderbook updates
TRADE Trade updates

Bid

Sample Data

{
    "price": 27879.5,
    "quantity": 1.5,
}

Represents the aggregate of all buy orders on a particular market for a given price level.

Name Type Required Description
price f64 True Price of the buy orders (in units of quoteAsset)
quantity f64 True Aggregated quantity of the buy orders (in units of baseAsset)

Ask

Sample Data

{
    "price": 27500.00,
    "quantity": 1,
}

Represents the aggregate of all sell orders on a particular market for a given price level.

Name Type Required Description
price f64 True Price of the sell orders (in units of quoteAsset)
quantity f64 True Aggregated quantity of the sell orders (in units of baseAsset)

Trade

Sample Data

{
    "exchangeMarket": {
        "exchange": "BINANCE",
        "market": {
            "baseAsset": {
                "type": "SPOT",
                "asset": "BTC"
            },
            "quoteAsset": "USDT"
        }
    },
    "price": 30199.49,
    "quantity": 0.0032,
    "side": "SELL"
}

Astra represents a trade through Trade on a specific market on an exchange.

Name Type Required Description
exchangeMarket Exchange Market True Contains exchange and market which was traded
price Float (f64) True Price of trade units of quote asset
quantity Float (f64) True Quantity of trade in units of base asset
side [Side]( True Direction of trade

Exchange Market

Name Type Required Description
exchange Exchange True Exchange to fetch data from.
price Float (f64) True Price of trade units of quote asset

Side

Value Description
SELL Taker is selling the asset
BUY Taker is buying the asset

Self hosting

What is it?

Astra API is available in two modes: managed and self-hosted.

With managed hosting, we run all the infrastructure behind the scenes to give you fast, robust market access.

With self-hosting, we provide you with a lightweight proxy agent that you run on your own servers. Your business software can then interact directly with each exchange via our proxy.

To get started, create an account with us and create and Astra API key. If you are using our API only to access public market data, then this is all you need.

If you are placing/cancelling orders or fetching your private user data, you will need to bring your own exchange accounts and API keys. Once you have set up accounts on an exchange, you can export your API keys and use that with the Astra API.

How to Self-Host?

For self-hosting, follow these steps:

  1. Install Docker: Ensure Docker is installed on your server. If not, visit Docker's official website for instructions.
docker run -d --platform linux/amd64 -p 8080:8080 -p 9090:9090 --env ASTRA_API_KEY=$ASTRA_API_KEY --name astra-gateway -t docker.io/astraimages/gateway:v0.0.1-alpha
  1. Obtain your API key Refer above for how to create an account and an Astra API key. Your API key is crucial for authentication and ensuring secure communication with the Astra API.

  2. Run the astra-gateway proxy Execute the following command in a shell on your server. Replace $ASTRA_API_KEY in the command with your actual Astra API key.

Data Privacy

For users of managed hosting, your data is encrypted in transit via HTTPS, and we never read any credentials that you transmit via our API. We have a strict no-logging policy for sensitive user data, which means that any credentials get destroyed as soon as they are used, and are never written to disk.

For users of self-hosting, you fully own your data. Your data, keys, and other credentials never leave your servers. Astra's proxy agent is self-contained, and only communicates with our servers to authenticate you and make sure you have a valid Astra API key.

OTC

Request quote

Sample Request

POST /request-quote
# Body
{
    "accountId": "a0743434-66c8-49b7-aca2-46c910a54cf1",
    "fromAsset": "BTC",
    "toAsset": "USD",
    "fromAmount": 1.25
}

Sample Response

{
    "quote": {
        "accountId": "a0743434-66c8-49b7-aca2-46c910a54cf1",
        "fromAsset": "BTC",
        "toAsset": "USD",
        "fromAssetQuantity": 1.25,
        "toAssetQuantity": 81436.0875,
        "expiryTime": 1733561867046245,
        "signature": "6932874cf486617239c7d27100e911903ccbee05c8b07fe3f4299e047f46553a"
    },
}

GET /request-quote

Generates an OTC trade quote for the specific asset pair and amount. Exactly one of fromAmount or toAmount must be specified in the request. 'fromAmount' is in units of the 'fromAsset' and 'toAmount' is in units of the 'toAsset'.

The response will include the expiry time of the quote, as well as a signature that will need to be sent while accepting a quote in order to successfully complete the trade.

Request

Parameter Type Required Description
accountId string True Account ID to generate quote for
fromAsset string True Asset to buy
toAsset string True Asset to sell
fromAmount number False Amount of 'fromAsset' to buy
toAmount number False Amount of 'toAsset' to sell

Response

Name Type Required Description
quote Quote True Quote for the trade

Quote

Name Type Required Description
accountId string True Account ID the quote was generated for
fromAsset string True Asset to buy
toAsset string True Asset to sell
fromAssetQuantity number True Amount of fromAsset to buy
toAssetQuantity number True Amount of toAsset to sell
expiryTime number True Unix timestamp in microseconds when quote expires
signature string True Signature required to execute trade with this quote

Accept quote

Sample Request

POST /accept-quote
# Body
{
    "quote": {
        "accountId": "a0743434-66c8-49b7-aca2-46c910a54cf1",
        "fromAsset": "BTC",
        "toAsset": "USD",
        "fromAssetQuantity": 1.25,
        "toAssetQuantity": 81436.0875,
        "expiryTime": 1733561867046245,
        "signature": "6932874cf486617239c7d27100e911903ccbee05c8b07fe3f4299e047f46553a"
    }
}

Sample Response

{}

POST /accept-quote

Accepts an OTC trade quote and completes the trade.

Request

Parameter Type Required Description
quote Quote True Quote to accept for the trade

Response

If successful, returns a 200 response with an empty JSON in the response body. Otherwise, returns an error message.