Introduction
Welcome to the Bitwyre API!
All API URLs should use the base URL https://api.bitwyre.com for REST, and wss://api.bitwyre.com/ws for Websocket.
We have APIs for REST Public, REST Private, Websocket Public, and Websocket Private.
All endpoints returns either a JSON object or array along with some error messages (REST only, if any).
REST APIs
Example: REST On success
{
"error": [],
"result": {"some array or object of result(s)"}
}
Example: REST On error
{
"error": ["some (array) of error message(s)"],
"result": {}
}
- Public endpoints are all using
GET
method. - Private endpoints are using
POST
,GET
, andDELETE
with authentication scheme described in Authentication.
Websocket APIs
All of the examples are using Websocat, to install it you need Rust's Cargo and execute cargo install --features=ssl websocat
.
By its responses, both Public & Private, Websocket APIs both Public and Private can be categorized as:
- Asynchronous Request-Reply (Reactive), Private API must include auth scheme in the request data.
- Streaming Data/Broadcast (Pubsub and Periodic), Private API must include auth scheme in the the subscribe request data.
Authentication
Bitwyre uses HTTP Header authentication to allow access to the Private API.
REST Private API Request Headers
Example: REST GET private/account/balance
curl "https://api.bitwyre.com/private/orders" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"cd94e66609492952b26a4f3b29949d58548e9bd5e7bdd72598e441c6a57e57f4\",\
\"payload\": {\
\"pair\": \"btc_idr\",\
\"type\": \"buy\",\
\"ordertype\": \"limit\",\
\"price\": \"125000000\",\
\"volume\": \"500000\"\
}\
}"
Make sure to fill all fields with the correct ones.
All Private API endpoints expects for the following headers to be included in all API requests:
Header Key | Data Type | Required | Remark |
---|---|---|---|
"API-Key" | string | true | unique API-Key bounded to a user, see API Key. |
"API-Sign" | string | true | request signature , see API Sign. |
"Content-type" | string | varies | always application/json for POST & DELETE |
API Key
You can get a new Bitwyre API key pairs (api-key
and api-secret
) at our developer portal.
API Sign
The signature
, we call it API-Sign
, is created using HMAC-SHA512 of (URI path + SHA256(nonce + checksum))
and api-secret
, see REST Private API Data.
The URI path
is the endpoint path, e.g /private/orders
.
REST Private API Request Data
All Private API endpoints expect for the follow json data structure (form/query url for GET
) to be included in all API requests:
JSON Field | Data Type | Required | Remark |
---|---|---|---|
"nonce" | big-integer | true | always increasing unsigned 64 bit integer, see Cryptographic Nonce. |
"checksum" | string | true | SHA256 hash of "payload". |
"payload" | json-object/json-array | varies | endpoint specific request payload data. |
Websocket Private API Request Data
Example: Websocket Subscribe Request (Note: minify the json request for websocat)
websocat -E wss://api.bitwyre.com/ws/private/orders
>{
"command": "create",
"nonce": 1573882687533732677,
"checksum": "cd94e66609492952b26a4f3b29949d58548e9bd5e7bdd72598e441c6a57e57f4",
"api_key": "user_apikey",
"api_sign": "request_signature",
"payload": {
"pair": "btc_idr_spot",
"type": "buy",
"ordertype": "limit",
"price": "125000000",
"volume": "500000"
}
}
The Websocket Private API expects no HTTP Headers, bellow json data structure is needed for any secure request.
JSON Field | Data Type | Required | Remark |
---|---|---|---|
"command" | string | true | endpoint specific command. |
"nonce" | big-integer | true | see REST Private API Request Data. |
"checksum" | string | true | see REST Private API Request Data. |
"api_key" | string | true | see API Key. |
"api_sign" | string | true | see API Sign. |
"payload" | json-object/array | true | endpoint specific request payload data. |
Public API Endpoints
Server Time
Request
curl "https://api.bitwyre.com/public/time" -X GET
Response
{
"error": [],
"result": {
"unixtime": 1571744594571020435
}
}
Returns server's time.
This helps in approximating the time difference between the server and client.
Endpoint
https://api.bitwyre.com/public/time
Request Fields/Parameters
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
unixtime | big-integer | unix time in nanoseconds |
Markets
Request
curl "https://api.bitwyre.com/public/markets" -X GET
Response
{
"error": [],
"result": [
"crypto",
"equities",
"stablecoin",
"commodities",
"fixed_income",
"carbon"
]
}
Returns an underscore _
delimited tradable markets array
Endpoint
https://api.bitwyre.com/public/markets
Request Fields/Parameters
Response Types (JSON Array)
JSON Field | Data Type | Remark |
---|---|---|
JSON-array | string | Returns an underscore _ delimited tradable markets array |
Products
Request
curl "https://api.bitwyre.com/public/products" -X GET
Response
{
"error": [],
"result": ["spot", "futures", "options", "swaps", "spreads"]
}
Returns an underscore _
delimited tradable products array
Endpoint
https://api.bitwyre.com/public/products
Request Fields/Parameters
Response Types (JSON Array)
JSON Field | Data Type | Remark |
---|---|---|
JSON-array | string | Returns an underscore _ delimited tradable products array |
Assets
Request
curl "https://api.bitwyre.com/public/assets" -X GET
Response
{
"error": [],
"result": [
{
"asset": "btc",
"btc_equivalent": "1",
"icon_url": "https://storage.bitwyre.com/assets/btc.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "10",
"min_withdrawal": "0.001",
"name": "Bitcoin",
"precision": "1e-8",
"withdrawal_fee": "0.00000001"
},
{
"asset": "eth",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/public/images/coins/raster/ETH_500px.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "10",
"min_withdrawal": "0.001",
"name": "Ethereum",
"precision": "1e-9",
"withdrawal_fee": "0.00000001"
},
{
"asset": "xmr",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/public/images/coins/raster/XMR_500px.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "10",
"min_withdrawal": "0.001",
"name": "Monero",
"precision": "1e-12",
"withdrawal_fee": "0.00000001"
},
{
"asset": "zec",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/public/images/coins/raster/ZEC_500px.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "10",
"min_withdrawal": "0.001",
"name": "ZCash",
"precision": "1e-8",
"withdrawal_fee": "0.00000001"
},
{
"asset": "usdt",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/assets/usdt.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "",
"min_withdrawal": "20000",
"name": "USD Tether Stablecoin",
"precision": "1e-6",
"withdrawal_fee": "10000"
},
{
"asset": "idr",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/public/images/coins/raster/IDR.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "100000000",
"min_withdrawal": "100000",
"name": "Indonesian Rupiah",
"precision": "1",
"withdrawal_fee": "0"
},
{
"asset": "usd",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/assets/usd.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "",
"min_withdrawal": "20000",
"name": "United States Dollar",
"precision": "1e-2",
"withdrawal_fee": "10000"
},
{
"asset": "brl",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/public/images/fiats/raster/brl.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "",
"min_withdrawal": "20000",
"name": "Brazilian Real",
"precision": "1e-2",
"withdrawal_fee": "10000"
},
{
"asset": "mxn",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/public/images/fiats/raster/mxn.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "",
"min_withdrawal": "20000",
"name": "Mexican Peso",
"precision": "1e-2",
"withdrawal_fee": "10000"
}
]
}
Returns an array filled with supported assets.
Endpoint
https://api.bitwyre.com/public/assets
Request Fields/Parameters
Response Types (JSON Array)
JSON Field | Data Type | Remark |
---|---|---|
JSON-array | string | Returns an an array filled with tradable products |
Crypto Assets
Request
curl "https://api.bitwyre.com/public/assets/crypto" -X GET
Response
{
"error": [],
"result": [
{
"asset": "btc",
"btc_equivalent": "1.000000000000000",
"icon_url": "https://storage.bitwyre.com/assets/btc.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"market_cap_rank": "1",
"market_cap_usd": "420000000000",
"max_withdrawal": "10",
"min_deposit": "0",
"min_order_size": "0.00001",
"min_order_size_increment": "0.00001",
"min_price_increment_usd": "0.01",
"min_withdrawal": "0.001",
"name": "Bitcoin",
"network_list": [
{
"network_name": "Bitcoin",
"network_id": "BTC",
"asset_type": "coin",
"address_tag": "",
"token_type": "",
"address_regex": "^(tb1)[a-zA-Z0-9]{39}$|^(m|n)[a-zA-Z0-9]{33}$",
"memo_regex": "",
"is_contains_address_tag": false,
"is_network_deposit_enabled": true,
"is_network_withdraw_enabled": true,
"is_default_network": true,
"network_confirmations": 1,
"max_withdrawal": "100",
"min_deposit": "0.0001",
"min_withdrawal": "0",
"withdrawal_fee": "0",
"deposit_desc": "Ensure to check withdrawal address supports Bitcoin (BTC) chain deposits",
"withdraw_desc": "Send only Bitcoin (BTC) asset to this deposit address",
"explorer_address_url": "https://live.blockcypher.com/btc/address/",
"explorer_tx_url": "https://live.blockcypher.com/btc/tx/",
"notes": "",
}
],
"precision": "1e-8",
"price_to_usd": "21950.0000000000",
"withdrawal_fee": "0.00000001",
},
{
"asset": "eth",
"btc_equivalent": "0.069503416856492",
"icon_url": "https://storage.bitwyre.com/public/images/coins/raster/ETH_500px.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"market_cap_rank": "2",
"market_cap_usd": "180000000000",
"max_withdrawal": "10",
"min_deposit": "0",
"min_order_size": "0.0001",
"min_order_size_increment": "0.0001",
"min_price_increment_usd": "0.01",
"min_withdrawal": "0.001",
"name": "Ethereum",
"network_list": [
{
"network_name": "Ethereum",
"network_id": "ETH",
"asset_type": "coin",
"address_tag": "",
"token_type": "",
"address_regex": "^(0x)[0-9A-Fa-f]{40}$",
"memo_regex": "",
"is_contains_address_tag": false,
"is_network_deposit_enabled": true,
"is_network_withdraw_enabled": true,
"is_default_network": true,
"network_confirmations": 12,
"max_withdrawal": "1000",
"min_deposit": "1",
"min_withdrawal": "0",
"withdrawal_fee": "0",
"deposit_desc": "Ensure to check withdrawal address supports Ethereum (ETH) chain deposits",
"withdraw_desc": "Send only Ethereum (ETH) asset to this deposit address",
"explorer_address_url": "https://etherscan.io/address/",
"explorer_tx_url": "https://etherscan.io/tx/",
"notes": "",
},
{
"network_name": "Binance Smart Chain",
"network_id": "BSC",
"asset_type": "token",
"address_tag": "",
"token_type": "BEP20",
"address_regex": "^(0x)[0-9A-Fa-f]{40}$",
"memo_regex": "",
"is_contains_address_tag": false,
"is_network_deposit_enabled": true,
"is_network_withdraw_enabled": true,
"is_default_network": false,
"network_confirmations": 12,
"max_withdrawal": "1000",
"min_deposit": "1",
"min_withdrawal": "0",
"withdrawal_fee": "0",
"deposit_desc": "Ensure to check withdrawal address supports Ethereum (Binance Smart Chain BEP20) chain deposits",
"withdraw_desc": "Send only Ethereum (Binance Smart Chain BEP20) to this deposit address",
"explorer_address_url": "https://bscscan.com/address/",
"explorer_tx_url": "https://bscscan.com/tx/",
"notes": "",
},
{
"network_name": "Fantom",
"network_id": "FTM",
"asset_type": "token",
"address_tag": "",
"token_type": "ERC20",
"address_regex": "^(0x)[0-9A-Fa-f]{40}$",
"memo_regex": "",
"is_contains_address_tag": false,
"is_network_deposit_enabled": true,
"is_network_withdraw_enabled": true,
"is_default_network": false,
"network_confirmations": 12,
"max_withdrawal": "1000",
"min_deposit": "1",
"min_withdrawal": "0",
"withdrawal_fee": "0",
"deposit_desc": "Ensure to check withdrawal address supports Ethereum (Fantom ERC20) chain deposits",
"withdraw_desc": "Send only Ethereum (Fantom ERC20) to this deposit address",
"explorer_address_url": "https://ftmscan.com/address/",
"explorer_tx_url": "https://ftmscan.com/tx/",
"notes": "",
},
{
"network_name": "Solana",
"network_id": "SOL",
"asset_type": "token",
"address_tag": "",
"token_type": "SOL",
"address_regex": "^(0x)[0-9A-Fa-f]{40}$",
"memo_regex": "",
"is_contains_address_tag": false,
"is_network_deposit_enabled": true,
"is_network_withdraw_enabled": true,
"is_default_network": false,
"network_confirmations": 12,
"max_withdrawal": "1000",
"min_deposit": "1",
"min_withdrawal": "0",
"withdrawal_fee": "0",
"deposit_desc": "Ensure to check withdrawal address supports Ethereum (Solana SOL) chain deposits",
"withdraw_desc": "Send only Ethereum (Solana SOL) to this deposit address",
"explorer_address_url": "https://solscan.io/address/",
"explorer_tx_url": "https://solscan.io/tx/",
"notes": "",
}
],
"precision": "1e-9",
"price_to_usd": "1525.6000000000",
"withdrawal_fee": "0.00000001"
}
]
}
Returns an array filled with supported crypto assets.
Endpoint
https://api.bitwyre.com/public/assets/crypto
Request Fields/Parameters
Response Types (JSON Array)
JSON Field | Data Type | Remark |
---|---|---|
JSON-array | string | Returns an an array filled with tradable products |
Fiat Assets
Request
curl "https://api.bitwyre.com/public/assets/fiat" -X GET
Response
{
"error": [],
"result": [
{
"asset": "idr",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/public/images/coins/raster/IDR.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "100000000",
"min_withdrawal": "100000",
"name": "Indonesian Rupiah",
"precision": "1",
"withdrawal_fee": "0"
},
{
"asset": "mxn",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/public/images/fiats/raster/mxn.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "",
"min_withdrawal": "20000",
"name": "Mexican Peso",
"precision": "1e-2",
"withdrawal_fee": "10000"
},
{
"asset": "brl",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/public/images/fiats/raster/brl.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "",
"min_withdrawal": "20000",
"name": "Brazilian Real",
"precision": "1e-2",
"withdrawal_fee": "10000"
},
{
"asset": "usd",
"btc_equivalent": "",
"icon_url": "https://storage.bitwyre.com/assets/usd.png",
"is_deposit_enabled": true,
"is_trading_enabled": true,
"is_withdraw_enabled": true,
"local_equivalent": "",
"local_reference": "",
"max_withdrawal": "",
"min_withdrawal": "20000",
"name": "United States Dollar",
"precision": "1e-2",
"withdrawal_fee": "10000"
}
]
}
Returns an array filled with supported fiat assets.
Endpoint
https://api.bitwyre.com/public/assets/fiat
Request Fields/Parameters
Response Types (JSON Array)
JSON Field | Data Type | Remark |
---|---|---|
JSON-array | string | Returns an an array filled with tradable products |
Instruments
Request
curl "https://api.bitwyre.com/public/pairs?market=crypto&product=spot&country=ID" -X GET
Response For Spot Product
{
"error": [],
"result": [
{
"base_asset": "btc",
"best_ask": "0",
"best_bid": "9000.0",
"change_24hours": "0",
"forbidden_country": "US",
"incremental_price": "0.000001",
"instrument": "btc_usdt_spot",
"is_halt": false,
"is_matching_engine_replaying": false,
"last": "60000",
"market": "crypto",
"minimum_order_size": "0.00001",
"product": "spot",
"quote_asset": "usdt",
"size_increment": "0.00001",
"symbol": "BTC/USDT",
"volume_base": "0.001",
"volume_quote": "60"
},
{
"base_asset": "eth",
"best_ask": "0",
"best_bid": "1233.0",
"change_24hours": "0",
"forbidden_country": "US",
"incremental_price": "0.000001",
"instrument": "eth_usdt_spot",
"is_halt": true,
"is_matching_engine_replaying": false,
"last": "0",
"market": "crypto",
"minimum_order_size": "0.0001",
"product": "spot",
"quote_asset": "usdt",
"size_increment": "0.000001",
"symbol": "ETH/USDT",
"volume_base": "0",
"volume_quote": "0"
}
]
}
Returns an underscore _
delimited tradable asset pairs array.
A sample response for a futures market in crypto:
Request
curl "https://api.bitwyre.com/public/pairs?market=crypto&product=futures&country=GLOBAL" -X GET
Response
{
error: [],
result: [
{ instrument: "btcusdx_200607_futures", symbol: "BTCM20" }, // BTC USD Index, futures contract, settled in USD, delivery on June 7th 2020
{ instrument: "bchusdx_200607_futures", symbol: "BCHM20" }, // BCH USD Index, futures contract, settled in USD, delivery on June 7th 2020
{ instrument: "ethusdx_200607_futures", symbol: "ETHM20" }, // ETH USD Index, futures contract, settled in USD, delivery on June 7th 2020
{ instrument: "ethusdx_perp_futures", symbol: "ETHPERPS" }, // ETH USD Index, perpetual swap futures contracts, USD settled
{ instrument: "btcusdx_perp_futures", symbol: "BTCPERPS" }, // ETH USD Index, perpetual swap futures contracts, USD settled
],
}
For long product codes, we are using an _
(underscore) delimited convention to refer our futures and options product: indexname_expiry_producttype
.
- Underlying financial instrument price.
btcusdtx
here is the Bitcoin to USD index on Bitwyre's exchange; a weighted average of worldwide Bitcoin spot market index price. - Settlement currency,
USD
. - Product type, that can only be futures, swap, calloption, putoption, swaptions, swapfutures, spreads.
For short product codes, we are using the Chicago Mercantile Exchange (CME) convention with asset traded, month code and year code concatenated in capital letters.
Month | Month Code |
---|---|
January | F |
February | G |
March | H |
April | J |
May | K |
June | L |
July | M |
August | Q |
September | U |
October | V |
November | X |
December | Z |
A sample response for an options market in crypto:
Request
curl "https://api.bitwyre.com/public/pairs?market=crypto&product=options&country=GLOBAL" -X GET
Response
{
error: [],
result: [
{ instrument: "btcusdx_200607_10000_calloption", symbol: "BTCM20" }, // BTC USD Index, call options, settled in USD, delivery on June 7th 2020, strike price of 10000 USD
{ instrument: "bchusdx_200607_300_calloption", symbol: "BCHM20" }, // BCH USD Index, call options, settled in USD, delivery on June 7th 2020, strike price of 300 USD
{ instrument: "ethusdx_200607_500_calloption", symbol: "ETHM20" }, // ETH USD Index, call options, settled in USD, delivery on June 7th 2020, strike price of 300 USD
{ instrument: "btcusdx_200607_5000_putoption", symbol: "BTCM20" }, // BTC USD Index, put options, settled in USD, delivery on June 7th 2020, strike price of 5000 USD
{ instrument: "bchusdx_200607_100_putoption", symbol: "BCHM20" }, // BCH USD Index, put options, settled in USD, delivery on June 7th 2020, strike price of 100 USD
{ instrument: "ethusdx_200607_100_putoption", symbol: "ETHM20" }, // ETH USD Index, put options, settled in USD, delivery on June 7th 2020, strike price of 100 USD
{ instrument: "ethusdx_perp_100_putoption", symbol: "ETH100PUTPERPS" }, // ETH USD Index, put options, settled in USD, perpetual/everlasting options, strike price of 100 USD
{ instrument: "ethusdx_perp_1000000_calloption", symbol: "ETH1000000CALLPERPS" }, // ETH USD Index, call options, settled in USD, perpetual/everlasting options, strike price of 1,000,000 USD (one million dollars)
],
}
The product btcusdx_200607_10000_calloption
means a call contract
with delivery on June 7th, 2020
, at the strike price of 10,000
of the underlying financial instrument BTCUSDX
). bchusdx_200607_2000_calloption0
means a put contract
with delivery on June 7th, 2020
, at the strike price of 2,000
of the underlying financial instrument BTCUSDX
).
Endpoint
https://api.bitwyre.com/public/pairs
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"market" | string | true | crypto , equity , stablecoin , fixed_income , commodities or carbon |
"product" | string | true | spot , futures , options , swaps , or spreads |
"country" | string | true | ISO 3166-2 Country Code. Only ID or PA for now |
Response Types (JSON Array)
JSON Field | Data Type | Remark |
---|---|---|
JSON-array | string | base asset, quote asset, product filter, delimited with an _ (underscore). |
Ticker
Request
curl "https://api.bitwyre.com/public/ticker?instrument=btc_idr_spot" -X GET
Response
{
"error": [],
"result": [
{
"instrument": "btc_idr_spot",
"asset_base": "btc",
"asset_quote": "idr",
"high": "126989000",
"low": "115201000",
"percent_change": "-2.123",
"volume_base": "611.66499447",
"volume_quote": "7434324.9431",
"last": "124783000",
"best_bid": "124761000",
"best_ask": "124777000",
"timestamp": 1571744594571020435,
"market": "crypto",
"is_frozen": false
},
{
"instrument": "btc_usdt_spot",
"asset_base": "btc",
"asset_quote": "usdt",
"high": "126989000",
"low": "115201000",
"percent_change": "-2.123",
"volume_base": "611.66499447",
"volume_quote": "7434324.9431",
"last": "124783000",
"best_bid": "124761000",
"best_ask": "124777000",
"timestamp": 1571744594571020435,
"market": "crypto",
"is_frozen": false
}
]
}
Returns ticker information for an asset pair.
Endpoint
https://api.bitwyre.com/public/ticker
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"instrument" | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
If the instrument
paremeter is empty or omitted, will return the ticker data of all available asset pairs.
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
"instrument" | string | base asset, quote asset, product filter, delimited with an _ (underscore). |
"asset_base" | string | base asset in the trade pair |
"asset_quote" | string | quote asset in the trade pair |
"high" | float-string | highest market price in the last 24 hours |
"low" | float-string | lowest market price in the last 24 hours |
"percent_change" | float-string | market price change percentage in the last 24 hours (up to 8 precision) |
"volume_base" | float-string | total market volume of the base asset in the last 24 hours |
"volume_quote" | float-string | total market volume of the quote asset in the last 24 hours |
"last" | float-string | last market price for the base asset |
"best_bid" | float-string | current highest bid price |
"best_ask" | float-string | current lowest ask price |
"timestamp" | big-integer | unix time in nanoseconds |
"market" | enum-string | equities , crypto , fixed_income , or commodiities |
"is_frozen" | boolean | market frozen status |
Trades
Request
curl "https://api.bitwyre.com/public/trades?instrument=btc_usdt_spot&trade_num=2" -X GET
Response
{
"error": [],
"result": [
{
"instrument": "btc_usd_spot",
"price": "70000.0",
"side": 1,
"timestamp": 1617701262147203562,
"trade_uuid": "7d0cec66-f130-4fc6-b314-622d394ccec2",
"value": "4900.0",
"volume": "0.07"
},
{
"instrument": "btc_usd_spot",
"price": "70000.0",
"side": 2,
"timestamp": 1617701262147203562,
"trade_uuid": "7d0cec66-f130-4fc6-b314-622d394ccec2",
"value": "4900.0",
"volume": "0.07"
}
]
}
Returns last trade_num
trades for an asset pair.
Limited to a maximum of 50
last trades.
Endpoint
https://api.bitwyre.com/public/trades
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"instrument" | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
"trade_num" | number | true | last trade_num trades to get |
"from_time" | int | false | start timestamp in nanoseconds. |
"to_time" | int | false | end timestamp in nanoseconds. |
Response Types (Array of JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
instrument | string | base asset, quote asset, product filter, delimited with an _ (underscore). |
price | float-string | price/quote asset of the traded base asset |
volume | float-string | volume of the traded base asset |
value | float-string | quote value (price x volume) |
side | enum-number | trade type ( 1 - buy; 2 - sell ) |
id | uuid-string | universal unique id of the trade |
timestamp | big-integer | trade time, unixtime in nanoseconds |
Depth
Request
curl "https://api.bitwyre.com/public/depth?instrument=btc_idr_futures&depth_num=2" -X GET
Response
{
"error": [],
"result": {
"bids": [
["124112000", "0.18154050"],
["124110000", "0.47319750"]
],
"asks": [
["124130000", "0.03701609"],
["124251000", "0.03223585"]
],
"is_frozen": 0
}
}
Response For All Instrument
{
error: [],
result: {
asks: {
btc_usd_spot: [[]],
btc_idr_spot: [
["124112000", "0.18154050"],
["124110000", "0.47319750"],
],
// ... other instrument
},
bids: {
btc_usd_spot: [[]],
btc_idr_spot: [
["124130000", "0.03701609"],
["124251000", "0.03223585"],
],
// ... other instrument
},
is_frozen: 0,
},
}
Returns depth data for an asset pair.
Limited to a maximum of 150
data points.
Endpoint
https://api.bitwyre.com/public/depth
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). If instrument empty will fetch all depth from all instrument |
depth_num | number | true | depth_num count of data points to get |
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
bids | array-of-float-string-tuple | depth_num count of current bid orders in the orderbook |
asks | array-of-float-string-tuple | depth_num count of current ask orders in the orderbook |
is_frozen | boolean | market frozen status |
Contract
Request
curl "https://api.bitwyre.com/public/contract?instrument=btcusdtx_usdt_200607F1000000" -X GET
Response
{
"error": [],
"result": {
"instrument": "btcusdtx_usdt_200607F1000000",
"details": "contract for cash delivery of BTC/USD index settled for July 6th, 2020 for the strike price of 10,000 USD",
"pricing_source": "CME Bitcoin Real Time Index",
"bitwyre_index_price": "11500.00",
"bitwyre_index_price_currency": "USD",
"24h_volume": "800,000,000.00",
"24h_volume_currency": "USD",
"open_interest": "600,000,000.00",
"interest_rate": "0.001%",
"contract_value": "1 USD",
"initial_margin_base_value": "1%",
"maintenance_margin_base_value": "0.5%"
}
}
Returns contract details for a derivative instrument/asset pair.
Endpoint
https://api.bitwyre.com/public/contract
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
instrument | string | true | base asset, quote asset, product filter, delimited with an _ (underscore). |
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
instrument | string | base asset, quote asset, product filter, delimited with an _ (underscore). |
details | string | detail of financial contract |
pricing_source | string | source of index pricing |
bitwyre_index_price | float-string | price of index |
bitwyre_index_price_currency | string | currency of price index |
24h_volume | string | 24 hour traded volume of instrument |
24h_volume_currency | string | currency reference for 24 hour traded volume |
open_interest | string | the number of contracts or commitments outstanding in futures and options that are trading on an official exchange at any one time. |
interest_rate | percentage-string | interest rate reference for valuation reference |
contract_value | string | 1 contract value equivalent in USD |
initial_margin_base_value | string | initial margin percentage |
maintenance_margin_base_value | string | maintenance margin percentage |
Get Fiat Withdrawal Method
Request
curl "https://api.bitwyre.com/public/withdrawal/fiat/method" -X GET
Response
{
"error": [],
"result": [
{
"asset": "idr",
"fee": "0",
"fee_type": "",
"is_enabled": true,
"max_withdrawal": "",
"merchant_id": "MANDIRI",
"min_withdrawal": "0",
"payment_type": "Bank Transfer"
},
{
"asset": "idr",
"fee": "0",
"fee_type": "",
"is_enabled": true,
"max_withdrawal": "",
"merchant_id": "BRI",
"min_withdrawal": "0",
"payment_type": "Bank Transfer"
},
{
"asset": "idr",
"fee": "0",
"fee_type": "",
"is_enabled": true,
"max_withdrawal": "",
"merchant_id": "BNI",
"min_withdrawal": "0",
"payment_type": "Bank Transfer"
}
],
}
Get fiat withdrawal method data
Endpoint
https://api.bitwyre.com/public/withdrawal/fiat/method
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
asset | string | false | Transaction Asset. Default all |
payment_type | string | false | Withdrawal Payment Type (ex. Bank Transfer ) . Default all |
merchant_id | string | false | Withdrawal Merchant ID. Default all |
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
asset | string | Transaction Asset |
fee | string | Amount of withdrawal fee |
fee_type | string | Type of fee (if any) |
is_enabled | boolean | true if withdrawal method is enabled |
max_withdrawal | string | Maximum amount of withdrawal for the method |
merchant_id | string | Withdrawal Merchant ID |
min_withdrawal | string | Minimum amount of withdrawal for the method |
payment_type | string | Withdrawal Payment Type |
Insider Profiles
Request
curl "https://api.bitwyre.com/public/insider"
-X GET
Response
{
"error": [],
"result": [
{
"email": "[email protected]",
"email_verified": 0,
"has_submitted_kyc": null,
"insider": 1,
"institution": 0,
"is_otp_activated": 0,
"kyc_level": 0,
"master_account": 1,
"master_account_uuid": null,
"monthly_avg_trading_volumes": null,
"nationality": "ID",
"preference_pairs": null,
"pseudonym": null,
"reference_asset": null,
"restricted": 0,
"sub_account": 0,
"subaccount_code": "541ebc38-6bef-4d65-aefd-c3575d4e4a21",
"suspended": 0,
"user_uuid": "2952e311-cfc9-412e-9ff3-e5cb8131ed45",
"username": "Insider 1"
},
{
"email": "[email protected]",
"email_verified": 0,
"has_submitted_kyc": 1,
"insider": 1,
"institution": 0,
"is_otp_activated": 0,
"kyc_level": 0,
"master_account": 1,
"master_account_uuid": null,
"monthly_avg_trading_volumes": null,
"nationality": "ID",
"preference_pairs": null,
"pseudonym": null,
"reference_asset": null,
"restricted": 1,
"sub_account": 0,
"subaccount_code": "55e77e70-bfba-46be-aad1-dc986312da5a",
"suspended": 0,
"user_uuid": "04761f29-0288-4fff-97c8-14d58413e720",
"username": "Insider 2"
}
]
}
Request
curl "https://api.bitwyre.com/public/insider?username=<username>"
-X GET
Response
{
"error": [],
"result": {
"email": "[email protected]",
"email_verified": 0,
"has_submitted_kyc": null,
"insider": 1,
"institution": 0,
"is_otp_activated": 0,
"kyc_level": 0,
"master_account": 1,
"master_account_uuid": null,
"monthly_avg_trading_volumes": null,
"nationality": "ID",
"preference_pairs": null,
"pseudonym": null,
"reference_asset": null,
"restricted": 0,
"sub_account": 0,
"subaccount_code": "541ebc38-6bef-4d65-aefd-c3575d4e4a21",
"suspended": 0,
"user_uuid": "2952e311-cfc9-412e-9ff3-e5cb8131ed45",
"username": "Insider 1"
}
}
Returns insider user profiles info
Endpoint
https://api.bitwyre.com/public/insider
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
username | string | false | Username |
Response Types (JSON Object/Arrays)
JSON Field | Data Type | Remark |
---|---|---|
string | Insider Email | |
email_verified | boolean | 1 if email is already verified |
has_submitted_kyc | boolean | 1 if user is already submitted kyc |
insider | boolean | 1 if user is an insider |
institution | boolean | 1 if user has an institution |
is_otp_activated | boolean | 1 if user is already activated otp |
kyc_level | integer | User KYC Level |
master_account | boolean | 1 if user is a master account |
master_account_uuid | string | User Master Account UUID |
monthly_avg_trading_volumes | integer | User Monthly Average Trading Volumes |
nationality | string | User Nationality |
preference_pairs | boolean | User preference pairs |
reference_asset | array-of-string | User reference asset |
restricted | boolean | User trading status |
sub_account | boolean | 1 if user has a sub account |
subaccount_code | string | User Sub Account User Code |
suspended | boolean | User Status |
user_uuid | string | User UUID |
username | string | Username |
Insider Trades
Request
curl "https://api.bitwyre.com/public/insider/trades"
-X GET
Response
{
"error": [],
"result": [
{
"btc_usdt_spot": [
{
"exec_price": 1.21,
"exec_qty": 10.0,
"exec_type": 13,
"exec_value": 12.1,
"fee_paid": -0.015,
"fee_paid_asset": "btc",
"fee_rate": -0.0015,
"fee_type": 1,
"notes": null,
"order_price": 1.21,
"order_qty": 10.0,
"order_remaining": 0.0,
"order_type": 2,
"side": 1,
"status": 2,
"timestamp": 1609027200000000000,
"username": "Insider 1"
}
],
"eth_usdt_spot": [
{
"exec_price": 1.21,
"exec_qty": 1.0,
"exec_type": 13,
"exec_value": 12.1,
"fee_paid": 36300.0,
"fee_paid_asset": "idr",
"fee_rate": 0.003,
"fee_type": 2,
"notes": null,
"order_price": 1.21,
"order_qty": 1.0,
"order_remaining": 0.0,
"order_type": 2,
"side": 2,
"status": 2,
"timestamp": 1609027200000000000,
"username": "Insider 2"
}
]
}
]
}
Request
curl "https://api.bitwyre.com/public/insider/trades?username=<username>"
-X GET
Response
{
"error": [],
"result": [
{
"btc_usdt_spot": [
{
"exec_price": 1.21,
"exec_qty": 10.0,
"exec_type": 13,
"exec_value": 12.1,
"fee_paid": -0.015,
"fee_paid_asset": "btc",
"fee_rate": -0.0015,
"fee_type": 1,
"notes": null,
"order_price": 1.21,
"order_qty": 10.0,
"order_remaining": 0.0,
"order_type": 2,
"side": 1,
"status": 2,
"timestamp": 1609027200000000000
}
]
}
]
}
Returns user insider's trades data info
Endpoint
https://api.bitwyre.com/public/insider/trades
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
username | string | false | Username |
Response Types (JSON Arrays)
JSON Field | Data Type | Remark |
---|---|---|
exec_price | float | Order Execution Price |
exec_qty | float | Order Execution Quantity |
exec_type | integer | Order Execution Type |
exec_value | float | Order Execution Value |
fee_paid | float | Order Paid Fees |
fee_paid_asset | string | Asset of Fees |
fee_rate | float | Fees Rate |
fee_type | integer | Type of Fees |
notes | string | Order Notes |
order_price | float | Order Price |
order_qty | float | Order Quantity |
order_remaining | integer | Order Remaining Quantity |
order_type | enum-number | order type |
side | enum-number | trade type ( 1 - buy; 2 - sell) |
status | enum-number | order status |
timestamp | big-integer | unix time in nanoseconds |
Announcements
Request
curl "https://api.bitwyre.com/public/announcements" -X GET
Response
{
"error": [],
"result": {
"unixtime": 1571744594571020435,
"announcement": "halting btc_usdt_spot"
}
}
Returns announcement with the server's time.
Endpoint
https://api.bitwyre.com/public/announcements
Request Fields/Parameters
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
unixtime | big-integer | unix time in nanoseconds |
announcement | string | announcement |
Order Types
Request
curl "https://api.bitwyre.com/public/ordertypes" -X GET
Response
{
"error": [],
"result": {
"1": "Market",
"2": "Limit",
"3": "Stop",
"4": "Stop Limit"
}
}
Returns enumeration of order types
Endpoint
https://api.bitwyre.com/public/ordertypes
Request Fields/Parameters
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
result | JSON | Enumeration of order types |
Supported Languages
Request
curl "https://api.bitwyre.com/public/languages" -X GET
Response
{
"error": [],
"result": [
{
"iso639-2_code": "eng",
"language": "English"
},
{
"iso639-2_code": "rus",
"language": "Russian"
},
{
"iso639-2_code": "hin",
"language": "Hindi"
},
{
"iso639-2_code": "ind",
"language": "Bahasa Indonesia"
},
{
"iso639-2_code": "chi",
"language": "官话"
},
{
"iso639-2_code": "fra",
"language": "Français"
},
{
"iso639-2_code": "spa",
"language": "Español"
},
{
"iso639-2_code": "por",
"language": "Portugais"
}
]
}
Returns pairs of supported languages
Endpoint
https://api.bitwyre.com/public/languages
Request Fields/Parameters
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
"result" | JSON | Pairs of supported languages |
Get Search Results
Request
curl 'https://api.bitwyre.com/public/search \
-X GET
Response
{
"error": [],
"result": {
[
{"keyword": "btc_usdt_spot", "url": "https://www.bitwyre.com/terminal/btc_usdt_spot"},
{"keyword": "btc_idr_spot", "url": "https://www.bitwyre.com/terminal/btc_idr_spot"},
]
....
}
}
Retrieve search query
Endpoint
https://api.bitwyre.com/public/search
Request Fields/Parameters
None needed yet
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
Nearest neighbor search of words | string | Closest word |
... | ... | ... |
Price Index
An aggregate of an instrument's current market price, collected from multiple third party sources and major exchanges Indices are calculated by fetching orderbook per exchanges, getting their bid-ask spread, then averaging their prices. It is calculated every second by our backend. Current sources are:
- Binance
- Bitfinex
- Bitstamp
- Coinbase
- Huobi
- Okex
Request
curl "https://api.bitwyre.com/public/index?instrument=btc_usdt_spot" -X GET
Response
{
"error": [],
"result": {
"btc_usdt_spot": [
{
"price": "400000.0",
"timestamp": "2021-08-13 04:26:34.086636",
"timestamp_integer": 1628828794
},
{
"price": "500000.0",
"timestamp": "2021-08-18 05:08:29.128583",
"timestamp_integer": 1629263309
}
]
}
}
Endpoint
https://api.bitwyre.com/public/index
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"instrument" | string | true | base asset, quote asset, product filter, delimited with an _ (underscore). |
"amount" | integer | false | amount of data to be fetched |
"to_time" | integer | false | end time of data to be fetched |
"from_time" | integer | false | start time of data to be fetched |
"ascending" | boolean | false | true to sort data ascending bytime |
Notes:
- Example for instruments:
btc_usdt_spot
,eth_usdc_spot
. - If no amount is specified, endpoint will returns only 1 data, depends on whether it is ascending/descending. Current limit is 100 data points per request.
- If no to_time is specified, endpoint will fetch the latest data.
- If no from_time is specified, endpoint will try to fetch data from earliest possible point given the maximum limit of data per request.
- Default for ascending is false (
0
), ie the data is sorted descending by time, change to1
to sort ascending
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
error | list | Error messages, if any |
result | dictionaries | contain list of dictionaries of the data, grouped by instrument |
and the list of dictionaries for the results
JSON Field | Data Type | Remark |
---|---|---|
price | string | String representation of the price, up to two decimals |
timestamp | string | Human-readable UTC timestamp |
timestamp_integer | integer | UNIX timestamp, in seconds |
Search
Search ticker, trades, and depth data in one endpoint
Request
curl "https://api.bitwyre.com/public/search?country=ID" -X GET
Response
{
"error": [],
"result": {
"spot": {
"crypto": {
"btc_usdt_spot": {
"high": "11000",
"low": "10000",
"percent_change": "110.0",
"volume_base": "34",
"volume_quote": "267346.0",
"last": "10100",
"best_bid": "10075",
"best_ask": "11000",
"timestamp": 1571747594573320135,
"last_trade_price": "10000.0",
"last_trade_side": 1,
"last_trade_uuid": "752837c7-aec6-41f8-bb07-286f859f2718",
"last_trade_value": "20000.0",
"last_trade_volume": "2.0",
"last_trade_timestamp": 1571747594573320135,
"bidbook": [["310.0", "5.0"]],
"askbook": [["400.0", "2.0"]]
}
}
}
}
}
Endpoint
https://api.bitwyre.com/public/search
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"country" | string | true | two-character of country of interest (eg. US, ID, HK) |
"instrument" | string | false | Instrument of interest (eg btc_usdt_spot) |
Notes: if no instrument is specified, endpoint will return all available instrument
Response Types (JSON Object)
Returns | JSON Field | Data Type | Remark | | ---------- | --------- | -------------------------- | | error | list | Error messages, if any | | result | dictionaries | contain list of dictionaries of the data, grouped by product, market, instrument |
Please check ticker, trades, and depth endpoint documentation for explanation of the dictionary members
Matching Engine Order Lag
Request
curl "https://api.bitwyre.com/public/orderlag?instrument=<instrument>"
-X GET
Response
{
"error": [],
"result": {
"btc_usdt_spot": "1",
"eth_usdt_spot": "0"
}
}
Return order lag of matching engine per instrument (in events)
Endpoint
https://api.bitwyre.com/public/orderlag
Request Fields/Parameters
Parameter | Data Type | Required | Remark |
---|---|---|---|
instrument | string | false | Instrument of interest (eg btc_usdt_spot) |
Notes: if no instrument is specified, endpoint will return all available instrument
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
instrument | string | amount of order event lag |
Please check ticker, trades, and depth endpoint documentation for explanation of the dictionary members
Matching Engine Throughput
Request
curl "https://api.bitwyre.com/public/throughput?instrument=<instrument>"
-X GET
Response
{
"error": [],
"result": {
"Consumer": [
{
"instrument": "btc_usdt_spot",
"lag": "22",
"max_lag": "2000",
"throughput": "1000 msg/s"
},
{
"instrument": "eth_usdt_spot",
"lag": "0",
"max_lag": "2000",
"throughput": "500 msg/s"
}
],
"CreditRiskAccountManagement": [
{
"lag": "11",
},
],
"Matching": [
{
"instrument": "btc_usdt_spot",
"lag": "983",
"max_lag": "2000",
"throughput": "1000 msg/s"
},
{
"instrument": "eth_usdt_spot",
"lag": "1",
"max_lag": "2000",
"throughput": "500 msg/s"
}
],
"Producer": [
{
"instrument": "btc_usdt_spot",
"lag": "154",
"max_lag": "2000",
"throughput": "500 msg/s"
},
{
"instrument": "eth_usdt_spot",
"lag": "0",
"max_lag": "2000",
"throughput": "1000 msg/s"
}
]
}
}
Return throughput rate data of matching engine of the instrument (in events/second), in addition of consumer and max lag data of the instrument.
Endpoint
https://api.bitwyre.com/public/throughput
Request Fields/Parameters
Parameter | Data Type | Required | Remark |
---|---|---|---|
instrument | string | false | Instrument of interest (eg btc_usdt_spot) |
Notes: if no instrument is specified, endpoint will return all available instrument if no type is specified, endpoint will return all available type
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
Consumer | array-of-objects | consumer matching engine throughput rate of the instrument |
Matching | array-of-objects | mathcing engine throughput rate of the instrument |
Producer | array-of-objects | producer matching engine throughput rate of the instrument |
OTC
Request
curl "https://api.bitwyre.com/public/otc?base_asset=<base_asset>"e_asset=<quote_asset>&spread=<spread>"
-X GET
Response
{
"error": [],
"result": {
"ask_price": 59816.143336500005,
"bid_price": 19938.7144455
}
}
Return Ask Price and Bid Price real time.
Endpoint
https://api.bitwyre.com/public/otc?base_asset=btc"e_asset=usd&spread=1.0
Request Fields/Parameters
Parameter | Data Type | Required | Remark |
---|---|---|---|
base_asset | string | true | Base Asset (eg btc) |
quote_asset | string | true | Quote Asset (eg usd) |
spread | float | true | Spread parameter (eg 1.0) |
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
ask_price | float | Value of Ask Price (eg 59816.143336500005) |
bid_price | float | Value of Bid Price (eg 19938.7144455) |
Get Convert Rate
Request
curl "https://api.bitwyre.com/public/convert?from_coin=btc&to_coin=usdt&size=2&convert_uuid={convert_uuid}"
-X GET
Response
{
"error": [],
"result": {
"amount": "60000",
"convert_price": "30000",
"size": "2",
"volatility": "1.54",
}
}
Return Ask Price and Bid Price real time.
Endpoint
https://api.bitwyre.com/public/convert
Request Fields/Parameters
Parameter | Data Type | Required | Remark |
---|---|---|---|
from_coin | string | true | Asset that will be converted from |
to_coin | string | true | Asset that will be converted to |
size | string | true | Convert amount (used only if value is empty) |
value | string | true | Convert value (used only if size is empty) |
convert_uuid | string | true | Convert UUID |
Response Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
convert_price | string | Asset conversion price rate |
amount | string | Calculated amount of asset that will be received |
volatility | string | Price volatility |
Spot Product API Endpoints
Getting Spot Account Balance
Request
curl "https://api.bitwyre.com/private/account/spotbalance?nonce=17081945&checksum=<payload_checksum>&page=1&per_page=30&type=fiat&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": [
{
"asset": "aed",
"available_balance": 0,
"btc_equivalent": 0,
"constant_multiplier": 10000000,
"icon_url": "https://robin.bitwyre.id/app/Raster/AE_72px.png",
"is_deposit_enabled": false,
"is_trading_enabled": false,
"is_usd_stablecoin": false,
"is_withdraw_enabled": false,
"local_equivalent": 0,
"local_reference": "",
"locked_balance": 0,
"max_withdrawal": "0",
"min_withdrawal": "0",
"name": "UAE Dirham",
"precision": "1.00E-07",
"total_balance": 0,
"type": "fiat",
"usd_equivalent": 0,
"withdrawal_fee": "0"
},
{
"asset": "afn",
"available_balance": 0,
"btc_equivalent": 0,
"constant_multiplier": 1000000,
"icon_url": "https://robin.bitwyre.id/app/Raster/AF_72px.png",
"is_deposit_enabled": false,
"is_trading_enabled": false,
"is_usd_stablecoin": false,
"is_withdraw_enabled": false,
"local_equivalent": 0,
"local_reference": "",
"locked_balance": 0,
"max_withdrawal": "0",
"min_withdrawal": "0",
"name": "Afghani",
"precision": "1.00E-06",
"total_balance": 0,
"type": "fiat",
"usd_equivalent": 0,
"withdrawal_fee": "0"
}
// ... and all other asset balances
],
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 8,
"prev_page": null,
"total_count": 16
}
}
Retrieve all user's fiat and crypto balance.
Endpoint
https://api.bitwyre.com/private/account/spotbalance
Request Fields/Parameters
Because this is a GET endpoint, nonce
& checksum
are query parameters, also payload
should be always an empty string.
The SHA256
steps for this endpoint's payload:
- jsonify an empty string.
- then SHA256 from above result.
Please refer to Authentication.
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
use_pagination | bool | false | Default is 1. To turn off the pagination set use_pagination=0 |
asset | str | false | Eg. asset=btc to retrieve only btc balance |
type | str | false | crypto or fiat to retrieve balance by type |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
asset | string | asset |
available_balance | float | available asset balance |
constant_multiplier | integer | asset constant multiplier |
icon_url | string | asset icon image url |
is_deposit_enabled | bool | true if asset deposit is enabled |
is_trading_enabled | bool | true if asset trade is enabled |
is_withdraw_enabled | bool | true if asset withdraw is enabled |
btc_equivalent | integer | balance in bitcoin |
local_equivalent | integer | balance in local reference |
local_reference | string | local reference asset |
locked_balance | integer | amount of locked balance |
max_withdrawal | string | maximum amount of withdrawal |
min_withdrawal | string | minimum amount of withdrawal |
name | string | name of asset |
precision | string | precision of asset |
total_balance | integer | amount of total balance |
type | string | type of asset (crypto/fiat) |
usd_equivalent | integer | asset equivalent in USD |
withdrawal_fee | string | asset withdrawal fees |
is_usd_stablecoin | false | true if asset is usd stablecoin |
Moving Spot Account Balance to Derivatives Account Balance
Request
curl "https://api.bitwyre.com/private/account/spotbalance?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X POST
Response
{
"error": [],
"result": [
{
"asset": "btc",
"amount": 100,
"to_derivatives": true,
"to_spot": false,
"success": true
},
{
"asset": "usdt",
"amount": 100,
"to_derivatives": true,
"to_spot": false,
"success": true
}
]
}
Move a user's fiat and crypto balance for derivatives trading.
Endpoint
https://api.bitwyre.com/private/account/spotbalance
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | true | the asset to be moved from the spot balance to the derivatives account balance |
amount | integer | true | the amount of the asset to be moved from the spot balance to the derivatives account balance (in the currency's normal unit e.g bitcoin, ether) |
Please refer to Authentication.
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
asset | string | name of asset |
amount | integer | asset amount moved |
to_derivatives | boolean | if the direction is spot -> derivatives |
to_spot | boolean | if the direction is derivatives -> spot |
success | boolean | if the move operation is a success |
Getting Account Statement
Request
curl "https://api.bitwyre.com/private/account/statement?nonce=17081945&checksum=<payload_checksum>&asset=idr&payload={\"assets\": [\"btc\", \"idr\"]}&page=1&per_page=5" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"deposit": {
"brl": [],
"btc": [
{
"fee": 5e-5,
"gross_amount": 0.01,
"id": 4,
"nett_amount": 0.00995,
"network_confirmation": 0,
"provider": "duitku",
"status": "pending",
"submit_time": 1571747594573320135,
"success_time": 0,
"transaction_id": "26a13a32-2e11-472a-84cc-242d765a88dg",
"tx_id": "26a13a32-2e11-472a-84cc-242d765a88dg",
"type": "crypto"
}
],
"eth": [],
"idr": [
{
"centralized_confirmation": 0,
"fee": 1000.0,
"gross_amount": 5000.0,
"id": 5,
"nett_amount": 4000.0,
"provider": "duitku",
"status": "pending",
"submit_time": 1571747594573320135,
"success_time": 0,
"transaction_id": "26a13a32-2e11-472a-84cc-242d765a88dg",
"type": "fiat"
}
],
"mxn": [],
"usd": [],
"usdt": [],
"xmr": [],
"zec": []
},
"withdrawal": {
"brl": [],
"btc": [
{
"fee": 5e-5,
"gross_amount": 0.01,
"id": 6,
"nett_amount": 0.00995,
"network_confirmation": 0,
"provider": "duitku",
"status": "pending",
"submit_time": 1571747594573320135,
"success_time": 0,
"transaction_id": "26a13a32-2e11-472a-84cc-242d765a88dj",
"tx_id": "26a13a32-2e11-472a-84cc-242d765a88dj",
"type": "crypto"
}
],
"eth": [],
"idr": [
{
"centralized_confirmation": 0,
"fee": 1000.0,
"gross_amount": 10000.0,
"id": 1,
"nett_amount": 9000.0,
"provider": "duitku",
"status": "pending",
"submit_time": 1571747594573320135,
"success_time": 0,
"transaction_id": "26a13a32-2e11-472a-84cc-242d765a88de",
"type": "fiat"
},
{
"centralized_confirmation": 0,
"fee": 1000.0,
"gross_amount": 5000.0,
"id": 3,
"nett_amount": 4000.0,
"provider": "duitku",
"status": "pending",
"submit_time": 1571747594573320135,
"success_time": 0,
"transaction_id": "26a13a32-2e11-472a-84cc-242d765a88df",
"type": "fiat"
}
],
"mxn": [],
"usd": [],
"usdt": [],
"xmr": [],
"zec": []
}
},
"meta": {
"has_next": false,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 1,
"prev_page": null,
"total_count": 6
}
}
Retrieve user's withdraw and deposit history.
Endpoint
https://api.bitwyre.com/private/account/statement
Request Fields/Parameters
Because this is a GET endpoint, nonce
& checksum
are query parameters, also payload
should be always an empty string.
The SHA256
steps for this endpoint's payload:
- jsonify an empty string.
- then SHA256 from above result.
Please refer to Authentication.
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Request Payload Fields
When no payload specified, it will return all statements
Payload Fields | Value | Required | Description |
---|---|---|---|
assets | list | false | list of assets for the statements |
Please refer to Authentication.
Response Base Structure
JSON Field | Data Type | Remark |
---|---|---|
withdrawal | asset-statement-object | historical withdrawal data for specific asset (array). |
deposit | asset-statement-object | historical deposit data for specific asset (array). |
Getting User Withdrawal Fees
Request (All Instruments)
curl "https://api.bitwyre.com/private/account/fees/withdrawal?nonce=17081945&checksum=<payload_checksum>&payload={\"asset\":\"all\"}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response (All Instruments)
{
"error": [],
"result": {
"btc": {
"global_fee": "0.0001",
"user_fee": "0.0001"
},
"eth": {
"global_fee": "0.001",
"user_fee": "0.001"
}
}
}
Request (One Instrument)
curl "https://api.bitwyre.com/private/account/fees/withdrawal?nonce=17081945&checksum=<payload_checksum>&payload={\"asset\":\"btc\"}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response (One Instrument)
{
"error": [],
"result": {
"btc": {
"global_withdrawal_fee": "0.0001",
"user_withdrawal_fee": "0.0001"
}
}
}
Retrieve user's withdraw fees.
Endpoint
https://api.bitwyre.com/private/account/fees/withdrawal
Request Payload Fields
When no payload specified, it will return all statements
Payload Fields | Value | Required | Description |
---|---|---|---|
asset | string | true | Crypto asset, e.g btc , eth . |
Please refer to Authentication.
Response Base Structure
Dictionary of asset
and it's withdrawal fees data, withdrawal fees fields:
JSON Field | Data Type | Remark |
---|---|---|
global_withdrawal_fee | string | withdrawal fees data for specific asset |
user_withdrawal_fee | string | withdrawal fees data for specific user |
Getting Transaction Histories
Request
curl `https://api.bitwyre.com/private/account/transactions?nonce=17081945&checksum=<payload_checksum>&type=all&asset=all&page=1&per_page=50` \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"deposit": {
"idr": [
{
"account_balance_id": 1,
"address": "thisisaddress",
"amount": "100000000.0",
"asset": "idr",
"fee": "0.0",
"final_balance": "1100000000.0",
"notes": "",
"status": "Cancelled",
"time": 1618206392203845000,
"type": 1
}
],
"btc": [
{
"account_balance_id": 2,
"address": "thisisaddress",
"amount": "1.0",
"asset": "btc",
"fee": "0.0",
"final_balance": "10.0",
"notes": "",
"status": "Cancelled",
"time": 1618206125002066000,
"type": 1
}
]
// ... other coins
},
"withdrawal": {
"btc": [
{
"account_balance_id": 4,
"address": "thisisaddress",
"amount": "-1.0",
"asset": "btc",
"fee": "0.0",
"final_balance": "9.0",
"notes": "",
"status": "Pending",
"time": 1617974544507879000,
"type": 2
}
],
"idr": [
{
"account_balance_id": 3,
"address": "thisisaddress",
"amount": "-1000.0",
"asset": "idr",
"fee": "0.0",
"final_balance": "1099999000.0",
"notes": "",
"status": "Pending",
"time": 1618207558627212000,
"type": 2
}
]
// ... other coins
},
"clearing": {
"idr": [
{
"account_balance_id": 5,
"address": "thisisaddress",
"amount": "-1000.0",
"asset": "BTC IDR spot clearing",
"fee": "0.0",
"final_balance": "1099999000.0",
"notes": "",
"status": "Pending",
"time": 1618207558627212000,
"type": 3
}
],
"btc": [
{
"account_balance_id": 3,
"address": "thisisaddress",
"amount": "-1000.0",
"asset": "BTC IDR spot clearing",
"fee": "0.0",
"final_balance": "1099999000.0",
"notes": "",
"status": "Pending",
"time": 1618207558627212000,
"type": 3
}
]
// ... other coin clearing
}
},
"meta": {
"has_next": false,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 1,
"prev_page": null,
"total_count": 6
}
}
Retrieve user's withdraw, deposit, and clearing history.
Endpoint
https://api.bitwyre.com/private/account/transactions
Request Fields/Parameters
Parameter | Value | Required | Description |
---|---|---|---|
type | string | false | Type of transaciton (all, deposit, withdrawal, clearing). Default all |
asset | string | false | Supported crypto/fiat asset. Default all |
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Please refer to Authentication.
Response Base Structure
JSON Field | Data Type | Remark |
---|---|---|
withdrawal | asset-statement-object | historical withdrawal data for specific asset (array). |
deposit | asset-statement-object | historical deposit data for specific asset (array). |
clearing | asset-statement-object | historical clearging data for specific asset (array). |
Getting Order Quantity Percentage
Example
curl "https://api.bitwyre.com/private/orders/qty-percentage?order_type=2&order_side=1&price=20000&instrument=btc_usdt_spot" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET
Response
{
"error": [],
"result": {
"1%": "0.00002",
"2%": "0.00005",
"3%": "0.00008",
"4%": "0.00010",
"5%": "0.00012",
"6%": "0.00015",
"7%": "0.00018",
"8%": "0.00020",
"9%": "0.00022",
"10%": "0.00025",
"11%": "0.00028",
"12%": "0.00030",
"13%": "0.00032",
"14%": "0.00035",
"15%": "0.00038",
"16%": "0.00040",
"17%": "0.00042",
"18%": "0.00045",
"19%": "0.00048",
"20%": "0.00050",
"21%": "0.00052",
"22%": "0.00055",
"23%": "0.00058",
"24%": "0.00060",
"25%": "0.00062",
"26%": "0.00065",
"27%": "0.00068",
"28%": "0.00070",
"29%": "0.00072",
"30%": "0.00075",
"31%": "0.00078",
"32%": "0.00080",
"33%": "0.00082",
"34%": "0.00085",
"35%": "0.00088",
"36%": "0.00090",
"37%": "0.00092",
"38%": "0.00095",
"39%": "0.00098",
"40%": "0.00100",
"41%": "0.00102",
"42%": "0.00105",
"43%": "0.00108",
"44%": "0.00110",
"45%": "0.00112",
"46%": "0.00115",
"47%": "0.00118",
"48%": "0.00120",
"49%": "0.00122",
"50%": "0.00125",
"51%": "0.00128",
"52%": "0.00130",
"53%": "0.00132",
"54%": "0.00135",
"55%": "0.00138",
"56%": "0.00140",
"57%": "0.00142",
"58%": "0.00145",
"59%": "0.00148",
"60%": "0.00150",
"61%": "0.00152",
"62%": "0.00155",
"63%": "0.00158",
"64%": "0.00160",
"65%": "0.00162",
"66%": "0.00165",
"67%": "0.00168",
"68%": "0.00170",
"69%": "0.00172",
"70%": "0.00175",
"71%": "0.00178",
"72%": "0.00180",
"73%": "0.00182",
"74%": "0.00185",
"75%": "0.00188",
"76%": "0.00190",
"77%": "0.00192",
"78%": "0.00195",
"79%": "0.00198",
"80%": "0.00200",
"81%": "0.00202",
"82%": "0.00205",
"83%": "0.00208",
"84%": "0.00210",
"85%": "0.00212",
"86%": "0.00215",
"87%": "0.00218",
"88%": "0.00220",
"89%": "0.00222",
"90%": "0.00225",
"91%": "0.00228",
"92%": "0.00230",
"93%": "0.00232",
"94%": "0.00235",
"95%": "0.00238",
"96%": "0.00240",
"97%": "0.00242",
"98%": "0.00245",
"99%": "0.00248",
"100%": "0.00250"
},
}
Retrieve user's possible order amount/quantity from 1-100% based on price, order type and order side
Endpoint
https://api.bitwyre.com/private/orders/qty-percentage
Request Fields/Parameters
Parameter | Value | Required | Description |
---|---|---|---|
order_type | int | true | Order's Type. See Order Type |
order_side | int | true | Order's Side. See Order Size |
instrument | str | true | base asset, quote asset, product filter, delimited with an _ (underscore). |
price | str | false | Order's Price. Not required for Market-type orders |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
n-percentage | string | Order Quantity Amount at n% |
Opening a New Order
Example: New Market Order
curl "https://api.bitwyre.com/private/orders" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"instrument\": \"btc_usdt_spot\",\
\"side\": 2,\
\"ordtype\": 1,\
\"orderqty\": \"2.9301\",\
}\
}"
Response (Execution Report)
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 0,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdt_spot",
"leavesqty": "2.9301",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "2.9301",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 2,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Example: New Limit Order
curl "https://api.bitwyre.com/private/orders" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"instrument\": \"btc_usdt_spot\",\
\"side\": 1,\
\"ordtype\": 2,\
\"price\": \"9800.5\",\
\"orderqty\": \"2.9301\",\
}\
}"
Response (Execution Report)
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 0,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdt_spot",
"leavesqty": "2.9301",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "2.9301",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 2,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "9800.5",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Example: New Stop Order
curl "https://api.bitwyre.com/private/orders" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"instrument\": \"btc_usdt_spot\",\
\"side\": 2,\
\"ordtype\": 3,\
\"stoppx\": \"9850.35\",\
\"orderqty\": \"2.9301\",\
}\
}"
Response (Execution Report)
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 0,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdt_spot",
"leavesqty": "2.9301",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "2.9301",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "0",
"side": 2,
"stoppx": "9850.35",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Example: New Stop-Limit Order
curl "https://api.bitwyre.com/private/orders" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"instrument\": \"btc_usdt_spot\",\
\"side\": 1,\
\"ordtype\": 4,\
\"price\": \"9800.5\",\
\"stoppx\": \"9750\",\
\"orderqty\": \"2.9301\",\
}\
}"
Response (Execution Report)
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 0,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdt_spot",
"leavesqty": "2.9301",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "2.9301",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 4,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "9800.5",
"side": 1,
"stoppx": "9750",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Create a new buy/sell order
Endpoint
https://api.bitwyre.com/private/orders
Create Order Payload
JSON Field | Value | Required | Description |
---|---|---|---|
clordid | uuid-string | false | client generated uuid string, no mandatory. |
instrument | string | true | base asset, quote asset, product filter, delimited with an _ (underscore). |
side | enum-number | true | side of order, currently only supports buy (1) or sell (2) . |
ordtype | enum-number | true | Supports market (1) , limit (2) , stop (3) , or stop_limit (4) order, post only (19), market IOC (20), limit IOC (21), and FOK (22) |
price | float-string | false | mandatory for limit and stop_limit order. |
stoppx | float-string | false | mandatory for stop and stop_limit order. |
orderqty | float-string | true | order quantity for the base asset. |
timeinforce | enum-number | false | order lifetime enforcement, see Time In Force. |
expiretime | big-integer | false | mandatory when "timeinforce" is set to gtd , unix time in nanoseconds. |
execinst | string | false | not-yet-supported, reserved for future. |
cancelondisconnect | bool | false | cancel order on disconnection, not supported in REST (yet). |
One must make sure that price, quantity and also value are in the the currency unit that are from the base and quote pairs. For example if the instrument is btc_usdt_spot
, the quantity is btc
and the price and value are in usdt
. Note that our clearing engine does clearing inside our database based on 64-bit integer computations. Thus, to reduce the amount of increment errors, we also highly suggest you to compute the quantity in the smallest unit of the base asset and the value in the smallest unit of the quote asset. For the previous example of btc_usdt_spot
the smallest unit of btc
is satoshi, 10^-8 of a btc
, and for usdt
it is 10^-6 of a usdt
. For a quantity of 1 btc
we will process in our backend in the integer 100,000,000
and for
1 usdtit will be
1,000,000`. This is the same for Monero (piconero) and ZCash (zatoshi), the exception is only for Ethereum, where we use GWei in our backend computations.
Getting Open Orders
Request
Getting specific open orders
curl 'https://api.bitwyre.com/private/orders/open?nonce=17081945&checksum=<payload_checksum>&payload={"instrument":"btc_usdt_spot", "from_time": 1593487780108470000, "to_time": 1593487786824088000 }&page=1&per_page=1' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Getting all open orders
curl 'https://api.bitwyre.com/private/orders/open/all?nonce=17081945&checksum=<payload_checksum>&payload=&page=1&per_page=1' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_usdt_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdt_spot",
"leavesqty": "1",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "1",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
]
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Retrieves curent open orders.
Endpoint
https://api.bitwyre.com/private/orders/open
https://api.bitwyre.com/private/orders/open/all
Request Payload Fields
When no payload specified, it will return all orders symbols that currently in open position. Otherwise on /open/all
it automatically returns all open order, no payload necessary
Payload Fields | Value | Required | Description |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
from_time | int | false | nanosecond timestamp for oldest order to be enumerated. |
to_time | int | false | nanosecond timestamp for newest order to be enumerated. |
Request Parameters
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Data
A dictionary, where the keys are the symbols and the values are an array of currently open order(s), see Execution report Response.
Getting Closed Orders
Request
Getting specific closed order
curl 'https://api.bitwyre.com/private/orders/closed?nonce=17081945&checksum=<payload_checksum>&payload={"instrument":"btc_usdt_spot", "from_time": 1593487780108470000, "to_time": 1593487786824088000}?page=1&per_page=5' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Getting all closed order
curl 'https://api.bitwyre.com/private/orders/closed/all?nonce=17081945&checksum=<payload_checksum>&page=1&per_page=3' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_idr_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "1",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "1",
"ordrejreason": "",
"ordstatus": 1,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
},
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "1",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc1",
"orderqty": "1",
"ordrejreason": "",
"ordstatus": 1,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc1",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc1",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 2345676543246,
"transacttime": 0,
"value": "100.0"
}
],
"btc_usd_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usd_spot",
"leavesqty": "1",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "1",
"ordrejreason": "",
"ordstatus": 1,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "0.1",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "1.0"
}
]
},
"meta": {
"has_next": true,
"has_prev": true,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 15
}
}
Retrieves currently closed orders. Similar to order history.
Endpoint
https://api.bitwyre.com/private/orders/closed
https://api.bitwyre.com/private/orders/closed/all
Request Payload Fields
For showing closed order based on parameters on /closed
. Otherwise on /closed/all
it automatically returns all closed order, no payload necessary
Payload Fields | Value | Required | Description |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
from_time | int | false | nanosecond timestamp for oldest order to be enumerated. |
to_time | int | false | nanosecond timestamp for newest order to be enumerated. |
Request Parameters
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Data
A dictionary, where the keys are the symbols and the values are an array of currently closed order(s), see Execution report Response.
Getting All Cancelled Orders
Request
curl 'https://api.bitwyre.com/private/orders/cancelled?nonce=17081945&checksum=<payload_checksum>&payload=' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_idr_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 4,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
],
"btc_usd_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usd_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 4,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "0.1",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "1.0"
}
]
}
}
Retrieves all cancelled orders. Similar to order history.
Endpoint
https://api.bitwyre.com/private/orders/cancelled
Request Payload Fields
This API does not require request payload
Response Data
A dictionary, where the keys are the symbols and the values are an array of currently cancelled order(s), see Execution report Response.
Getting Order Info
Request
Getting one specific order detail
curl "https://api.bitwyre.com/private/orders/info/732f066e-feed-baad-beef-e000ed83243a?nonce=17081945&checksum=<payload_checksum>&payload=&page=1&per_page=1" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Getting all orders details
curl "https://api.bitwyre.com/private/orders/info/all?nonce=<nonce>&checksum=<checksum>&payload=&page=1&per_page=1" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
Getting orders details
{
"error": [],
"result": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fb",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "1e-06",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "5500.0",
"instrument": "btc_idr_spot",
"leavesqty": "9e-06",
"orderid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fc",
"orderqty": "1e-05",
"ordrejreason": "",
"ordstatus": 1,
"ordstatusReqID": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fe",
"ordtype": 1,
"origclid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fd",
"price": "5000.0",
"side": 1,
"stoppx": "6000.0",
"time_in_force": 0,
"timestamp": 1231123123,
"transacttime": 123123,
"value": "5000000.0"
}
],
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Retrieves information on a specific order or all orders.
Endpoint
https://api.bitwyre.com/private/orders/info/:order_id
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
order_id | uuid | True | specific order_id to get info from. When specified as all , the endpoint will return all orders (open and closed) |
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Data
See Execution report Response.
Getting Order Histories
Request
curl 'https://api.bitwyre.com/private/orders/histories?nonce=17081945&checksum=<payload_checksum>&payload={"instrument":"btc_usdt_futures", "from_time": 1593487780108470000, "to_time": 1593487786824088000}&page=1&per_page=1' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_usdt_futures": [
{
"cancel_order_id": "",
"filled": "1",
"instrument": "btc_usd_spot",
"order_id": 1,
"remaining": "1",
"fill_price": "1000",
"status": 1,
"time": 123123
}
]
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Retrieves all order histories for current instrument.
Endpoint
https://api.bitwyre.com/private/orders/histories
Request Fields
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Request Payload Fields
When no payload specified, it will return all order histories.
Payload Fields | Value | Required | Description |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
from_time | int | false | nanosecond timestamp for oldest order to be enumerated. |
to_time | int | false | nanosecond timestamp for newest order to be enumerated. |
Getting Order Journey
Request
curl 'https://api.bitwyre.com/private/orders/journey?nonce=17081945&checksum=<payload_checksum>&payload={"order_id":"da5f12ea-8c7c-4cab-83a2-c21912aa51e9"}' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"da5f12ea-8c7c-4cab-83a2-c2191": [
{
"cancel_order_id": "",
"qty": "10000", // total number of order requested
"filled": "8500",
"instrument": "btc_usd_spot",
"order_id": "da5f12ea-8c7c-4cab-83a2-c2191",
"remaining": "1500",
"cancelled": "0",
"accumulated_percentage": "85%",
"incremental_percentage": "85%",
"status": 1,
"time": 1621570548809209000
},
{
"cancel_order_id": "",
"qty": "10000", // total number of order requested
"filled": "9000",
"instrument": "btc_usd_spot",
"order_id": "da5f12ea-8c7c-4cab-83a2-c2191",
"remaining": "1000",
"cancelled": "0",
"accumulated_percentage": "90%",
"incremental_percentage": "5%",
"status": 1,
"time": 1621570557593313000
}
]
}
}
Retrieves all order histories for current order_id
Endpoint
https://api.bitwyre.com/private/orders/journey
Request Payload Fields
When no payload specified, it will return all order histories.
Payload Fields | Value | Required | Description |
---|---|---|---|
order_id | string | true | Order UUID |
Cancelling an Open Order or All Open Orders
Request
curl "https://api.bitwyre.com/private/orders/cancel?nonce=17081945&checksum=<payload_checksum>&payload={'order_ids':['a9e3d010-3169-489d-9063-ced912b0fdc9', 'a9e3d010-3169-489d-9063-ced912b0fdc9'], 'qtys':[1, 3]}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 5,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 6,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Cancels a specific order.
Endpoint
https://api.bitwyre.com/private/orders/cancel/
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
order_ids | list | True | list of order_id s to cancel. When specified as an empty list, the endpoint will cancel all open orders |
qtys | list | True | list of qtys to cancel corresponding to the order_id s with the same list index |
When qtys
specified as an empty list, the endpoint will cancel max amount on every order_id
s , when only one is specified, endpoint will cancel every order_id
s to that amount, if -1
is specified, it cancels all amount
Response Data
See Execution report Response.
Cancelling an Open Order per Instrument
Request
curl "https://api.bitwyre.com/private/orders/cancel/instrument/btc_usdt_spot?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 5,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdt_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 6,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Cancels all open orders for a specific instrument.
Endpoint
https://api.bitwyre.com/private/orders/cancel/instrument/<string:instrument>
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
instrument | string | True | specific instrument |
Response Data
See Execution report Response.
Closing an Open Positions or All Open Positions
Request
curl "https://api.bitwyre.com/private/position/close?nonce=17081945&checksum=<payload_checksum>&payload={'position_ids':['a9e3d010-3169-489d-9063-ced912b0fdc9', 'a9e3d010-3169-489d-9063-ced912b0fdc9']}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 5,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 6,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Closing a specific position or all positions.
Endpoint
https://api.bitwyre.com/private/positions/close/
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
position_ids | list | True | list of position_id s to close. When specified as an empty list, the endpoint will close all open positions |
Response Data
See Execution report Response.
Closing Open Positions per Instrument
Request
curl "https://api.bitwyre.com/private/positions/closed/instrument/btcusdx_perp_futures?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 5,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdt_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 6,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Closes all open position for a specific instrument.
Endpoint
https://api.bitwyre.com/private/position/closed/instrument/<string:derivatives_instrument>
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
instrument | string | True | specific instrument |
Response Data
See Execution report Response.
Getting Trade History
curl 'https://api.bitwyre.com/private/trades?nonce=17081945&checksum=<payload_checksum>&payload={"count": 2, "from_time": 1509225871147236500, "to_time": 1709225871147236500, "instrument":"btc_usd_spot"}&page=1&per_page=2' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_usd_spot": [
{
"exec_price": 20.0,
"exec_qty": 1.0,
"exec_type": 1,
"exec_value": 20000.0,
"fee_paid": 0.005, # if positive, it is rebate
"fee_rate": 0.0001,
"fee_type": 1,
"notes": "insert notes",
"order_price": 0,
"order_qty": 0,
"order_remaining": 0,
"order_type": 1,
"order_uuid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fd",
"side": 1,
"status": 1,
"symbol": "btc_usd_spot",
"timestamp": 123123,
"user_uuid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fb"
},
{
"exec_price": 20.0,
"exec_qty": 1.0,
"exec_type": 1,
"exec_value": 20000.0,
"fee_paid": 0.005, # if positive, it is rebate
"fee_rate": 0.0001,
"fee_type": 1,
"notes": "insert notes",
"order_price": 0,
"order_qty": 0,
"order_remaining": 0,
"order_type": 1,
"order_uuid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fe",
"side": 1,
"status": 1,
"symbol": "btc_usd_spot",
"timestamp": 123123,
"user_uuid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fb"
}
]
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 10
}
}
Retrieves some latest buying/selling transaction history.
Endpoint
https://api.bitwyre.com/private/trades
Request Payload Fields
JSON Field | Data Type | Required | Remark |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
count | number | false | limit the latest historical trade data. |
from_time | big-integer | false | inclusive historical time offset, unixtime in nanoseconds. |
to_time | big-integer | false | exclusive historical time limit, unixtime in nanoseconds. |
Request Parameters
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Types
Dictionary of instrument
and it's trades info, trade info fields:
JSON Field | Data Type | Remark |
---|---|---|
id | uuid-string | universal unique id of the trade. |
time | big-integer | Trade time, unixtime in nanoseconds. |
type | enum-string | "buy" for buy, "sell" for sell. |
price | float-string | quote price for the base asset of the trade. |
volume | float-string | base asset amount of the trade. |
total | float-string | total quote value of the trade. |
fee_percentage | float-string | percentage of the fee. |
fee | float-string | fee value. |
fee_currency | string | asset of the fee, in most case is the quote asset. |
Getting Trading Notifications
Example: Get All Notifications
curl "https://api.bitwyre.com/private/account/notifications/trading"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
}"
-X GET
Response
{
"error": [],
"result": [
{
"OrderRejected": [
{
"notification_message": "Notification Message OrderRejected #2",
"timestamp": 1638408842500649920
},
{
"notification_message": "Notification Message OrderRejected #1",
"timestamp": 1638408841588082866
}
],
"OrderCancelled": [
{
"notification_message": "Notification Message OrderCancelled #3",
"timestamp": 1638408842505009193
},
{
"notification_message": "Notification Message OrderCancelled #2",
"timestamp": 1638408842409370461
},
{
"notification_message": "Notification Message OrderCancelled #1",
"timestamp": 1638408842315787091
}
],
"OrderFilled": [
{
"notification_message": "Notification Message OrderFilled #1",
"timestamp": 1638408841987827578
}
],
"Deposit": [
{
"notification_message": "Notification Message Deposit #1",
"timestamp": 1638408842290246580
}
],
"Withdrawal": [
{
"notification_message": "Notification Message Withdrawal #2",
"timestamp": 1638408842131569666
},
{
"notification_message": "Notification Message Withdrawal #1",
"timestamp": 1638408842048839032
}
],
"KYC": [
{
"notification_message": "Notification Message KYC #1",
"timestamp": 1638408842230728389
}
]
}
]
}
Example: Get Specific Notifications
curl "https://api.bitwyre.com/private/account/notifications/trading?trading_notification_type=0?limit=2"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
}"
-X GET
Response
{
"error": [],
"result": [
{
"OrderRejected": [
{
"notification_message": "Notification Message OrderRejected #2",
"timestamp": 1638408842500649920
},
{
"notification_message": "Notification Message OrderRejected #1",
"timestamp": 1638408841588082866
}
]
}
]
}
Endpoint
https://api.bitwyre.com/private/account/notifications/trading
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
trading_notification_type | integer | False | Type of notification. Default all . See Trading Notification Type |
limit | integer | False | No of notifications per type. Default `100 (max) |
Response Data (Array of JSON Object)
An array of JSON object, where the keys of the object are notification type names and the values are an array of object with the following specifications.
JSON Field | Data Type | Remark |
---|---|---|
notification_message | string | Content of notification message |
timestamp | integer | Unixtime nanosecond timestamp |
Search Favorites
Search ticker, trades, and depth data of pairs in one endpoint
Request
curl "https://api.bitwyre.com/private/favorites?instruments=['btc_usdt_spot']" -X GET
Response
{
"error": [],
"result": {
"favorites": [
{
"btc_usdt_spot": {
"askbook": [["400.0", "2.0"]],
"best_ask": "11000",
"best_bid": "10075",
"bidbook": [["310.0", "5.0"]],
"high": "11000",
"last": "10100",
"last_trade_price": "10000.0",
"last_trade_side": 1,
"last_trade_timestamp": 1571747594573320135,
"last_trade_uuid": "752837c7-aec6-41f8-bb07-286f859f2718",
"last_trade_value": "20000.0",
"last_trade_volume": "2.0",
"low": "10000",
"percent_change": "110.0",
"timestamp": 1571747594573320135,
"volume_base": "34",
"volume_quote": "267346.0"
}
}
]
}
}
Endpoint
https://api.bitwyre.com/private/favorites
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
instruments | list | false | Instruments of interest (eg ['btc_usdt_spot','eth_usdt_spot']) |
Notes: if no instrument is specified, endpoint will return all available instrument
Response Types (JSON Object)
Returns
JSON Field | Data Type | Remark |
---|---|---|
error | list | Error messages, if any |
result | dictionaries | contain list of dictionaries of the data, grouped by product, market, instrument |
Please check ticker, trades, and depth endpoint documentation for explanation of the dictionary members
Derivatives API Endpoints
Get Account Collaterals
Example:
curl "https://api.bitwyre.com/private/derivatives/account" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET
Response
{
"error" : [],
"result" :
{
"collateral": {"usd": "91275.565", "idr": "0"},
"free_collateral": {"usd": "91275.565", "idr": "0"},
"total_acount_value": {"usd": "91275.565", "idr": "0"},
"unrealized_pnl": {"usd": "0", "idr": "0"},
"maintenance_margin_requirements": "0.03",
"initial_margin_fraction": "1.0",
"margin_fraction": "nan",
"open_margin_fraction": "0",
"liquidating": 0,
"backstop_provider": 0,
}
}
Get Account Collateral Informations
Endpoint
https://api.bitwyre.com/private/derivatives/account
Get Leverage
Example:
curl "https://api.bitwyre.com/private/derivatives/leverage?instrumet=btc_usdx_futures_perp" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET
Response
{
"error" : [],
"result":
{ "current_leverage": 3, "instrument": "btc_usdx_futures_perp" }
}
Get Current Leverage
Endpoint
https://api.bitwyre.com/private/derivatives/leverage
Change Leverage
Example:
curl "https://api.bitwyre.com/private/derivatives/leverage?instrumet=btc_usdx_futures_perp" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"instrument\": \"btc_usdx_futures_perp\",\
\"leverage\": 4,\
}\
}"
Response
{
"error" : [],
"result":
{
"message": "Leverage has been set to 4x successfully",
"new_leverage": 4,
"old_leverage": 1,
"success": true
}
}
Change Current Leverage
Endpoint
https://api.bitwyre.com/private/derivatives/leverage
Get Open Positions
Example:
curl "https://api.bitwyre.com/private/derivatives/positions?instrumet=btc_usdx_futures_perp&page=1&per_page=50" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET
Response
{
"error" : [],
"meta": {
"has_next": false,
"has_prev": false,
"next_page": null,
"prev_page": null,
"page": 1,
"pages": 1,
"total_count": 1,
},
"result":
{
"btc_usdx_futures_perp": {
"instrument": "btc_usdx_futures_perp",
"position_uuid": "dfc8e496-30c8-49d4-9f41-8fbb8c549efe",
"index_name": "BTC-USD",
"side": 1,
"leverage": 10,
"derivatives_type": 1,
"next_funding": "0.481944",
"next_funding_datetime": "1685525465.481945",
"expiry": "0",
"margin_fraction": "0.29688",
"maintenance_margin_requirements": "0.03",
"size": "20",
"notional_size": "400000",
"average_price": "19000",
"bankruptcy_price": "13060",
"liquidation_price": "16872",
"collateral_used": "41000",
"expiry_price": "0",
"realized_pnl": "0",
"unrealized_pnl": "20000",
"status": 1,
}
}
}
Get Open Positions
Endpoint
https://api.bitwyre.com/private/derivatives/positions
Reduce Position SIze
Example:
curl "https://api.bitwyre.com/private/derivatives/reduce" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"position_uuid\": \"dfc8e496-30c8-49d4-9f41-8fbb8c549ef\",\
\"size\": \"1\",\
}\
}"
Response
{
"error" : [],
"result": {
"leverage": 1,
"refrreal_code": "xr8gjhq",
"last_price": "27000",
"entry_price": "26000",
"position": "LONG",
"roe": "0.001"
}
}
Reduce Positions Size
Endpoint
https://api.bitwyre.com/private/derivatives/reduce
Close Position
Example:
curl "https://api.bitwyre.com/private/derivatives/close" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"position_uuid\": \"dfc8e496-30c8-49d4-9f41-8fbb8c549ef\",\
}\
}"
Response
{
"error" : [],
"result": {
"leverage": 1,
"refrreal_code": "xr8gjhq",
"last_price": "27000",
"entry_price": "26000",
"position": "LONG",
"roe": "0.001"
}
}
Reduce Positions Size
Endpoint
https://api.bitwyre.com/private/derivatives/reduce
Opening a New Order
Example: New Market Order
curl "https://api.bitwyre.com/private/orders" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"instrument\": \"btc_usdx_futures_perp\",\
\"side\": 2,\
\"ordtype\": 1,\
\"orderqty\": \"2.9301\",\
}\
}"
Response (Execution Report)
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 0,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdx_futures_perp",
"leavesqty": "2.9301",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "2.9301",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 2,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Example: New Limit Order
curl "https://api.bitwyre.com/private/orders" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"instrument\": \"btc_usdx_futures_perp\",\
\"side\": 1,\
\"ordtype\": 2,\
\"price\": \"9800.5\",\
\"orderqty\": \"2.9301\",\
}\
}"
Response (Execution Report)
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 0,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdx_futures_perp",
"leavesqty": "2.9301",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "2.9301",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 2,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "9800.5",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Example: New Stop Order
curl "https://api.bitwyre.com/private/orders" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"instrument\": \"btc_usdx_futures_perp\",\
\"side\": 2,\
\"ordtype\": 3,\
\"stoppx\": \"9850.35\",\
\"orderqty\": \"2.9301\",\
}\
}"
Response (Execution Report)
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 0,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdx_futures_perp",
"leavesqty": "2.9301",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "2.9301",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "0",
"side": 2,
"stoppx": "9850.35",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Example: New Stop-Limit Order
curl "https://api.bitwyre.com/private/orders" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"instrument\": \"btc_usdx_futures_perp\",\
\"side\": 1,\
\"ordtype\": 4,\
\"price\": \"9800.5\",\
\"stoppx\": \"9750\",\
\"orderqty\": \"2.9301\",\
}\
}"
Response (Execution Report)
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 0,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdx_futures_perp",
"leavesqty": "2.9301",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "2.9301",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 4,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "9800.5",
"side": 1,
"stoppx": "9750",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Create a new buy/sell order
Endpoint
https://api.bitwyre.com/private/orders
Create Order Payload
JSON Field | Value | Required | Description |
---|---|---|---|
clordid | uuid-string | false | client generated uuid string, no mandatory. |
instrument | string | true | base asset, quote asset, product filter, delimited with an _ (underscore). |
side | enum-number | true | side of order, currently only supports buy (1) or sell (2) . |
ordtype | enum-number | true | Supports market (1) , limit (2) , stop (3) , or stop_limit (4) order, post only (19), market IOC (20), limit IOC (21), and FOK (22) |
price | float-string | false | mandatory for limit and stop_limit order. |
stoppx | float-string | false | mandatory for stop and stop_limit order. |
orderqty | float-string | true | order quantity for the base asset. |
timeinforce | enum-number | false | order lifetime enforcement, see Time In Force. |
expiretime | big-integer | false | mandatory when "timeinforce" is set to gtd , unix time in nanoseconds. |
execinst | string | false | not-yet-supported, reserved for future. |
cancelondisconnect | bool | false | cancel order on disconnection, not supported in REST (yet). |
One must make sure that price, quantity and also value are in the the currency unit that are from the base and quote pairs. For example if the instrument is btc_usdt_spot
, the quantity is btc
and the price and value are in usdt
. Note that our clearing engine does clearing inside our database based on 64-bit integer computations. Thus, to reduce the amount of increment errors, we also highly suggest you to compute the quantity in the smallest unit of the base asset and the value in the smallest unit of the quote asset. For the previous example of btc_usdt_spot
the smallest unit of btc
is satoshi, 10^-8 of a btc
, and for usdt
it is 10^-6 of a usdt
. For a quantity of 1 btc
we will process in our backend in the integer 100,000,000
and for
1 usdtit will be
1,000,000`. This is the same for Monero (piconero) and ZCash (zatoshi), the exception is only for Ethereum, where we use GWei in our backend computations.
Getting Open Orders
Request
Getting specific open orders
curl 'https://api.bitwyre.com/private/orders/open?nonce=17081945&checksum=<payload_checksum>&payload={"instrument":"btc_usdx_futures_perp", "from_time": 1593487780108470000, "to_time": 1593487786824088000 }&page=1&per_page=1' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Getting all open orders
curl 'https://api.bitwyre.com/private/orders/open/all?nonce=17081945&checksum=<payload_checksum>&payload=&page=1&per_page=1' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_usdt_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdx_futures_perp",
"leavesqty": "1",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "1",
"ordrejreason": "",
"ordstatus": 0,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
]
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Retrieves curent open orders.
Endpoint
https://api.bitwyre.com/private/orders/open
https://api.bitwyre.com/private/orders/open/all
Request Payload Fields
When no payload specified, it will return all orders symbols that currently in open position. Otherwise on /open/all
it automatically returns all open order, no payload necessary
Payload Fields | Value | Required | Description |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
from_time | int | false | nanosecond timestamp for oldest order to be enumerated. |
to_time | int | false | nanosecond timestamp for newest order to be enumerated. |
Request Parameters
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Data
A dictionary, where the keys are the symbols and the values are an array of currently open order(s), see Execution report Response.
Getting Closed Orders
Request
Getting specific closed order
curl 'https://api.bitwyre.com/private/orders/closed?nonce=17081945&checksum=<payload_checksum>&payload={"instrument":"btc_usdt_spot", "from_time": 1593487780108470000, "to_time": 1593487786824088000}?page=1&per_page=5' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Getting all closed order
curl 'https://api.bitwyre.com/private/orders/closed/all?nonce=17081945&checksum=<payload_checksum>&page=1&per_page=3' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_idr_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "1",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "1",
"ordrejreason": "",
"ordstatus": 1,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
},
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "1",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc1",
"orderqty": "1",
"ordrejreason": "",
"ordstatus": 1,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc1",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc1",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 2345676543246,
"transacttime": 0,
"value": "100.0"
}
],
"btc_usd_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usd_spot",
"leavesqty": "1",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "1",
"ordrejreason": "",
"ordstatus": 1,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "0.1",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "1.0"
}
]
},
"meta": {
"has_next": true,
"has_prev": true,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 15
}
}
Retrieves currently closed orders. Similar to order history.
Endpoint
https://api.bitwyre.com/private/orders/closed
https://api.bitwyre.com/private/orders/closed/all
Request Payload Fields
For showing closed order based on parameters on /closed
. Otherwise on /closed/all
it automatically returns all closed order, no payload necessary
Payload Fields | Value | Required | Description |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
from_time | int | false | nanosecond timestamp for oldest order to be enumerated. |
to_time | int | false | nanosecond timestamp for newest order to be enumerated. |
Request Parameters
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Data
A dictionary, where the keys are the symbols and the values are an array of currently closed order(s), see Execution report Response.
Getting All Cancelled Orders
Request
curl 'https://api.bitwyre.com/private/orders/cancelled?nonce=17081945&checksum=<payload_checksum>&payload=' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_idr_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 4,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
],
"btc_usd_spot": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usd_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 4,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 1,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "0.1",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "1.0"
}
]
}
}
Retrieves all cancelled orders. Similar to order history.
Endpoint
https://api.bitwyre.com/private/orders/cancelled
Request Payload Fields
This API does not require request payload
Response Data
A dictionary, where the keys are the symbols and the values are an array of currently cancelled order(s), see Execution report Response.
Getting Open Derivatives Positions
Request
Getting all open derivatives positions in the time range 1593487780108470000 and 1593487786824088000
curl 'https://api.bitwyre.com/private/positions/open?nonce=17081945&checksum=<payload_checksum>&payload={"instrument":"btcusdx_perp_futures", "from_time": 1593487780108470000, "to_time": 1593487786824088000 }&page=1&per_page=1' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Getting all open derivatives positions
curl 'https://api.bitwyre.com/private/positions/open/all?nonce=17081945&checksum=<payload_checksum>&payload=&page=1&per_page=1' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btcusdx_perp_futures": [
{
"open_timestamp": 1657440070843300000,
"closed_timestamp": 0,
"trade_id": "5e31da45-f0c9-430a-844c-38e001b84cee",
"instrument": "btcusdx_perp_futures",
"derivatives_type": "futures",
"derivatives_subtype": "perpetualswap",
"mark_price": 21000,
"est_liquidation_price": 11000,
"bankruptcy_price": 10500,
"avg_open_price": 20490,
"breakeven_price": 20500,
"position_size": 1,
"notional_size": 21000,
"index": "btcusdx",
"settlement_asset": "usd",
"time_to_expiry": "NA", // perpetuals have no expiry
"days_to_expiry": "NA", // perpetuals have no expiry
"strike_price": "NA", // perpetual futures have no strike price
"option_type": "NA", // can be CALL or PUT
"implied_volatility": "NA", // futures does not have implied volatility
"direction": 1, // 1 LONG and 2 SHORT
"pnl": 500, // in options this is true
}
]
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Retrieves curent open derivatives positions.
Endpoint
https://api.bitwyre.com/private/positions/open
https://api.bitwyre.com/private/positions/open/all
Request Payload Fields
When no payload specified, it will return all position symbols that currently in open position inside the matching engine. Otherwise on /open/all
it automatically returns all open position, no payload necessary
Payload Fields | Value | Required | Description |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
from_time | int | false | nanosecond timestamp for oldest position to be enumerated. |
to_time | int | false | nanosecond timestamp for newest position to be enumerated. |
Request Parameters
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Data
A dictionary, where the keys are the symbols and the values are an array of currently open position(s), see Position report Response.
Getting Order Info
Request
Getting one specific order detail
curl "https://api.bitwyre.com/private/orders/info/732f066e-feed-baad-beef-e000ed83243a?nonce=17081945&checksum=<payload_checksum>&payload=&page=1&per_page=1" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Getting all orders details
curl "https://api.bitwyre.com/private/orders/info/all?nonce=<nonce>&checksum=<checksum>&payload=&page=1&per_page=1" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
Getting orders details
{
"error": [],
"result": [
{
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fb",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "1e-06",
"execid": "",
"exectype": 1,
"expiry": 0,
"fill_price": "5500.0",
"instrument": "btc_idr_spot",
"leavesqty": "9e-06",
"orderid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fc",
"orderqty": "1e-05",
"ordrejreason": "",
"ordstatus": 1,
"ordstatusReqID": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fe",
"ordtype": 1,
"origclid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fd",
"price": "5000.0",
"side": 1,
"stoppx": "6000.0",
"time_in_force": 0,
"timestamp": 1231123123,
"transacttime": 123123,
"value": "5000000.0"
}
],
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Retrieves information on a specific order or all orders.
Endpoint
https://api.bitwyre.com/private/orders/info/:order_id
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
order_id | uuid | True | specific order_id to get info from. When specified as all , the endpoint will return all orders (open and closed) |
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Data
See Execution report Response.
Getting Order Histories
Request
curl 'https://api.bitwyre.com/private/orders/histories?nonce=17081945&checksum=<payload_checksum>&payload={"instrument":"btc_usdt_futures", "from_time": 1593487780108470000, "to_time": 1593487786824088000}&page=1&per_page=1' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_usdt_futures": [
{
"cancel_order_id": "",
"filled": "1",
"instrument": "btc_usd_spot",
"order_id": 1,
"remaining": "1",
"fill_price": "1000",
"status": 1,
"time": 123123
}
]
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Retrieves all order histories for current instrument.
Endpoint
https://api.bitwyre.com/private/orders/histories
Request Fields
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Request Payload Fields
When no payload specified, it will return all order histories.
Payload Fields | Value | Required | Description |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
from_time | int | false | nanosecond timestamp for oldest order to be enumerated. |
to_time | int | false | nanosecond timestamp for newest order to be enumerated. |
Getting Order Journey
Request
curl 'https://api.bitwyre.com/private/orders/journey?nonce=17081945&checksum=<payload_checksum>&payload={"order_id":"da5f12ea-8c7c-4cab-83a2-c21912aa51e9"}' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"da5f12ea-8c7c-4cab-83a2-c2191": [
{
"cancel_order_id": "",
"qty": "10000", // total number of order requested
"filled": "8500",
"instrument": "btc_usd_spot",
"order_id": "da5f12ea-8c7c-4cab-83a2-c2191",
"remaining": "1500",
"cancelled": "0",
"accumulated_percentage": "85%",
"incremental_percentage": "85%",
"status": 1,
"time": 1621570548809209000
},
{
"cancel_order_id": "",
"qty": "10000", // total number of order requested
"filled": "9000",
"instrument": "btc_usd_spot",
"order_id": "da5f12ea-8c7c-4cab-83a2-c2191",
"remaining": "1000",
"cancelled": "0",
"accumulated_percentage": "90%",
"incremental_percentage": "5%",
"status": 1,
"time": 1621570557593313000
}
]
}
}
Retrieves all order histories for current order_id
Endpoint
https://api.bitwyre.com/private/orders/journey
Request Payload Fields
When no payload specified, it will return all order histories.
Payload Fields | Value | Required | Description |
---|---|---|---|
order_id | string | true | Order UUID |
Cancelling an Open Order or All Open Orders
Request
curl "https://api.bitwyre.com/private/orders/cancel?nonce=17081945&checksum=<payload_checksum>&payload={'order_ids':['a9e3d010-3169-489d-9063-ced912b0fdc9', 'a9e3d010-3169-489d-9063-ced912b0fdc9'], 'qtys':[1, 3]}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 5,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 6,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Cancels a specific order.
Endpoint
https://api.bitwyre.com/private/orders/cancel/
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
order_ids | list | True | list of order_id s to cancel. When specified as an empty list, the endpoint will cancel all open orders |
qtys | list | True | list of qtys to cancel corresponding to the order_id s with the same list index |
When qtys
specified as an empty list, the endpoint will cancel max amount on every order_id
s , when only one is specified, endpoint will cancel every order_id
s to that amount, if -1
is specified, it cancels all amount
Response Data
See Execution report Response.
Cancelling an Open Order per Instrument
Request
curl "https://api.bitwyre.com/private/orders/cancel/instrument/btc_usdt_spot?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 5,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdt_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 6,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Cancels all open orders for a specific instrument.
Endpoint
https://api.bitwyre.com/private/orders/cancel/instrument/<string:instrument>
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
instrument | string | True | specific instrument |
Response Data
See Execution report Response.
Closing an Open Positions or All Open Positions
Request
curl "https://api.bitwyre.com/private/position/close?nonce=17081945&checksum=<payload_checksum>&payload={'position_ids':['a9e3d010-3169-489d-9063-ced912b0fdc9', 'a9e3d010-3169-489d-9063-ced912b0fdc9']}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 5,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_idr_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 6,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Closing a specific position or all positions.
Endpoint
https://api.bitwyre.com/private/positions/close/
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
position_ids | list | True | list of position_id s to close. When specified as an empty list, the endpoint will close all open positions |
Response Data
See Execution report Response.
Closing Open Positions per Instrument
Request
curl "https://api.bitwyre.com/private/positions/closed/instrument/btcusdx_perp_futures?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"AvgPx": "0",
"LastLiquidityInd": "0",
"LastPx": "0",
"LastQty": "0",
"account": "a9e3d010-3169-489d-9063-ced912b0fdc8",
"cancelondisconnect": 0,
"clorderid": "",
"cumqty": "0",
"execid": "",
"exectype": 5,
"expiry": 0,
"fill_price": "0",
"instrument": "btc_usdt_spot",
"leavesqty": "10",
"orderid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"orderqty": "10",
"ordrejreason": "",
"ordstatus": 6,
"ordstatusReqID": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"ordtype": 3,
"origclid": "a9e3d010-3169-489d-9063-ced912b0fdc9",
"price": "10.0",
"side": 1,
"stoppx": "0",
"time_in_force": 0,
"timestamp": 123123132123,
"transacttime": 0,
"value": "100.0"
}
}
Closes all open position for a specific instrument.
Endpoint
https://api.bitwyre.com/private/position/closed/instrument/<string:derivatives_instrument>
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
instrument | string | True | specific instrument |
Response Data
See Execution report Response.
Getting Trade History
curl 'https://api.bitwyre.com/private/trades?nonce=17081945&checksum=<payload_checksum>&payload={"count": 2, "from_time": 1509225871147236500, "to_time": 1709225871147236500, "instrument":"btc_usd_spot"}&page=1&per_page=2' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"btc_usd_spot": [
{
"exec_price": 20.0,
"exec_qty": 1.0,
"exec_type": 1,
"exec_value": 20000.0,
"fee_paid": 0.005, # if positive, it is rebate
"fee_rate": 0.0001,
"fee_type": 1,
"notes": "insert notes",
"order_price": 0,
"order_qty": 0,
"order_remaining": 0,
"order_type": 1,
"order_uuid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fd",
"side": 1,
"status": 1,
"symbol": "btc_usd_spot",
"timestamp": 123123,
"user_uuid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fb"
},
{
"exec_price": 20.0,
"exec_qty": 1.0,
"exec_type": 1,
"exec_value": 20000.0,
"fee_paid": 0.005, # if positive, it is rebate
"fee_rate": 0.0001,
"fee_type": 1,
"notes": "insert notes",
"order_price": 0,
"order_qty": 0,
"order_remaining": 0,
"order_type": 1,
"order_uuid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fe",
"side": 1,
"status": 1,
"symbol": "btc_usd_spot",
"timestamp": 123123,
"user_uuid": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fb"
}
]
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 10
}
}
Retrieves some latest buying/selling transaction history.
Endpoint
https://api.bitwyre.com/private/trades
Request Payload Fields
JSON Field | Data Type | Required | Remark |
---|---|---|---|
instrument | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
count | number | false | limit the latest historical trade data. |
from_time | big-integer | false | inclusive historical time offset, unixtime in nanoseconds. |
to_time | big-integer | false | exclusive historical time limit, unixtime in nanoseconds. |
Request Parameters
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Types
Dictionary of instrument
and it's trades info, trade info fields:
JSON Field | Data Type | Remark |
---|---|---|
id | uuid-string | universal unique id of the trade. |
time | big-integer | Trade time, unixtime in nanoseconds. |
type | enum-string | "buy" for buy, "sell" for sell. |
price | float-string | quote price for the base asset of the trade. |
volume | float-string | base asset amount of the trade. |
total | float-string | total quote value of the trade. |
fee_percentage | float-string | percentage of the fee. |
fee | float-string | fee value. |
fee_currency | string | asset of the fee, in most case is the quote asset. |
Getting Trading Notifications
Example: Get All Notifications
curl "https://api.bitwyre.com/private/account/notifications/trading"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
}"
-X GET
Response
{
"error": [],
"result": [
{
"OrderRejected": [
{
"notification_message": "Notification Message OrderRejected #2",
"timestamp": 1638408842500649920
},
{
"notification_message": "Notification Message OrderRejected #1",
"timestamp": 1638408841588082866
}
],
"OrderCancelled": [
{
"notification_message": "Notification Message OrderCancelled #3",
"timestamp": 1638408842505009193
},
{
"notification_message": "Notification Message OrderCancelled #2",
"timestamp": 1638408842409370461
},
{
"notification_message": "Notification Message OrderCancelled #1",
"timestamp": 1638408842315787091
}
],
"OrderFilled": [
{
"notification_message": "Notification Message OrderFilled #1",
"timestamp": 1638408841987827578
}
],
"Deposit": [
{
"notification_message": "Notification Message Deposit #1",
"timestamp": 1638408842290246580
}
],
"Withdrawal": [
{
"notification_message": "Notification Message Withdrawal #2",
"timestamp": 1638408842131569666
},
{
"notification_message": "Notification Message Withdrawal #1",
"timestamp": 1638408842048839032
}
],
"KYC": [
{
"notification_message": "Notification Message KYC #1",
"timestamp": 1638408842230728389
}
]
}
]
}
Example: Get Specific Notifications
curl "https://api.bitwyre.com/private/account/notifications/trading?trading_notification_type=0?limit=2"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
}"
-X GET
Response
{
"error": [],
"result": [
{
"OrderRejected": [
{
"notification_message": "Notification Message OrderRejected #2",
"timestamp": 1638408842500649920
},
{
"notification_message": "Notification Message OrderRejected #1",
"timestamp": 1638408841588082866
}
]
}
]
}
Endpoint
https://api.bitwyre.com/private/account/notifications/trading
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
trading_notification_type | integer | False | Type of notification. Default all . See Trading Notification Type |
limit | integer | False | No of notifications per type. Default `100 (max) |
Response Data (Array of JSON Object)
An array of JSON object, where the keys of the object are notification type names and the values are an array of object with the following specifications.
JSON Field | Data Type | Remark |
---|---|---|
notification_message | string | Content of notification message |
timestamp | integer | Unixtime nanosecond timestamp |
Search Favorites
Search ticker, trades, and depth data of pairs in one endpoint
Request
curl "https://api.bitwyre.com/private/favorites?instruments=['btc_usdt_spot']" -X GET
Response
{
"error": [],
"result": {
"favorites": [
{
"btc_usdt_spot": {
"askbook": [["400.0", "2.0"]],
"best_ask": "11000",
"best_bid": "10075",
"bidbook": [["310.0", "5.0"]],
"high": "11000",
"last": "10100",
"last_trade_price": "10000.0",
"last_trade_side": 1,
"last_trade_timestamp": 1571747594573320135,
"last_trade_uuid": "752837c7-aec6-41f8-bb07-286f859f2718",
"last_trade_value": "20000.0",
"last_trade_volume": "2.0",
"low": "10000",
"percent_change": "110.0",
"timestamp": 1571747594573320135,
"volume_base": "34",
"volume_quote": "267346.0"
}
}
]
}
}
Endpoint
https://api.bitwyre.com/private/favorites
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"instruments" | list | false | Instruments of interest (eg ['btc_usdt_spot','eth_usdt_spot']) |
Notes: if no instrument is specified, endpoint will return all available instrument
Response Types (JSON Object)
Returns | JSON Field | Data Type | Remark | | ---------- | --------- | -------------------------- | | error | list | Error messages, if any | | result | dictionaries | contain list of dictionaries of the data, grouped by product, market, instrument |
Please check ticker, trades, and depth endpoint documentation for explanation of the dictionary members
Convert/Instant API Endpoints
Request Convert
Request
curl "https://api.bitwyre.com/private/convert" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"from_coin\": \"btc\",\
\"size\": \"2\",\
\"to_coin\": \"usdt\",\
\"convert_uuid\": \"78838a5a-c5bc-4317-a47f-2481a92558ca\",\
\"send_callback\": true,\
}\
}"
Response
{
"error": [],
"result": {
"timestamp": 1571744594571020435,
"message": "Convert Request Success",
"quote_asset": "btc",
"quote_quantity": "2",
"base_asset": "usdt",
"base_quantity": "60000",
"details": "2 btc to 60,000 usdt",
"implied_convert_price": "0.00003333333",
"instrument": "usdt_btc_spot",
"convert_uuid": "78838a5a-c5bc-4317-a47f-2481a92558ca",
}
}
Create a convert request. Once this convert request is complete, it will send a POST request to the URL set in the set URL callback method below. The body of the callback request will be in this format.
POST Callback
{
"error": [],
"result": {
"timestamp": 1571744594571020435,
"message": "Convert Request Success",
"quote_asset": "btc",
"quote_quantity": "2",
"base_asset": "usdt",
"base_quantity": "60000",
"details": "2 btc to 60,000 usdt",
"implied_convert_price": "0.00003333333",
"instrument": "usdt_btc_spot",
"convert_uuid": "78838a5a-c5bc-4317-a47f-2481a92558ca",
}
}
Endpoint
https://api.bitwyre.com/private/convert
Request Payload Fields
Payload Fields | Value | Required | Description |
---|---|---|---|
from_coin | string | true | eg. btc |
to_coin | string | true | eg. usdt |
size | string | true | convert size |
convert_uuid | string | false | convert id |
send_callback | string | false | true if want to send data to URL callback. Default true |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
timestamp | integer | timestamp in unix |
message | string | conversion message |
quote_asset | string | paid asset |
quote_quantity | string | paid asset quantity |
base_asset | bool | received asset |
base_quantity | string | received asset convert quantity |
details | string | conversion transctions details |
implied_convert_price | string | price conversion rate |
instrument | string | base asset, quote asset, product filter, delimited with an _ (underscore) |
convert_uuid | integer | convert id |
Convert Details
Request
curl 'https://api.bitwyre.com/private/convert?nonce=17081945&checksum=<payload_checksum>&convert_uuid=78838a5a-c5bc-4317-a47f-2481a92558ca' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": [{
"timestamp": 1571744594571020435,
"base_asset": "btc",
"convert_uuid": "78838a5a-c5bc-4317-a47f-2481a92558ca",
"quote_asset": "usdt",
"details": "2 btc to 60,000 usdt",
"expired": false,
"accepted": true,
"price": "7695.5",
"proceeds": "384.77",
"size": "0.05",
"side": 2,
"success_time": 1571744594571020435,
}]
}
Get Convert Status
Endpoint
https://api.bitwyre.com/private/convert
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
convert_uuid | string | true | Convert ID |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
base_coin | string | base asset |
quote_coin | string | quote asset |
from_coin | string | from coin |
to_coin | string | to_coint |
accepted | bool | accepted status |
price | string | price in units of quote_coint |
proceeds | string | proceeds of accepting the quote in units of to_coin |
size | string | balance in bitcoin |
side | string | "sell" if from_coin is base_coin, otherwise "buy" |
success_time | integer | success timestamp |
timestamp | integer | timestamp |
Convert Payment Methods
Request
curl 'https://api.bitwyre.com/private/convert/payment_methods?nonce=17081945&checksum=<payload_checksum>&type=all' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": [
{
"fiat": ["Credit Cards", "Banking", "Virtual Account"],
"crypto": ["Deposit", "Withdrawal"],
}
]
}
Get Convert Payment Method List
Endpoint
https://api.bitwyre.com/private/convert/payment_methods
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
type | string | false | Type of Asset fiat , crypto or all . Default all |
Response Types (JSON Array)
JSON Field | Data Type | Remark |
---|---|---|
JSON-array | string | Returns an an array filled with payment methods |
Get Asset Conversion Status
Request
curl 'https://api.bitwyre.com/private/convert/status?nonce=17081945&checksum=<payload_checksum>&convert_uuid={convert_uuid}' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"details": "1 btc to 30,000 usdt",
"status": "Success",
"convert_uuid": "8de70f37-c2b1-4d01-a6ba-bffc28391af4",
"quote_asset": "btc",
"quote_quantity": "2",
"base_asset": "usdt",
"base_quantity": "60000",
"details": "2 btc to 60,000 usdt",
"implied_convert_price": "0.00003333333",
"instrument": "usdt_btc_spot",
}
}
Get Convert Status Data
Endpoint
https://api.bitwyre.com/private/convert/status
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
convert_uuid | string | true | Convert ID |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
details | string | Amount details of asset conversion |
status | string | Asset convert status |
convert_uuid | string | Convert ID |
Create Vault Convert
Request
curl "https://api.bitwyre.com/private/convert/vault" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"btc\",\
\"network_id\": \"BTC\",\
\"convert_uuid\": \"78838a5a-c5bc-4317-a47f-2481a92558ca\",\
}\
}"
Response
{
"error": [],
"result": {
"asset": "btc",
"network_name": "Bitcoin",
"deposit_address": "3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5",
"address_tag": "",
"address_tag_name": "",
}
}
Create Vault Convert
Endpoint
https://api.bitwyre.com/private/convert/vault
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
asset | string | true | Asset name |
network_id | string | true | Asset network ID |
convert_uuid | string | true | Convert ID |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
asset | string | Asset name |
network_name | string | Asset network name |
deposit_address | string | Crypto deposit address |
address_tag | string | Address tag |
address_tag_name | string | Address tag name |
Set Deposit Callback
Request
curl "https://api.bitwyre.com/private/deposit/callback" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X PUT \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"callback_url\": \"https://api.garuda.to/wallet/deposit/callback\",\
}\
}"
Response
{
"error": [],
"result": {
"timestamp": 1571744594571020435,
"message": "Set Deposit Callback URL to https://api.garuda.to/wallet/deposit/callback success",
}
}
Set a convert URL callback to make sure after a deposit on a conversion request is successful, it will submit a POST request to hit this endpoint.
Endpoint
https://api.bitwyre.com/private/deposit/callback
Request Payload Fields
Payload Fields | Value | Required | Description |
---|---|---|---|
callback_url | string | true | https://api.garuda.to/wallet/deposit/callback |
Set Convert Callback
Request
curl "https://api.bitwyre.com/private/convert/callback" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X PUT \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"callback_url\": \"https://api.garuda.to/wallet/convert/callback\",\
}\
}"
Response
{
"error": [],
"result": {
"timestamp": 1571744594571020435,
"message": "Set Convert Callback URL to https://api.garuda.to/wallet/convert/callback success",
}
}
Set a convert URL callback to make sure after a conversion request successful, it will submit a POST request to hit this endpoint.
Endpoint
https://api.bitwyre.com/private/convert/callback
Request Payload Fields
Payload Fields | Value | Required | Description |
---|---|---|---|
callback_url | string | true | https://api.garuda.to/wallet/convert/callback |
Set Withdrawal Callback
Request
curl "https://api.bitwyre.com/private/withdrawal/callback" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X PUT \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"callback_url\": \"https://api.garuda.to/wallet/withdrawal/callback\",\
}\
}"
Response
{
"error": [],
"result": {
"timestamp": 1571744594571020435,
"message": "Set Withdrawal Callback URL to https://api.garuda.to/wallet/withdrawal/callback success",
}
}
Set a convert URL callback to make sure after a deposit on a conversion request is successful, it will submit a POST request to hit this endpoint.
Endpoint
https://api.bitwyre.com/private/withdrawal/callback
Request Payload Fields
Payload Fields | Value | Required | Description |
---|---|---|---|
callback_url | string | true | https://api.garuda.to/wallet/withdrawal/callback |
Get Convert Deposit Information
Request
curl 'https://api.bitwyre.com/private/convert/vault?asset=btc&nonce=17081945&checksum=<payload_checksum>' \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 2,
"prev_page": null,
"total_count": 3
},
"result": [
{
"address": "tb1q8xylgnxwtj7gzsf2kd9tsxgrzkwpv4v4q0d3gw",
"amount": "0.0001",
"asset": "btc",
"network_id": "BTC_TEST",
"network_name": "Bitcoin Testnet",
"no_of_confirmations": 1,
"status": "Confirmed",
"timestamp": 1662628198005000000,
"tx_id": "afefcbcdf56dc24d71e44b716cbdc511e6a265b341c44d021d997cdf11627e70"
},
{
"address": "tb1q8xylgnxwtj7gzsf2kd9tsxgrzkwpv4v4q0d3gw",
"amount": "0.0001",
"asset": "btc",
"network_id": "BTC_TEST",
"network_name": "Bitcoin Testnet",
"no_of_confirmations": 1,
"status": "Confirmed",
"timestamp": 1662603131619000000,
"tx_id": "a8d8219490fe6a45bd8499084efc2e1b9ecc3380cabf04259d53b13119ebcd36"
}
]
}
Get Convert Deposit Info
Endpoint
https://api.bitwyre.com/private/convert/vault
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
asset | string | true | Asset crypto |
network_id | string | false | Asset crypto network ID. Default all |
convert_uuid | string | false | Convert ID. Default all |
address | string | false | Asset crypto address destination. Default all |
tx_id | string | false | Asset crypto transaction ID/hash. Default all |
page | int | false | Displayed result page number. Default 1 |
per_page | int | false | Number of displayed result per page. Default 50 |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
address | string | Asset crypto address |
amount | string | Amount of deposited asset |
asset | string | Asset crypto |
network_id | string | Asset crypto network ID |
network_name | string | Asset crypto network name |
no_of_confirmations | int | No of transaction network confirmations |
status | string | Status of asset transaction |
timestamp | int | Timestamp in unix |
tx_id | string | Asset crypto transaction ID/hash |
Custodian API Endpoints
Creating a New Crypto Withdrawal Request
curl "https://api.bitwyre.com/private/account/withdrawal/crypto" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"btc\",\
\"amount\": \"1\",\
\"address\": \"12dRugNcdxK39288NjcDV4GX7rMsKCGn6B\",\
\"network_id\": \"BTC\",\
\"notes\": \"Buying new shoes\"\
}\
}"
Response
{
"error": [],
"result": {
"withdrawal": {
"btc": [
{
"fee": "to-be-determined",
"gross_amount": "to-be-determined",
"id": "f98c7277-881a-46f8-a260-99c626619c2f",
"nett_amount": "1.0",
"network_confirmation": 0,
"network_id": "BTC",
"network_name": "Bitcoin",
"provider": "hot",
"status": "Pending",
"submit_time": 1617971125374549000,
"success_time": 0,
"tx_id": "",
"type": "crypto",
"verification_uuid": "db6547d6-dc9e-404f-982f-75cc2fa7b919"
}
]
}
}
}
Creates a new withdrawal request for a given asset with the given amount.
A confirmation email will be sent and contains instruction on how to confirm the withdrawal request.
The transaction will not be processed before a confirmation is conducted.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/crypto
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | true | Asset to withdraw. |
amount | string | true | Amount to withdraw. |
address | string | true | Destination address. |
network_id | string | true | Network of Destination address. |
notes | string | false | Optional annotation, e.g. "Buying new shoes". |
Response Data
See Response Asset Statement Object.
Verify Crypto Withdrawal Request
curl "https://api.bitwyre.com/private/account/withdrawal/crypto/verify/65792f1b-a4b5-4b41-befd-f1e5bb8815ef/4cd1ff2d-cda0-4e9f-b1d5-2b59f1b17154?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"withdrawal_verified": [
{
"id": "65792f1b-a4b5-4b41-befd-f1e5bb8815ef",
"transaction_uuid": "4cd1ff2d-cda0-4e9f-b1d5-2b59f1b17154",
"is_verified": 1
}
]
}
}
Confirms that the crypto withdrawal requeset is verified.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/crypto/verify/:withdrawal_id/:verification_uuid
Request Fields/Parameters
Path Parameter | Value | Required | Description |
---|---|---|---|
"withdrawal_id" | uuid-string | true | specific withdrawal_id to get info from. If specified as all it will return all crypto withdrawal request statuses |
"verification_uuid" | uuid-string | true | specific verification_uuid to verified withdrawal request |
Getting a Crypto Withdrawal Request Status
curl "https://api.bitwyre.com/private/account/withdrawal/crypto/btc/65792f1b-a4b5-4b41-befd-f1e5bb8815ef?nonce=17081945&checksum=<payload_checksum>&payload=&page=1&per_page=1" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"withdrawal": {
"btc": [
{
"asset": "btc",
"fee": "0",
"gross_amount": "1.0",
"id": "65792f1b-a4b5-4b41-befd-f1e5bb8815ef",
"is_verified": 0,
"nett_amount": "100000000",
"network_confirmation": 0,
"network_id": "BTC",
"network_name": "Bitcoin",
"provider": "",
"status": "Pending",
"submit_time": 1617974544503655000,
"success_time": 0,
"tx_id": "",
"tx_hash_url": "",
"verification_uuid": "3b577d3e-8e15-4ff9-aee6-4e95c3042a05",
"withdrawal_type": "crypto"
}
]
}
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Retrieves a withdrawal request's details.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/crypto/:asset/:withdrawal_id
Request Fields/Parameters
Path Parameter | Value | Required | Description |
---|---|---|---|
asset | string | true | Crypto asset, e.g btc , bch . |
withdrawal_id | uuid-string | true | specific withdrawal_id to get info from. If specified as all it will return all crypto withdrawal request statuses |
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Creating a New Fiat Withdrawal Request
curl "https://api.bitwyre.com/private/account/withdrawal/fiat" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"usdt\",\
\"amount\": \"15000000\",\
\"notes\": \"Buying a new computer\"\
\"address\": \"An address\"\
}\
}"
Response
{
"error": [],
"result": {
"withdrawal": {
"idr": [
{
"centralized_confirmation": 0,
"fee": "to-be-determined",
"gross_amount": "1000.0",
"id": "9a149eae-be9e-49f4-b209-6b333a19659e",
"nett_amount": "to-be-determined",
"provider": "",
"status": "pending",
"submit_time": 1618207558621551000,
"success_time": 0,
"tx_id": "",
"type": "fiat",
"verification_uuid": "3af17d81-499d-496e-b2cf-8b061ad63735"
}
]
}
}
}
Creates a new withdrawal request for a given asset with the given amount.
A confirmation email will be sent and contains instruction on how to confirm the withdrawal request.
The transaction will not be processed before a confirmation is conducted.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/fiat
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | true | Asset to withdraw. |
amount | string | true | Amount to withdraw. |
address | string | true | Address to transfer. |
notes | string | false | Optional annotation, e.g. "Buying new shoes". |
Response Data
See Banking Details.
Verify Fiat Withdrawal Request
curl "https://api.bitwyre.com/private/account/withdrawal/fiat/verify/65792f1b-a4b5-4b41-befd-f1e5bb8815ef/4cd1ff2d-cda0-4e9f-b1d5-2b59f1b17154?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"withdrawal_verified": [
{
"id": "65792f1b-a4b5-4b41-befd-f1e5bb8815ef",
"transaction_uuid": "4cd1ff2d-cda0-4e9f-b1d5-2b59f1b17154",
"is_verified": 1
}
]
}
}
Confirms that the fiat withdrawal requeset is verified.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/fiat/verify/:withdrawal_id/:verification_uuid
Request Fields/Parameters
Path Parameter | Value | Required | Description |
---|---|---|---|
"withdrawal_id" | uuid-string | true | specific withdrawal_id to get info from. If specified as all it will return all crypto withdrawal request statuses |
"verification_uuid" | uuid-string | true | specific verification_uuid to verified withdrawal request |
Getting a Fiat Withdrawal Request Status
curl "https://api.bitwyre.com/private/account/withdrawal/fiat/idr/65792f1b-a4b5-4b41-befd-f1e5bb8815ef?nonce=17081945&checksum=<payload_checksum>&payload=?age=1&per_page=1" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"withdrawal": {
"idr": [
{
"id": "073ba6e5-24d2-4532-8b02-58c1d7a104be",
"tx_id": "f4184fc596403b9d638783cf57adfe4c75c605f6356fbc91338530e9831e9e16",
"status": "pending",
"type": "fiat",
"provider": "bitwyre_bank",
"gross_amount": "15000000",
"fee": "0.001",
"nett_amount": "14990000",
"centralized_confirmation": true,
"submit_time": 1571747594573320135,
"success_time": null
}
]
}
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Retrieves a withdrawal request's details.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/fiat/:asset/:withdrawal_id
Request Fields/Parameters
Path Parameter | Value | Required | Description |
---|---|---|---|
"asset" | string | true | Fiat asset, e.g idr , usdt . |
"withdrawal_id" | uuid-string | true | specific withdrawal_id to get info from. If specified as all it will return all fiat withdrawal requests |
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Data
See Response Asset Statement Object.
Getting a New Crypto Deposit Address
curl "https://api.bitwyre.com/private/account/deposit/crypto" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"xlm\",\
\"network_id\": \"XLM\"\
}\
}"
Response
{
"error": [],
"result": {
"deposit": {
"xlm": [
{
"address": "GDRL4HRBJDRHDIJCKX6FB5UNB4KAQINZAJR7L6R3UFKM45BT5KKJ7NCI",
"address_tag": "3267106239",
"address_tag_name": "Memo",
}
]
}
}
}
Gets a new deposit address for a given asset.
Endpoint
https://api.bitwyre.com/private/account/deposit/crypto
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | true | Asset to get a deposit deposit address for. |
network_id | string | false | Asset network to get a deposit deposit address for. Default main |
Getting a Crypto Deposit Address' History
curl "https://api.bitwyre.com/private/account/deposit/crypto/btc/3MzqqLdsYA7mL7re49JMLHJUjbFQ5RHHc6?nonce=17081945&checksum=<payload_checksum>&payload=&page=1&per_page=1" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"deposit": {
"3MzqqLdsYA7mL7re49JMLHJUjbFQ5RHHc6": [
{
"id": "4b6dc35a-ab03-4f55-bb81-8efb5a8569e0",
"tx_id": "f4184fc596403b9d638783cf57adfe4c75c605f6356fbc91338530e9831e9e16",
"status": "success",
"type": "crypto",
"provider": "warm",
"gross_amount": "150.00",
"fee": "0.1",
"nett_amount": "149.9",
"network_id": "BTC",
"network_name": "Bitcoin",
"network_confirmation": 4,
"submit_time": 1571747594573320135,
"success_time": 1571747594573320135,
"url": "https://live.blockcypher.com/btc-testnet/tx/f4184fc596403b9d638783cf57adfe4c75c605f6356fbc91338530e9831e9e16/"
}
]
}
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Gets a crypto deposit address' transaction history.
Basically this is a subset operation of Getting Account Statement.
Endpoint
https://api.bitwyre.com/private/account/deposit/crypto/:asset/:address
Request Fields/Parameters
Path Parameter | Value | Required | Description |
---|---|---|---|
asset | string | true | Crypto asset, e.g btc . |
address | string | true | Crypto deposit address. If specified as all it will return all crypto deposit history |
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Getting a New Fiat Deposit Address
curl "https://api.bitwyre.com/private/account/deposit/fiat/all" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET
Response
{
"error": [],
"result": {
"idr": {
"Bank Transfer": [
{
"account": "1079026031",
"bank": "PT Artha Graha International Tbk",
"bank_address": "Kawasan Niaga Terpadu Sudirman (SCBD) Jl. Jend. Sudirman Kav. 52 - 53 Jakarta Selatan 12190, Indonesia",
"city": "Jakarta",
"country": "Republic of Indonesia",
"currency": "idr",
"is_enabled": 1,
"is_gateway": 0,
"name": "Artha Graha International",
"notes": "US Citizens are prohibited from sending wires in USD for trading. If we find out have the right to return the money and cancel all trades.",
"provider": "Bitwyre",
"routing_number": "",
"swift_code": "ARTGIDJAXXX"
},
{
"currency": "idr",
"is_enabled": true,
"is_gateway": true,
"minimum_deposit_amount": "0",
"payment_category": "Credit Card",
"payment_merchant": "",
"provider": "MKP"
},
{
"currency": "idr",
"is_enabled": false,
"is_gateway": true,
"minimum_deposit_amount": "10000",
"payment_category": "Virtual Account",
"payment_merchant": "BNI",
"provider": "MKP"
},
{
"currency": "idr",
"is_enabled": false,
"is_gateway": true,
"minimum_deposit_amount": "10000",
"payment_category": "Virtual Account",
"payment_merchant": "Mandiri",
"provider": "MKP"
},
{
"currency": "idr",
"is_enabled": false,
"is_gateway": true,
"minimum_deposit_amount": "10000",
"payment_category": "Virtual Account",
"payment_merchant": "Permata",
"provider": "MKP"
},
{
"currency": "idr",
"is_enabled": false,
"is_gateway": true,
"minimum_deposit_amount": "10000",
"payment_category": "Virtual Account",
"payment_merchant": "CIMB",
"provider": "MKP"
},
{
"currency": "idr",
"is_enabled": false,
"is_gateway": true,
"minimum_deposit_amount": "10000",
"payment_category": "Virtual Account",
"payment_merchant": "BRI",
"provider": "MKP"
},
{
"currency": "idr",
"is_enabled": false,
"is_gateway": true,
"minimum_deposit_amount": "10000",
"payment_category": "Virtual Account",
"payment_merchant": "Finpay",
"provider": "MKP"
},
],
"E-Money": [
{
"account": "",
"bank": "PT Espay Debit Indonesia Koe",
"bank_address": "",
"city": "Jakarta",
"country": "Republic of Indonesia",
"currency": "idr",
"is_enabled": 0,
"is_gateway": 1,
"name": "Dana Indonesia",
"notes": "US Citizens are prohibited from sending wires in USD for trading. If we find out have the right to return the money and cancel all trades.",
"payment_gateway_address": "Capital Place fl.18, Jl. Gatot Subroto, RT.6/RW.1, Kuningan Bar., Kec. Mampang Prpt., Kota Jakarta Selatan, Daerah Khusus Ibukota Jakarta 12790",
"provider": "DANA",
"routing_number": "",
"swift_code": ""
},
],
"QRIS": [
{
"currency": "idr",
"is_enabled": false,
"is_gateway": true,
"minimum_deposit_amount": "0",
"payment_category": "QRIS",
"payment_merchant": "",
"provider": "MKP"
},
],
},
}
}
Gets a new deposit address for a given asset
Endpoint
https://api.bitwyre.com/private/account/deposit/fiat/<asset>
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | true | Asset to get a deposit address for e.g. USD, IDR, if ALL then return every deposit address |
Creating a New Fiat Deposit Request
Request (MKP VA)
curl "https://api.bitwyre.com/private/account/deposit/fiat/request" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"idr\",\
\"amount\": \"100000\",\
\"provider\": \"MKP\",\
\"data\": {\
\"payment_category\": \"Virtual Account\",\
\"payment_merchant\": \"CIMB\",\
}\
}\
}"
Response (MKP VA)
{
"error": [],
"result": {
"data": {
"asset": "idr",
"confirmed_status": "Unconfirmed",
"created_at": "2022-11-11 11:24:24",
"expired_at": "2022-11-12 11:24:24",
"fee": 0,
"gross_amount": 10000,
"nett_amount": 10000,
"status": "Pending",
"submit_time": 1668140665352539000,
"time_limit": "1440",
"transaction_id": "352139ea-434b-473d-872c-eb72e343dcb7",
"va_code": "5489079498487726"
},
"message": "Successfully created a deposit transaction via Credit Card",
"success": true,
"timestamp": "2022-11-11T11:24:25+00:00"
}
}
Request (MKP CC)
curl "https://api.bitwyre.com/private/account/deposit/fiat/request" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"idr\",\
\"amount\": \"100000\",\
\"provider\": \"MKP\",\
\"data\": {\
\"payment_category\": \"Credit Card\",\
}\
}\
}"
Response (MKP CC)
{
"error": [],
"result": {
"data": {
"asset": "idr",
"confirmed_status": "Unconfirmed",
"created_at": "2022-11-11 11:16:26",
"expired_at": "2022-11-12 11:16:26",
"fee": 0,
"gross_amount": 10000,
"nett_amount": 10000,
"payment_url": "https://tokenize-staging.mcpayment.id/?eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJyZWdpc3Rlcl9pZCI6IkEyUC1DQzIwMjIxMTExMTExNjI3LTA5MzciLCJjYWxsYmFja191cmwiOiJodHRwOi8vMTQ5LjEyOS4yNDguMjUyOjE4MDAxL3B1cmNoYXNlL2NjL2NhbGxiYWNrcGF5bWVudCIsIm1lcmNoYW50X2lkIjoibWtwbW9iaWxlIiwidG9rZW5pemUiOnRydWUsInRyYW5zYWN0aW9uIjp7ImFtb3VudCI6MTAwMDAsImRlc2NyaXB0aW9uIjoiTUFOVUFMIElOUVVJUlkgT1RFIC0gQ0MifSwiaXNfdG9rZW5pemUiOnRydWUsInJldHVybl91cmwiOiJodHRwczovL2FwaS5iaXR3eXJlLmlkL21rcC9jYWxsYmFjay90cmFuc2FjdGlvbi11cGRhdGUvT1RFXzIwMjItMTEtMTFUMTE6MTY6MjZfQ0NfMTAwMDBfMzUyMTM5ZWEtNDM0Yi00NzNkLTg3MmMtZWI3MmUzNDNkY2I3IiwiaWF0IjoxNjY4MTQwMTg3LCJleHAiOjE2NjgxNDM3ODd9.IjacOqy5ZMm3nO26c6X8XbuX2AKhYJu1XbH_3z5Bhnw",
"status": "Pending",
"submit_time": 1668140187648069000,
"time_limit": "1440",
"transaction_id": "352139ea-434b-473d-872c-eb72e343dcb7"
},
"message": "Successfully created a deposit transaction via Credit Card",
"success": true,
"timestamp": "2022-11-11T11:16:27+00:00"
}
}
Request (MKP QRIS)
curl "https://api.bitwyre.com/private/account/deposit/fiat/request" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"idr\",\
\"amount\": \"100000\",\
\"provider\": \"MKP\",\
\"data\": {\
\"payment_category\": \"QRIS\",\
}\
}\
}"
Response (MKP QRIS)
{
"error": [],
"result": {
"data": {
"asset": "idr",
"confirmed_status": "Unconfirmed",
"created_at": "2022-11-11 10:59:19",
"expired_at": "",
"fee": 0,
"gross_amount": 10000,
"nett_amount": 10000,
"qr_code": "00020101021226530012COM.DOKU.WWW0118936008990000003163020431630303UBE51440014ID.CO.QRIS.WWW0215ID20210591722820303UBE520465335303360540810000.005802ID5908Apps2Pay6008SEMARANG61055012662470703A015036MKP-mkpapps2pay-202211111059000000066304DFBB",
"status": "Pending",
"submit_time": 1668139161566157000,
"time_limit": "",
"transaction_id": "3c2e68ee-2be9-4d56-8b5a-04d01bbe87ca"
},
"message": "Successfully created a deposit transaction via QRIS",
"success": true,
"timestamp": "2022-11-11T10:59:21+00:00"
}
}
Creates a new deposit request for a given fiat asset with the given amount.
Endpoint
https://api.bitwyre.com/private/account/deposit/fiat/request
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | true | Fiat Asset to deposit. |
amount | string | true | Amount to deposit. |
provider | string | true | Service Provider. |
data | object | false | Payment method data |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
message | string | Request success message |
success | boolean | true if request is success |
timestamp | string | Request timestamp |
data | object | Deposit transaction details data |
Getting a Fiat Deposit Address' History
curl "https://api.bitwyre.com/private/account/deposit/fiat/idr/address?nonce=17081945&checksum=<payload_checksum>&payload=&page=1&per_page=1" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"deposit": {
"address": [
{
"centralized_confirmation": 0,
"fee": "0",
"gross_amount": "0",
"id": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fb",
"nett_amount": "0",
"provider": "",
"status": "pending",
"submit_time": 0,
"success_time": 0,
"tx_id": "9927e7e9-c6d0-43ad-9443-8bb6b56ce1fb",
"type": "fiat"
}
]
}
},
"meta": {
"has_next": true,
"has_prev": false,
"next_page": 2,
"page": 1,
"pages": 5,
"prev_page": null,
"total_count": 5
}
}
Gets a fiat deposit address' transaction history.
Basically this is a subset operation of Getting Account Statement.
Endpoint
https://api.bitwyre.com/private/account/deposit/fiat/:asset/:address
Request Fields/Parameters
Path Parameter | Value | Required | Description |
---|---|---|---|
asset | string | true | Fiat asset, e.g idr . |
address | string | true | Fiat deposit address. If specified as `all it will return all fiat deposit history |
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Cancel Pending Crypto Withdrawal
curl "https://api.bitwyre.com/private/account/withdrawal/crypto/btc/fd15191a-7fe5-406d-91e8-fdfcb9476234?nonce=17081945&checksum=<payload_checksum>&payload="
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"withdrawal": {
"btc": [
{
"id": "073ba6e5-24d2-4532-8b02-58c1d7a104be",
"status": "Cancelled",
"submit_time": 1571747594573320135,
"success_time": 1571747594573321111
}
]
}
}
}
We conduct crypto withdrawal transfers 4 times a day 6:00 Jakarta/WIB, 12:00 Jakarta/WIB, 18:00 Jakarta/WIB, 00:00 Jakarta/WIB. A cancel pending withdrawal for crypto operation can only be done 1 hour before those designated withdrawal times.
For example, for the withdrawal batch of 6:00 Jakarta/WIB, the cancel time window closes on 5:00 Jakarta/WIB.
Any attempt to cancel a withdrawal after the cancel time window is rejected and will be returned a status of "cancel rejected" and be automatically processed on the next batch.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/crypto/:crypto/:withdrawal_id
Request Fields/Parameters
Path Parameter | Value | Required | Description |
---|---|---|---|
withdrawal_id | String | True | Withdrawal pending UUID. If specified as `all it cancel all pending withdrawals |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
id | string | UUID of pending request |
status | string | Cancel Success/Cancel Rejected |
submit_time | integer-timestamp | Nanosecond timestamp of submit time |
success_time | integer-timestamp | Nanosecond timesamp of success time, null on cancel rejecteed |
Cancel Pending Fiat Withdrawal
curl "https://api.bitwyre.com/private/account/withdrawal/fiat/usdt/fd15191a-7fe5-406d-91e8-fdfcb9476234?nonce=17081945&checksum=<payload_checksum>&payload="
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X DELETE
Response
{
"error": [],
"result": {
"withdrawal": {
"usdt": [
{
"id": "073ba6e5-24d2-4532-8b02-58c1d7a104be",
"status": "Cancelled",
"submit_time": 1571747594573320135,
"success_time": 1571747594573321111
}
]
}
}
}
We conduct fiat withdrawal transfers 1 time a day 9:00 Jakarta/WIB. A cancel pending withdrawal for fiat operation can only be done 24 hours before those designated withdrawal times.
For example, for the withdrawal batch of 9:00 Jakarta/WIB, the cancel time window closes on 8:59 Jakarta/WIB the previous day
Any attempt to cancel a withdrawal after the cancel time window is rejected and will be returned a status of "cancel rejected" and be automatically processed on the next batch.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/fiat/:fiat/:withdrawal_id
Request Fields/Parameters
Path Parameter | Value | Required | Description |
---|---|---|---|
withdrawal_id | String | True | Withdrawal pending UUID. If specified as `all it cancel all pending withdrawals |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
id | string | UUID of pending request |
status | string | Cancel Success/Cancel Rejected |
submit_time | integer-timestamp | Nanosecond timestamp of submit time |
success_time | integer-timestamp | Nanosecond timesamp of success time, null on Cancel rejecteed |
Getting Crypto Withdrawal Addresses
curl "https://api.bitwyre.com/private/account/withdrawal/crypto/address"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET
Response
{
"error": [],
"result": {
"btc": [
{
"address": "3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5",
"address_name": "mybtcaddress1",
"address_tag": "",
"created_at": "30/07/2021, 00:00:00"
}
],
"eth": [
{
"address": "0x89205A3A3b2A69De6Dbf7f01ED13B2108B2c43e7",
"address_name": "myethaddress1",
"address_tag": "",
"created_at": "30/07/2021, 00:00:00"
}
]
}
}
Response If User have no existing addresses
{
"error": ["No addresses found yet. Please insert and confirm to list one."],
"result": []
}
Return all user's existing and verified crypto withdrawal addresses
Endpoint
https://api.bitwyre.com/private/account/withdrawal/crypto/address
Request Fields/Parameters
Because this is a GET endpoint, nonce
& checksum
are query parameters, also payload
should be always an empty string.
The SHA256
steps for this endpoint's payload:
- jsonify an empty string.
- then SHA256 from above result.
Please refer to Authentication.
Response Data
JSON Field | Data Type | Remark |
---|---|---|
asset | string | Crypto asset |
address | string | Crypto address |
address_name | string | Address name |
address_tag | string | Address tag |
created_at | string | Datetime of address creation |
Add Crypto Withdrawal Address
curl "https://api.bitwyre.com/private/account/withdrawal/crypto/address"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"btc\",\
\"address\": \"3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5\",\
\"address_name\": \"mybtcaddress1\",\
\"address_tag\": \"tagaddress\",\
\"network_id\": \"BTC\",\
}"
-X PUT
Response if Success
{
"error": [],
"result": {
"message": "Successfully add network BTC withdrawal address 3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5",
"success": 1,
"timestamp": 1627473142470220000
}
}
Response if a duplicate address was inserted
{
"error": ["You are inserting a duplicate address that has been confirmed"],
"result": {}
}
Add a crypto withdrawal address for the user
Endpoint
https://api.bitwyre.com/private/account/withdrawal/crypto/address
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | True | crypto asset |
address | string | True | crypto address |
address_name | string | True | address name |
address_tag | string | False | address tag |
network_id | string | False | crypto network |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
message | string | response message |
success | integer | return 1 if the operation success |
timestamp | integer | Nanosecond timestamp |
Remove Crypto Withdrawal Address
curl "https://api.bitwyre.com/private/account/withdrawal/crypto/address"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"btc\",\
\"address\": \"3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5\",\
\"network_id\": \"BTC\",\
}"
-X DELETE
Response if Success
{
"error": [],
"result": {
"message": "Successfully remove network BTC withdrawal address 3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5",
"success": 1,
"timestamp": 1627473142470220000
}
}
Response if the address was already deleted
{
"error": ["You have deleted your address, you cannot use it anymore"],
"result": {}
}
Remove a crypto withdrawal address for the user
Endpoint
https://api.bitwyre.com/private/account/withdrawal/crypto/address
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | True | crypto asset |
address | string | True | crypto address |
network_id | string | False | crypto network |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
message | string | response message |
success | integer | return 1 if the operation success |
timestamp | integer | Nanosecond timestamp |
Verify Crypto Withdrawal Address
curl "https://api.bitwyre.com/private/account/withdrawal/crypto/address"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"btc\",\
\"address\": \"3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5\",\
\"withdrawal_confirmation_uuid\": \"c2025d42-e0c6-47a4-9f0f-bdc627983163\",\
\"network_id\": \"BTC\",\
}"
-X POST
Response if Success
{
"error": [],
"result": {
"message": "Successfully verify network BTC withdrawal address 3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5",
"success": 1,
"timestamp": 1627473142470220000
}
}
Response if the address was already verified
{
"error": ["You have already confirmed the address"],
"result": {}
}
Response if wrong withdrawal confirmation uuid was inserted.
{
"error": ["Wrong withdrawal confirmation code"],
"result": {}
}
Verify a crypto withdrawal address for the user
Endpoint
https://api.bitwyre.com/private/account/withdrawal/crypto/address
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | True | crypto asset |
address | string | True | crypto address |
withdrawal_confirmation_uuid | string | True | withdrawal address confirmation uuid |
network_id | string | False | crypto network |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
message | string | response message |
success | integer | return 1 if the operation success |
timestamp | integer | Nanosecond timestamp |
Resend Verification Crypto Withdrawal Address
curl "https://api.bitwyre.com/private/account/withdrawal/crypto/address"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"asset\": \"btc\",\
\"address\": \"3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5\",\
}"
-X PATCH
Response if Success
{
"error": [],
"result": {
"message": "Successfully resend verification code for btc withdrawal address 3FZbgi29cpjq2GjdwV8eyHuJJnkLtktZc5",
"success": 1,
"timestamp": 1627473142470220000
}
}
Response if the address was already verified
{
"error": ["You have already confirmed the address"],
"result": {}
}
Response if wrong address was inserted.
{
"error": ["Address is not found. Please add the address first."],
"result": {}
}
Resend the verification code for a crypto withdrawal address to the user via e-mail.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/crypto/address
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
asset | string | True | crypto asset |
address | string | True | crypto address |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
message | string | response message |
success | integer | return 1 if the operation success |
timestamp | integer | Nanosecond timestamp |
Getting Banking Details
curl "https://api.bitwyre.com/private/account/banking/get/<asset>?nonce=17081945&checksum=<payload_checksum>&payload="
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"account_nickname": "Nakamoto Chase Account",
"asset": "idr",
"bank_account": 123456,
"bank_account_name": "Satoshi Nakamoto",
"bank_name": "JP Morgan Chase",
"details": "routing code XXXXX",
"id": "1d987421-e850-4efe-85a8-30efb9665c2f",
"swift_code": "CHASUSXX"
}
}
Endpoint
https://api.bitwyre.com/private/account/banking/get
Request Fields/Parameters
Parameter asset
to get its associated bank detail, use all
to query all asset bank detail
Because this is a GET endpoint, nonce
& checksum
are query parameters, also payload
should be always an empty string.
The SHA256
steps for this endpoint's payload:
- jsonify an empty string.
- then SHA256 from above result.
Please refer to Authentication.
Setting Banking Details
curl "https://api.bitwyre.com/private/account/banking/post"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"bank_name\": \"JP Morgan Chase\",\
\"swift_code\": \"CHASUSXX\",\
\"bank_account\": \"xxxxxxxxxxx\",\
\"bank_account_name\": \"Satoshi Nakamoto\",\
\"address\": \"23 Embarcadero Road, California, USA\",
\"details\": \"routing code XXXXX\"\
\"account_nickname\": \"Nakamoto Chase Account\",
\"asset\": \"idr\",
}\
}"
Response
{
"error": [],
"result": {
"result": true
}
}
Endpoint
https://api.bitwyre.com/private/account/banking
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
bank_name | The bank name | True | The bank name designated for deposit/withdrawal |
swift_code | The bank SWIFT code | True | The bank's SWIFT code |
bank_account | The bank account number or IBAN | True | The designated deposit/withdrawal bank account number or IBAN |
bank_account_name | The bank account owner's name | True | The customer's name according to KYC/AML details |
address | The address of the customer | True | The customer's address according to KYC/AML details |
details | Other details to ease the process of transfer | True | The banking specific details needed to conduct the transfer that are country specific |
account_nickname | The nickname for this banking account | False | The customer's preference nickname for the account |
asset | Asset name | True | The Asset to be associated with the bank account |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
id | string-uuid | the UUID of the insertion |
Getting List of Deposit Payment Gateways
curl "https://api.bitwyre.com/private/account/deposit/gateway?nonce=17081945&checksum=<payload_checksum>&payload={\"asset\": \"usdt\"}"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"payment_gateway_name": "IDR Dana",
"url_payment": "https://dana.id/payment/id=xxxxxxxxx",
"url_callback": "https://api.bitwyre.com/private/account/gateway/callback"
}
}
Endpoint
https://api.bitwyre.com/private/account/deposit/gateway
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
"asset" | string | true | Fiat asset for e.g. USD, IDR |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
payment_gateway_name | string | payment gateway name |
url_payment | string-url | URL to be redirected for payment gateway |
url_callback | string-url | URL to get callback after payment gateway operation finished |
Getting List of Withdrawal Payment Gateways
curl "https://api.bitwyre.com/private/account/withdrawal/gateway?nonce=17081945&checksum=<payload_checksum>&payload={\"asset\": \"idr\"}"
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"payment_gateway_name": "IDR Duitku",
"url_payment": "https://dana.id/payment/id=xxxxxxxxx",
"url_callback": "https://api.bitwyre.com/private/account/withdrawal/callback"
}
}
Endpoint
https://api.bitwyre.com/private/account/withdrawal/gateway
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
"asset" | string | true | Fiat asset for e.g. USD, IDR |
Response Data
JSON Field | Data Type | Remark |
---|---|---|
payment_gateway_name | string | payment gateway name |
url_payment | string-url | URL to be redirected for payment gateway |
url_callback | string-url | URL to get callback after payment gateway operation finished |
Know Your Customer (KYC)/Anti-Money Laundering (AML) API Endpoints
Get KYC Data Status
Request
curl "https://api.bitwyre.com/private/account/kyc-data/status" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
}"
Response
{
"error": [],
"result": {
"identity_card_back_scan_uuid": "",
"identity_card_front_scan_uuid": "4f55ab02-a3a6-40cb-8f9c-35761fd4506a",
"rejection_reason": "",
"selfie_photo_uuid": "b2b92db4-31ec-4e5e-944a-2e6b7f6aeef8",
"status": "Pending"
}
}
Get user KYC Data status.
Endpoint
https://api.bitwyre.com/private/account/kyc-data/status
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
identity_card_back_scan_uuid | string | uuid of user id card scan (back side) |
identity_card_front_scan_uuid | string | uuid of user id card scan (front side) |
rejection_reason | string | reason of rejection if status is Rejected |
selfie_photo_uuid | string | uuid of user selfie photo |
status | string | user kyc data status |
Submit KYC Data
Request
curl "https://api.bitwyre.com/private/account/kyc-data" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"name\": \"Test User\",\
\"address\": \"Jalan Pegangsaan Timur Nomor 56\",\
\"id_card_type\": 0,\
\"id_card_number\": \"AB12345\",\
\"id_card_country_code\": \"id\",\
},\
}"
Response
{
"error": [],
"result": {
"success": true,
"message": "Successfully insert kyc data for user be327dcb-c21b-4d4f-944d-3cf1bf297222"
}
}
Submit User KYC Data by user.
Endpoint
https://api.bitwyre.com/private/account/kyc-data
Request Fields/Parameters
Payload Fields | Value | Required | Description |
---|---|---|---|
name | string | true | full name of user (as written in id card) |
address | string | true | current address of user (as written in id card) |
id_card_type | int | true | type of ID Card (0 - National ID, 1 - Driving License, 2 - Passport, 99 - Others) |
id_card_number | string | true | identification number (as written in id card) |
id_card_country_code | string | true | code name of the country where the id card is authorized (ISO 3166-1 alpha-2) |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
success | bool | Acknoledgement that the data has been submitted |
message | string | post success message |
Update Rejected KYC Data
Request
curl "https://api.bitwyre.com/private/account/kyc-data" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X PUT \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"rejection_reason\": 6,\
\"payload\": {\
\"name\": \"Test User\",\
\"address\": \"Jalan Pegangsaan Timur Nomor 56\",\
\"id_card_type\": 0,\
\"id_card_number\": \"AB12345\",\
\"id_card_country_code\": \"id\",\
},\
}"
Response
{
"error": [],
"result": {
"success": true,
"message": "Successfully update kyc data for user be327dcb-c21b-4d4f-944d-3cf1bf297222"
}
}
Update rejected user KYC data.
Endpoint
https://api.bitwyre.com/private/account/kyc-data
Request Fields/Parameters
Query Parameter | Value | Required | Description |
---|---|---|---|
rejection_reason | int | True | Reason of rejection. See KYC Rejection Reason |
Optional Fields/Parameters
These payload is required if rejected_reason contains InvalidData
or InvalidAll
Payload Fields | Value | Required | Description |
---|---|---|---|
name | string | true | full name of user (as written in id card) |
address | string | true | current address of user (as written in id card) |
id_card_type | int | true | type of ID Card (0 - National ID, 1 - Driving License, 2 - Passport, 99 - Others) |
id_card_number | string | true | identification number (as written in id card) |
id_card_country_code | string | true | code name of the country where the id card is authorized (ISO 3166-1 alpha-2) |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
success | bool | Acknoledgement that the data has been updated |
message | string | update success message |
Uploading KYC Files
Request
curl "https://api.bitwyre.com/private/uploadkycfiles" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: multipart/form-data" \
-X POST \
-F "payload={\"type\":1}" \
-F "nonce=17081945"\
-F "checksum=somechecksum"\
-F "file=file.jpg"
Response
{
"error": [],
"result": {
"success": true,
"message": "Image uploaded"
}
}
Endpoint for user to upload Identities.
Endpoint
https://api.bitwyre.com/private/uploadkycfiles
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
type | enum-number | true | 0- NationalIdentity; 1 - DrivingLicense; 2 - Passport ; 3 - Selfie ; 99 - Others |
file | .png, .jpg, .pdf | true | the image file |
Uploading Fiat Deposit Proof
Request
curl "https://api.bitwyre.com/private/account/deposit/fiat/uploadproof" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: multipart/form-data" \
-X POST \
-F "payload={"transction_id":"b9443247-eb59-47ad-a9f4-f479d6b92111"}" \
-F "checksum=somechecksum"\
-F "file=file.jpg"
Response
{
"error": [],
"result": {
"message": "Image uploaded"
}
}
Endpoint for user to upload fiat transfer proof to be checked.
Endpoint
https://api.bitwyre.com/private/account/deposit/fiat/uploadproof
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
transaction_id | string | true | Transaction ID. |
file | .png or .jpg | true | the image file |
Uploading KYC Files Mobile
Request
curl "https://api.bitwyre.com/private/uploadkycfiles-mobile" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: multipart/form-data" \
-X POST \
-F "payload={\"type\":1}" \
-F "nonce=17081945"\
-F "checksum=somechecksum"\
-F "file=file.jpg"
Response
{
"error": [],
"result": {
"success": true,
"message": "Successfully Upload Image"
}
}
Endpoint for user to upload Identities.
Endpoint
https://api.bitwyre.com/private/uploadkycfiles-mobile
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
type | enum-number | true | 0- NationalIdentity; 1 - DrivingLicense; 2 - Passport ; 3 - Selfie ; 99 - Others |
file | .png, .jpg, .pdf | true | the image file |
Uploading Fiat Deposit Proof Mobile
Request
curl "https://api.bitwyre.com/private/account/deposit/fiat/uploadproof-mobile" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: multipart/form-data" \
-X POST \
-F "payload={"transction_id":"b9443247-eb59-47ad-a9f4-f479d6b92111"}" \
-F "checksum=somechecksum"\
-F "file=file.jpg"
Response
{
"error": [],
"result": {
"message": "Successfully Upload Image"
}
}
Endpoint for user to upload fiat transfer proof to be checked.
Endpoint
https://api.bitwyre.com/private/account/withdrawal/fiat/uploadproof-mobile
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
transaction_id | string | true | Transaction ID. |
file | .png or .jpg | true | the image file |
Getting Support Tickets
Request
curl "https://api.bitwyre.com/private/support/ticket?page=1&per_page=3" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": [
{
"id": 3,
"priority": "Medium",
"closed_at": null,
"resolved_at": null,
"status": "Open",
"subject": "Test Ticket 3",
"type": "Incident"
},
{
"id": 2,
"priority": "Low",
"closed_at": "2021-01-12T09:18:23Z",
"resolved_at": "2021-01-12T09:18:23Z",
"status": "Closed",
"subject": "Test Ticket 2",
"type": "Problem"
},
{
"id": 1,
"priority": "Urgent",
"closed_at": "2021-01-07T13:22:08Z",
"resolved_at": "2021-01-07T13:22:08Z",
"status": "Closed",
"subject": "Test Ticket 1",
"type": "Refund"
}
]
}
Retrieve user's support tickets data.
Endpoint
https://api.bitwyre.com/private/support/ticket
Request Fields/Parameters
Parameter | Value | Required | Description |
---|---|---|---|
page | int | false | Page number |
per_page | int | false | Number result to show. Default 50 result per page |
Response Types
Returns a JSON array of support ticket details with following fields
JSON Field | Data Type | Remark |
---|---|---|
id | int | Freshdesk ticket ID |
priority | string | Ticket priority |
closed_at | string | Datetime of ticket closure |
resolved_at | string | Datetime of ticket settlement |
status | string | Current status of ticket |
subject | string | Subject of ticket |
type | string | Ticket type |
Create a Support Ticket
Request
curl "https://api.bitwyre.com/private/support/ticket" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X POST
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\
\"issue_type\": 1,\
\"priority\": 1,\
\"subject\": \"Test Subject\",\
\"description\": \"Test Description\",\
}\
}"
-F "file=file.jpg"
Response
{
"error": [],
"result": {
"message": "Successfully sent support ticket.",
"success": true
}
}
Retrieve user's support tickets data.
Endpoint
https://api.bitwyre.com/private/support/ticket
Request Fields/Parameters
JSON Field | Value | Required | Description |
---|---|---|---|
issue_type | int | true | Ticket type. See Issue Type Freshdesk |
priority | int | true | Ticket priority. See Priority Freshdesk |
subject | string | true | Subject of ticket. |
description | string | true | Description of ticket. |
file | binary | false | the image attachment file (in .png or .jpg or .jpeg or .pdf) |
Response Types
Returns a JSON array of support ticket details with following fields
JSON Field | Data Type | Remark |
---|---|---|
id | int | Freshdesk ticket ID |
priority | string | Ticket priority |
closed_at | string | Datetime of ticket closure |
resolved_at | string | Datetime of ticket settlement |
status | string | Current status of ticket |
subject | string | Subject of Ticket |
type | string | Ticket type |
Chat and Escrow API Endpoints
Get Chat Message
Request
curl "https://api.bitwyre.com/private/chat?nonce=17081945&checksum=<payload_checksum>&payload={\"counterparty\": <counterparty_username>}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"Counterparty": [
{
"from": "Active User",
"message": "Say Hi",
"timestamp": 1617946673962115000,
"to": "Counterparty"
},
{
"from": "Counterparty",
"message": "Say Hi Back",
"timestamp": 1617946673962115002,
"to": "Active User"
},
{
"from": "Active User",
"message": "Ask Question",
"timestamp": 1617946673962115004,
"to": "Counterparty"
},
{
"from": "Counterparty",
"message": "Answer Question",
"timestamp": 1617946673962115002,
"to": "Active User"
}
],
"Counterparty2": [
{
"from": "Active User",
"message": "Say Hi 2",
"timestamp": 1617946673962115000,
"to": "Counterparty2"
}
]
}
}
Retrieve user's chat message encrypted in Elliptic Curve Integrated Encryption Scheme (ECIES).
Endpoint
https://api.bitwyre.com/private/chat
Request Fields/Parameters
For showing chats on another username. Otherwise on if payload is not specified it automatically returns all valid chat
Payload Fields | Value | Required | Description |
---|---|---|---|
counterparty | string | false | the other user username chat to retrieve |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
chat counter party | string | the person who you are chatting with |
list of timestamp, encrypted messages | string | timestamp and encrypted messages |
... | ... | ... |
Send Chat Message
Request
curl "https://api.bitwyre.com/private/chat?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": \"I really like that painting\",\
}"
Response
{
"error": [],
"result": {
"timestamp": 1590654854095640000,
"message_id": "3e00e9f4-fe7a-45c9-9ed7-456d9e6518b3"
}
}
In the event that sending the chat is not successful
{
"error": ["Internal server error"],
"result": {}
}
Send a chat message.
Endpoint
https://api.bitwyre.com/private/chat
Request Fields/Parameters
Please refer to Authentication.
JSON Field | Value | Required | Description |
---|---|---|---|
"Payload" | string | True | Chat message |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
timestamp | Integer | Nanosecond timestamp |
message_id | UUID-String | The message ID |
Get Chat Message with Limit
Request
curl "https://api.bitwyre.com/private/chat/list?nonce=17081945&checksum=<payload_checksum>&payload={\"counterparty\": <counterparty_username>, limit: 5}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"Counterparty": [
{
"from": "Active User",
"message": "Say Hi",
"timestamp": 1617946673962115000,
"to": "Counterparty"
},
{
"from": "Counterparty",
"message": "Say Hi Back",
"timestamp": 1617946673962115002,
"to": "Active User"
},
{
"from": "Active User",
"message": "Ask Question",
"timestamp": 1617946673962115004,
"to": "Counterparty"
},
{
"from": "Counterparty",
"message": "Answer Question",
"timestamp": 1617946673962115002,
"to": "Active User"
}
],
"Counterparty2": [
{
"from": "Active User",
"message": "Say Hi 2",
"timestamp": 1617946673962115000,
"to": "Counterparty2"
}
]
}
}
Retrieve user's chat message encrypted in Elliptic Curve Integrated Encryption Scheme (ECIES) with limit data.
Endpoint
https://api.bitwyre.com/private/chat/list
Request Fields/Parameters
For showing chats on another username. Otherwise on if payload is not specified it automatically returns all valid chat
Payload Fields | Value | Required | Description |
---|---|---|---|
counterparty | string | false | the other user username chat to retrieve |
limit | int | false | number of retrieved chat data |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
chat counter party | string | the person who you are chatting with |
list of timestamp, encrypted messages | string | timestamp and encrypted messages |
... | ... | ... |
Search Chat Message
Request
curl "https://api.bitwyre.com/private/chat/search?nonce=17081945&checksum=<payload_checksum>&payload={\"keyword\":\"Hello\"}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET
Response
{
"error": [],
"result": {
"Counterparty": [
{
"from": "Active User",
"message": "Hello whats good?",
"timestamp": 1617946673962115000,
"to": "Counterparty"
},
{
"from": "Counterparty",
"message": "Hello, BTC is to the moon",
"timestamp": 1617946673962115002,
"to": "Active User"
}
]
}
}
In the event that searching the chat is not successful
{
"error": ["Internal server error"],
"result": {}
}
Search inside historial chats.
Endpoint
https://api.bitwyre.com/private/chat/search
Request Fields/Parameters
Payload Fields | Value | Required | Description |
---|---|---|---|
keyword | string | True | Chat message to be search |
counterparty | string | False | The other user username chat to retrieve |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
chat counter party | string | the person who you are chatting with |
list of timestamp, encrypted messages | string | timestamp and encrypted messages |
... | ... | ... |
Send Escrow Request
Request
curl "https://api.bitwyre.com/private/escrow" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {
\"base_asset\": \"btc\",\
\"base_asset_amount\":\"1000\",\
\"quote_asset\": \"eth\",\
\"quote_asset_amount\":\"3000\",\
\"counterparty\": \"counterparty\"}\
}"
Response
{
"error": [],
"result": {
"status": "pending",
"escrow_id": "76f7704b-85c7-4cb8-9a71-e48293616705",
"implied_price": "0.00000001 BTC/IDR",
"instrument": "btc_idr_spot",
"action": "Exchange 1 BTC for 100000000 IDR",
"counterparty": "John",
"fee_percentage": "0.01%",
"fee_amount": "0.01 BTC",
"order_time": 1495324800000000001,
"order_expiry_time": 1495424800000000001
}
}
Send an OTC escrow request
Endpoint
https://api.bitwyre.com/private/escrow
Request Fields/Parameters
Please refer to Authentication.
JSON Field | Value | Required | Description |
---|---|---|---|
"Payload" | string | True | base_asset, base_asset_amount, quote_asset, quote_asset_amount, counterparty |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
status | String | Acknoledgement that the post has been sent |
escrow_id | UUID-String | Unique ID for the escrow request |
implied_price | Float-String | Base Amount/Quote Amount |
instrument | String | Instrument Base/Quote |
action | String | A simple message about the trade |
counterparty | String | The counterparty username |
fee_percentage | Float-String | Amount of fee in percentage |
fee | Float-String | Amount of fee in quote asset |
order_time | Float-String | Nanosecond timestamp when order is specified |
order_expiry_time | Integer | Nanosecond timestamp when order would be expired |
Accepting An Escrow Request
Request
curl "https://api.bitwyre.com/private/escrow" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X PUT \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\"escrow_id\": \"9fa11e7f-afdf-4e89-a8a7-5a2d95a34026\"}
}"
Response
{
"error": [],
"result": {
"status": "processing",
"escrow_id": "9fa11e7f-afdf-4e89-a8a7-5a2d95a34026"
}
}
Accepting a OTC escrow request
Endpoint
https://api.bitwyre.com/private/escrow
Request Fields/Parameters
Please refer to Authentication.
JSON Field | Value | Required | Description |
---|---|---|---|
"Payload" | string | True | escrow_id |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
status | string | Current status of the trade |
escrow_id | UUID-String | Unique ID for the escrow request |
Declining An Escrow Request
Request
curl "https://api.bitwyre.com/private/escrow" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X DELETE \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\"escrow_id\": \"9fa11e7f-afdf-4e89-a8a7-5a2d95a34026\"}"
Response
{
"error": [],
"result": {
"status": "rejected",
"escrow_uuid": "76f7704b-85c7-4cb8-9a71-e48293616701",
"status_reason": "counterparty_reject"
}
}
Declining a OTC escrow request
Endpoint
https://api.bitwyre.com/private/escrow
Request Fields/Parameters
Please refer to Authentication.
JSON Field | Value | Required | Description |
---|---|---|---|
"Payload" | string | True | escrow_id |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
status | string | Current status of the trade |
escrow_id | UUID-String | Unique ID for the escrow request |
status_reason | Stringtring | Reason of the current status |
Escrow History
Request
curl "https://api.bitwyre.com/private/escrow/history/<escrow_uuid>" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET
Response
{
"error": [],
"result": [
{
"base_amount": 1.0,
"escrow_uuid": "cb60899c-7fd2-47b7-9de3-55d2f65e8855",
"counterparty": "John",
"counterparty_id": "0950831861a05539f5ec74f8d5faafddad70fdf385804955532beb91052e458a",
"fee_amount": "0.01 BTC",
"fee_percentage": "0.01%",
"implied_price": "0.00000001 BTC/IDR",
"instrument": "btc_idr_spot",
"message": "Lee asks John to exchange 1.0 BTC for 100000000.0 IDR",
"order_expiry_time": 1618825892598826000,
"order_time": 1618822292598826000,
"quote_amount": 100000000.0,
"requester": "Lee",
"requester_id": "127e50eb9a6646e2833fee8d69477c7371e2cbc5fbb0a37b7f83b58f02f512d9",
"status": "processing",
"status_reason": ""
},
{
"base_amount": 1.0,
"escrow_uuid": "cb60899c-7fd2-47b7-9de3-55d2f65e8857",
"counterparty": "John",
"counterparty_id": "0950831861a05539f5ec74f8d5faafddad70fdf385804955532beb91052e458a",
"fee_amount": "0.01 BTC",
"fee_percentage": "0.01%",
"implied_price": "0.00000001 BTC/IDR",
"instrument": "btc_idr_spot",
"message": "Lee asks John to exchange 1.0 BTC for 100000000.0 IDR",
"order_expiry_time": 1618825892598826000,
"order_time": 1618822292598826000,
"quote_amount": 100000000.0,
"requester": "Lee",
"requester_id": "127e50eb9a6646e2833fee8d69477c7371e2cbc5fbb0a37b7f83b58f02f512d9",
"status": "rejected",
"status_reason": "counterparty_reject"
}
]
}
History of a user's OTC escrow trades
Endpoint
https://api.bitwyre.com/private/escrow
Request Fields/Parameters
Please refer to Authentication.
Payload Fields | Value | Required | Description |
---|---|---|---|
escrow_uuid | string | false | the unique escrow identifier, when speficied "all" will return every escrow transaction |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
status | string | The current status of the trade |
status_reason | string | Reason for the status |
requester | string | The username who initiated the trade |
requester_id | Hash-string | The hashed uuid who initiated the trade |
counterparty | string | The counterparty username |
counterparty_id | Hash-string | The counterparty hashed uuid |
escrow_id | UUID-String | Unique ID for the escrow request |
implied_price | Float-String | Base Amount/Quote Amount |
instrument | String | Instrument Base/Quote |
base_amount | String | The base amount to be traded |
quote_amount | String | The quote amount to be traded |
message | String | A simple message explaining the trade |
fee_percentage | Float-String | Amount of fee in percentage |
fee | Float-String | Amount of fee in quote asset |
timestamp | Integer | Nanosecond timestamp when order was specified |
order_expiry_time | Integer | Nanosecond timestamp when order would be expired |
Escrow History Pending
Request
curl "https://api.bitwyre.com/private/escrow/pending" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET
Response
{
"error": [],
"result": [
{
"base_amount": 1.0,
"escrow_uuid": "cb60899c-7fd2-47b7-9de3-55d2f65e8855",
"counterparty": "John",
"counterparty_id": "0950831861a05539f5ec74f8d5faafddad70fdf385804955532beb91052e458a",
"fee_amount": "0.01 BTC",
"fee_percentage": "0.01%",
"implied_price": "0.00000001 BTC/IDR",
"instrument": "btc_idr_spot",
"message": "Lee asks John to exchange 1.0 BTC for 100000000.0 IDR",
"order_expiry_time": 1618825892598826000,
"order_time": 1618822292598826000,
"quote_amount": 100000000.0,
"requester": "Lee",
"requester_id": "127e50eb9a6646e2833fee8d69477c7371e2cbc5fbb0a37b7f83b58f02f512d9",
"status": "processing",
"status_reason": ""
},
{
"base_amount": 1.0,
"escrow_uuid": "cb60899c-7fd2-47b7-9de3-55d2f65e8857",
"counterparty": "John",
"counterparty_id": "0950831861a05539f5ec74f8d5faafddad70fdf385804955532beb91052e458a",
"fee_amount": "0.01 BTC",
"fee_percentage": "0.01%",
"implied_price": "0.00000001 BTC/IDR",
"instrument": "btc_idr_spot",
"message": "Lee asks John to exchange 1.0 BTC for 100000000.0 IDR",
"order_expiry_time": 1618825892598826000,
"order_time": 1618822292598826000,
"quote_amount": 100000000.0,
"requester": "Lee",
"requester_id": "127e50eb9a6646e2833fee8d69477c7371e2cbc5fbb0a37b7f83b58f02f512d9",
"status": "processing",
"status_reason": ""
}
]
}
Return all still pending escrow request for the current user only
Endpoint
https://api.bitwyre.com/private/escrow
Request Fields/Parameters
Please refer to Authentication.
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
status | string | The current status of the trade |
status_reason | string | Reason for the status |
requester | string | The username who initiated the trade |
requester_id | Hash-string | The hashed uuid who initiated the trade |
escrow_id | UUID-String | Unique ID for the escrow request |
implied_price | Float-String | Base Amount/Quote Amount |
instrument | String | Instrument Base/Quote |
base_amount | String | The base amount to be traded |
quote_amount | String | The quote amount to be traded |
message | String | A simple message explaining the trade |
fee_percentage | Float-String | Amount of fee in percentage |
fee | Float-String | Amount of fee in quote asset |
timestamp | Integer | Nanosecond timestamp when order was specified |
order_expiry_time | Integer | Nanosecond timestamp when order would be expired |
Send Forum Posts
Request
curl "https://api.bitwyre.com/private/forum?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X POST \
-d "{\
\"nonce\": 17081945,\
\"checksum\": \"somechecksum\",\
\"payload\": {\"post\": \"this be posts\",\"tagged\":\"john\"}\
}"
Response
{
"error": [],
"result": {
"success": true,
"timestamp": 1590654854095640000
}
}
Send a forum post
Endpoint
https://api.bitwyre.com/private/forum
Request Fields/Parameters
Please refer to Authentication.
JSON Field | Value | Required | Description |
---|---|---|---|
"Payload" | string | True | Post message |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
success | Bool | Acknoledgement that the post has been sent |
timestamp | Integer | Nanosecond timestamp |
Get Forum Posts
Request
curl "https://api.bitwyre.com/private/forum?nonce=17081945&checksum=<payload_checksum>&payload={\"tagged\":\"John\",\"poster\":\"Jane\",\"from_time\":\"123123\",\"to_time\":\"123123123\"}" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-H "Content-Type: application/json" \
-X GET \
Response
{
"error": [],
"result": [
{
"post": "ola",
"poster": "Jane",
"tagged": "John",
"timestamp": 1618212090462703000
}
]
}
Send a forum post
Endpoint
https://api.bitwyre.com/private/forum
Request Fields/Parameters
Please refer to Authentication.
JSON Field | Value | Required | Description |
---|---|---|---|
"Payload" | string | True | Tagged user, time range |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
success | Bool | Acknoledgement that the post has been sent |
timestamp | Integer | Nanosecond timestamp |
Posts | String | Received posts |
Getting Referrals Info
Request
curl "https://api.bitwyre.com/private/referrals?nonce=17081945&checksum=<payload_checksum>&payload=" \
-H "API-Key: someapikey" \
-H "API-Sign: somesignature" \
-X GET
Response
{
"error": [],
"result": {
"total_invited": 1,
"total_earned": { "btc": "0.001", "idr": "1000" }
}
}
Retrieve referrals info.
Endpoint
https://api.bitwyre.com/private/referrals
Request Fields/Parameters
Because this is a GET endpoint, nonce
& checksum
are query parameters, also payload
should be always an empty string.
The SHA256
steps for this endpoint's payload:
- jsonify an empty string.
- then SHA256 from above result.
Please refer to Authentication.
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
total_invited | int | People you invite |
total_earned | int | Total earned group by asset |
OTC
Get Crypto Networks
curl "https://api.bitwyre.com/app/otc/wallet/network" \
-H "Authorization: Bearer <access_token>" \
-X GET
Response
{
"error": [],
"result": [
{
"deposit_wallet_id": 13689,
"withdrawal_wallet_id": 13688,
"coin": "btc"
},
{
"deposit_wallet_id": 13687,
"withdrawal_wallet_id": 13686,
"coin": "eth"
},
{
"deposit_wallet_id": 13694,
"withdrawal_wallet_id": 13693,
"coin": "sol"
}
]
}
Retrieve list of available crypto networks
Endpoint
https://api.bitwyre.com/app/otc/wallet/network
Request Fields/Parameters
None
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
deposit_wallet_id | int | ID for Wallet Deposit |
withdrawal_wallet_id | int | ID for Wallet Withdrawal |
coin | string | Crypto Asset |
Get Crypto Wallet Balances
curl "https://api.bitwyre.com/app/otc/wallet/balance" \
-H "Authorization: Bearer <access_token>" \
-X GET
Response
{
"error": [],
"result": {
"data": [
{
"asset": "eth",
"icon_url": "https://robin.bitwyre.id/app/Raster/ETH_125px.png",
"asset_name": "Ethereum",
"total_balance": "2.34360451",
"type": "crypto",
"available_balance": "2.33076451",
"locked_balance": "0.01284"
},
{
"asset": "btc",
"icon_url": "https://robin.bitwyre.id/app/Raster/BTC_125px.png",
"asset_name": "Bitcoin",
"total_balance": "0.01291978",
"type": "crypto",
"available_balance": "0.01291978",
"locked_balance": "0"
},
],
"metadata": {
"page": 1,
"has_next": true
}
}
}
Retrieve list of user's available crypto wallet
Endpoint
https://api.bitwyre.com/app/otc/wallet/balance
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
type | string | true | Asset Type. Possible values are crypto |
page | string | true | Number of page of data that will be returned |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
asset | string | Asset |
icon_url | int | Asset icon URL |
asset_name | string | Asset name |
total_balance | string | User total balance |
type | string | Asset type |
available_balance | string | User available balance |
locked_balance | string | User locked balance |
Get Crypto Asset Lists
curl "https://api.bitwyre.com/app/otc/assets" \
-H "Authorization: Bearer <access_token>" \
-X GET
Response
{
"errors": [],
"result": [
{
"asset": "audf",
"name": "Australian Dollar Forte",
"icon_url": "https://robin.bitwyre.id/app/Raster/AUDF_125px.png"
},
{
"asset": "bidr",
"name": "Binance IDR Token",
"icon_url": "https://robin.bitwyre.id/app/Raster/BIDR_64px.png"
},
]
}
Retrieve list of available assets
Endpoint
https://api.bitwyre.com/app/otc/assets
Request Fields/Parameters
None
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
asset | string | Asset |
name | string | Asset name |
icon_url | int | Asset icon URL |
Generate Deposit Address
curl "https://api.bitwyre.com/app/otc/wallet/deposit?asset=eth&wallet_id={wallet_id}" \
-H "Authorization: Bearer <access_token>" \
-X GET
Response
{
"errors": [],
"result": {
"address": "0x1E210A64a7Bf01A4d6a021013A048F51dc0eDDE4",
"asset": "eth"
}
}
Generate Deposit Address For Wallet Balance OTC
Endpoint
https://api.bitwyre.com/app/otc/wallet/deposit?asset=eth&wallet_id={wallet_id}
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
asset | string | true | Asset Name. Possible values are in asset list |
wallet_id | int | true | Deposit Wallet ID from list networks |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
address | string | Address to deposit |
asset | string | Asset name |
Get Deposit Histories
curl "https://api.bitwyre.com/app/otc/wallet/deposit/histories?asset=btc" \
-H "Authorization: Bearer <access_token>" \
-X GET
Response
{
"errors": [],
"result": {
"data": [
{
"asset": "btc",
"date": "2023-12-20T05:45:11Z",
"gross_amount": "0.0001",
"nett_amount": "0.0001",
"fees": "0.00000416",
"txn": "https://blockstream.info/testnet/tx/d71767937f6a9486a6d70c524a081d70edc185c33585062f965ae417473b766b",
"status": "success"
},
{
"asset": "btc",
"date": "2023-12-20T05:44:39Z",
"gross_amount": "0.001",
"nett_amount": "0.001",
"fees": "0.00000143",
"txn": "https://blockstream.info/testnet/tx/b01850726154ef2ba586981eeabd69ac3fb778ae642cd8214c1af779580aa1d9",
"status": "success"
},
]
}
}
Get User Deposit Histories
Endpoint
https://api.bitwyre.com/app/otc/wallet/deposit/histories?asset={asset}
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
asset | string | true | Asset Name. Possible values are in asset list |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
asset | string | Asset name |
date | string | Deposit datetime |
gross_amount | string | Gross amount of deposit value |
nett_amount | string | Nett amount of deposit value |
fees | string | Deposit fee amount |
txn | string | Detail transaction URL |
status | string | Deposit status |
Get Withdrawal Histories
curl "https://api.bitwyre.com/app/otc/wallet/withdraw/histories?asset=eth" \
-H "Authorization: Bearer <access_token>" \
-X GET
Response
{
"errors": [],
"result": {
"data": [
{
"asset": "eth",
"date": "2023-12-20T09:39:12Z",
"gross_amount": "0.0012",
"nett_amount": "0.0012",
"fees": "0.000126",
"requested_amount": "0.0012",
"txn": "https://goerli.etherscan.io/tx/0x2016da3735503b8e2acbe3f3a76add7a7016988e5a333c6c9000135eac7c3a60",
"status": "confirmed"
},
{
"asset": "eth",
"date": "2023-12-19T21:54:24Z",
"gross_amount": "0.00329",
"nett_amount": "0.00329",
"fees": "0.000126",
"requested_amount": "0.00329",
"txn": "https://goerli.etherscan.io/tx/0x9951abfee7f69ae9bad086eabb5db04af4f9ad5c7fcb79548bd79902ec8fe73e",
"status": "confirmed"
},
]
}
}
Get User Withdrawal Histories
Endpoint
https://api.bitwyre.com/app/otc/wallet/withdraw/histories?asset={asset}
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
asset | string | true | Asset Name. Possible values are in asset list |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
asset | string | Asset name |
date | string | Withdrawal datetime |
gross_amount | string | Gross amount of withdrawal |
nett_amount | string | Nett amount of withdrawal |
fees | string | Withdrawal fee amount |
requested_amount | string | Total amount requested |
txn | string | Detail Withdrawal transaction URL |
status | string | Withdrawal status |
List Orders
curl "https://api.bitwyre.com/app/otc/orders?page=1" \
-H "Authorization: Bearer <access_token>" \
-X GET
Response
{
"errors": [],
"result": {
"data": [
{
"order_uuid": "163790b7-ee29-4688-80e7-7c28b761b312",
"instrument": "usdt_btc",
"side": "buy",
"rate_offers": "42433.39",
"qty": "10000.00",
"fee": "848.6677810308",
"total_received": "41584.7222189692",
"fee_percentage": 0.02,
"order_status": "need_confirmation",
"settlement_date": "2023-12-16T15:46:19Z",
"canceled_reason": null,
"created_at": "2023-12-14T15:46:19Z",
"updated_at": "2023-12-14T15:46:19Z",
"base_asset": {
"asset": "usdt",
"name": "USD Tether Stablecoin",
"icon_url": "https://robin.bitwyre.id/app/Raster/USDT_125px.png"
},
"quote_asset": {
"asset": "btc",
"name": "Bitcoin",
"icon_url": "https://robin.bitwyre.id/app/Raster/BTC_125px.png"
}
},
]
}
}
List of quote orders
Endpoint
https://api.bitwyre.com/app/otc/orders?page=1
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
page | int | false | page number for pagination |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
order_uuid | string | Order identifiers |
instrument | string | Order pairs information, example: eth_btc |
side | string | Order Side (deprecated soon) |
rate_offers | string | Rate for target assets |
qty | string | Order qty amount |
fee | string | Order fee amount |
total_received | string | Total amount that client will be received |
order_status | string | Current order status |
settlement_date | string | User settlement date that client requested |
canceled_reason | string | Reason if order got cancelled |
created_at | string | Order creation date |
updated_at | string | Order updated date |
base_asset | object | From asset information |
quote_asset | object | Target asset information |
Create Order
curl "https://api.bitwyre.com/app/otc/orders" \
-H "Authorization: Bearer <access_token>" \
-X POST \
--header 'Content-Type: application/json' \
--data '{
"instrument": "eth_btc",
"qty": "100",
"fee_percentage": 0.2,
"settlement_date": "2023-12-30"
}'
Response
{
"errors": [],
"result": {
"order_uuid": "4bf1fc83-5092-4c59-8247-3cc8cf2c3b3c"
}
}
Order Creation (Order Quotes)
Endpoint
https://api.bitwyre.com/app/otc/orders
Request Fields/Parameters
Body Parameter | Data Type | Required | Remark |
---|---|---|---|
instrument | string | true | Pairs information in FROM_TARGET format |
qty | string | true | Order quantity of FROM asset |
fee_percentage | float | true | Total fee of the order |
settlement_date | stringdate | true | Client settlement date request |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
order_uuid | string | Order created identifiers |
Update Order Status
curl "https://api.bitwyre.com/app/otc/orders/{order_uuid}" \
-H "Authorization: Bearer <access_token>" \
-X PUT \
--header 'Content-Type: application/json' \
--data '{
"status": "accepted",
"reason": ""
}'
Response
{
"errors": [],
"result": {
"success": true
}
}
Order Update (Quotes Confirmation)
Endpoint
https://api.bitwyre.com/app/otc/orders/{order_uuid}
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
order_uuid | string | true | Order identifiers to confirm |
Body Parameter | Data Type | Required | Remark |
---|---|---|---|
status | string | true | Status of orders confirmation, available values: accepted , rejected , cancelled |
reason | string | false | Cancellation reason (if applicable) |
Response Types (JSON Object as Key-Value Pair)
JSON Field | Data Type | Remark |
---|---|---|
success | bool | Result of operation |
Update Order Payment Data
Bank Payment
shell curl "https://api.bitwyre.com/app/otc/orders/{order_uuid}/payment" \ -H "Authorization: Bearer <access_token>" \ -X PUT \ --header 'Content-Type: application/json' \ --data '{ "type": "balance", "bank": { { "bank": "BCA", "bank_account_name": "bitwyre", "bank_account_number": "08123481313", "bank_swiftcode": "", "bank_country": "idr", } } }'
Crypto
shell curl "https://api.bitwyre.com/app/otc/orders/{order_uuid}/payment" \ -H "Authorization: Bearer <access_token>" \ -X PUT \ --header 'Content-Type: application/json' \ --data '{ "type": "crypto", "crypto": { "crypto_asset": "btc", "crypto_address": "1badadaajfafafkaafa" } }'
Response
{
"errors": [],
"result": {
"success": true
}
}
Endpoint
https://api.bitwyre.com/app/otc/orders/{order_uuid}/payment
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
order_uuid | string | true | Order identifiers to confirm |
Body Parameter | Data Type | Required | Remark |
---|---|---|---|
type | string | true | type of payment. available types : balance and crypto |
crypto | object | false | {"crypto_asset": "btc", "crypto_address": "1badadadaddad"} |
balance | object | false | {"bank": "BCA", "bank_account": "1badadadaddad", "banck_account_number": "13145225252", "bank_swiftcode": "DDJIA", "bank_country": "idr"} |
For update payment all address is internal address from bitwyre (generated by user via our platform)
Update Order Settlement Data
Bank Payment
shell curl "https://api.bitwyre.com/app/otc/orders/{order_uuid}/settlement" \ -H "Authorization: Bearer <access_token>" \ -X PUT \ --header 'Content-Type: application/json' \ --data '{ "type": "balance", "bank": { { "bank": "BCA", "bank_account_name": "bitwyre", "bank_account_number": "08123481313", "bank_swiftcode": "", "bank_country": "idr", } } }'
Crypto
shell curl "https://api.bitwyre.com/app/otc/orders/{order_uuid}/settlement" \ -H "Authorization: Bearer <access_token>" \ -X PUT \ --header 'Content-Type: application/json' \ --data '{ "type": "crypto", "crypto": { "crypto_asset": "btc", "crypto_address": "1badadaajfafafkaafa" } }'
Response
{
"errors": [],
"result": {
"success": true
}
}
Endpoint
https://api.bitwyre.com/app/otc/orders/{order_uuid}/settlement
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
order_uuid | string | true | Order identifiers to confirm |
Body Parameter | Data Type | Required | Remark |
---|---|---|---|
type | string | true | type of payment. available types : balance and crypto |
crypto | object | false | {"crypto_asset": "btc", "crypto_address": "1badadadaddad"} |
balance | object | false | {"bank": "BCA", "bank_account": "1badadadaddad", "banck_account_number": "13145225252", "bank_swiftcode": "DDJIA", "bank_country": "idr"} |
For update payment all address is external address (user personal wallet)
Withdrawal Request
Request
shell curl "https://api.bitwyre.com/app/otc/wallet/withdrawl" \ -H "Authorization: Bearer <access_token>" \ -X POST \ --header 'Content-Type: application/json' \ --data '{ "target_address": "bc1q8cgmzxm5yp3e452jnzw2k6ad530uujl6ekvpcv", "asset": "btc", "amount": "0.0000341" }'
Response
{
"errors": [],
"result": {
"success": true
}
}
Endpoint
https://api.bitwyre.com/app/otc/wallet/withdraw
Request Fields/Parameters
Body Parameter | Data Type | Required | Remark |
---|---|---|---|
target_address | string | true | user personal destination address |
asset | string | true | asset |
amount | string | true | amount to deduct |
List Transaction OTC
Request
shell curl "https://api.bitwyre.com/app/otc/transaction?page=1" \ -H "Authorization: Bearer <access_token>" \ -X POST \ --header 'Content-Type: application/json'
Response
shell { "errors": [], "result": { "data": [ { "tx_uuid": "b67d4f7c-7f41-48f4-95ae-af972b66d100", "instrument": "eth_btc", "order_uuid": "4bf1fc83-5092-4c59-8247-3cc8cf2c3b3c", "order_status": 2, "order_side": 1, "order_qty": "100.00", "order_total_received": "5.1589505409", "tx_status": 1, "tx_type": "crypto/crypto", "payment_type": null, "payment_status": null, "payment_complete_date": null, "payment_bank": null, "payment_bank_account_name": null, "payment_bank_account_number": null, "payment_bank_swiftcode": null, "payment_bank_country": null, "payment_crypto_asset": null, "payment_crypto_address": null, "settlement_type": null, "settlement_status": null, "settlement_complete_date": null, "settlement_bank": null, "settlement_bank_account_name": null, "settlement_bank_account_number": null, "settlement_bank_swiftcode": null, "settlement_bank_country": null, "settlement_crypto_asset": null, "settlement_crypto_address": null, "created_at": "2023-12-20T12:10:28Z", "updated_at": "2023-12-20T12:10:28Z", "base_asset": { "asset": "eth", "name": "Ethereum", "icon_url": "https://robin.bitwyre.id/app/Raster/ETH_125px.png" }, "quote_asset": { "asset": "btc", "name": "Bitcoin", "icon_url": "https://robin.bitwyre.id/app/Raster/BTC_125px.png" } }, { "tx_uuid": "b45a660a-f182-40c3-a2d8-8bc357e3b507", "instrument": "eth_btc", "order_uuid": "5f11c4f2-302f-48ef-88a4-27b8112fc65c", "order_status": 2, "order_side": 1, "order_qty": "0.0090", "order_total_received": "0.0009", "tx_status": 3, "tx_type": "crypto/crypto", "payment_type": 3, "payment_status": "completed", "payment_complete_date": "2023-12-14T15:03:40Z", "payment_bank": "", "payment_bank_account_name": "", "payment_bank_account_number": "", "payment_bank_swiftcode": null, "payment_bank_country": null, "payment_crypto_asset": "", "payment_crypto_address": "", "settlement_type": 3, "settlement_status": null, "settlement_complete_date": "2023-12-14T15:13:12Z", "settlement_bank": "", "settlement_bank_account_name": "", "settlement_bank_account_number": "", "settlement_bank_swiftcode": null, "settlement_bank_country": null, "settlement_crypto_asset": "", "settlement_crypto_address": "", "created_at": "2023-12-14T14:51:39Z", "updated_at": "2023-12-14T15:13:12Z", "base_asset": { "asset": "eth", "name": "Ethereum", "icon_url": "https://robin.bitwyre.id/app/Raster/ETH_125px.png" }, "quote_asset": { "asset": "btc", "name": "Bitcoin", "icon_url": "https://robin.bitwyre.id/app/Raster/BTC_125px.png" } } ], "metadata": { "page": 1, "has_next": false } } }
Endpoint
https://api.bitwyre.com/app/otc/transaction?page=1
Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
page | string | true | page |
Websocket Public API Endpoints
WS Server Time
Connecting
websocat -E "wss://api.bitwyre.com/ws/public/time"
Streaming Responses (1 Hz)
{"unixtime":1571744594571020435}
{"unixtime":1571744595571648685}
{"unixtime":1571744596571345719}
{"unixtime":1571744597571387480}
...
Streams server's time every second.
This helps in approximating the time difference between the server and client.
WS Endpoint
wss://api.bitwyre.com/ws/public/time
WS Request Fields/Parameters
WS Streaming Data Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
"unixtime" | big-number/i64 | unix time in nanoseconds |
Websocket Stream
Connecting
websocat -E "wss://api.bitwyre.com/ws/stream"
Bitwyre allows subscribing to real-time data. This access is not rate-limited once connected and is the best way to get the most up-to-date data to your programs.
To subscribe to topics, send them as a comma-separated list in your connection string. For example:
websocat -E wss://api.bitwyre.com/ws/stream
If you are already connected and wish to subscribe to a new topic, send a message with the following format:
{"op": "subscribe", "args": [<SubscriptionTopic1>, <SubscriptionTopic2>, ...]}
You may subscribe to multiple topics at a time by sending an array of subscription topics.
The following subscription topics are available without authentication:
Topic Subscription | Data Description |
---|---|
announcement | Site announcements |
markets | The markets supported by Bitwyre e.g crypto, equities, commodities, fixed_income |
products | The products supported by Bitwyre |
assets | The assets supported by Bitwyre |
instruments:market_product_country | The instrument supported by Bitwyre in the format ex. btc_usdt_spot for jurisdictions |
contract | The contract details for a derivative instrument/asset pair traded at Bitwyre |
ticker:instrument | The ticker stream supported for instruments at Bitwyre |
trades:instrument | The trades stream supported for instruments at Bitwyre |
depthl2:instrument | The L2 (full snapshot) depth stream supported for instruments at Bitwyre |
depthl2_10:instrument | The L2 (full snapshot) top 10 depth stream supported for instruments at Bitwyre |
depthl2_25:instrument | The L2 (full snapshot) top 25 depth stream supported for instruments at Bitwyre |
depthl2_incr:instrument | The L2 (incremental/changes) only stream supported for instruments at Bitwyre |
depthl3:instrument | The L3 market data stream supported for instruments at Bitwyre |
If you wish to get real-time order book data, we recommend you use the depthl2_25 subscription. depth10 pushes the top 10 levels on every tick, but transmits much more data. depthl2 pushes the full L2 order book, but the payload can get very large. orderbookL2_25 provides a subset of the full L2 orderbook, but is throttled. In the future, depth10 may be throttled, so use depthl2 in any latency-sensitive application. For those curious, the id on an depthl2_25 or depthl2 entry is a composite of price and symbol, and is always unique for any given price level. It should be used to apply update and delete actions.
When applicable, subjects may be filtered to a given instrument by appending a colon and instrument name. For example, trade:btc_usdt_spot will subscribe you to messages only for the btc_usdt_spot instrument.
Example traffic data would be
> {"op": "subscribe", "args": ["depthl2:btc_usdt_spot"]}
< {"success":true,"subscribe":"depthl2:btc_usdt_spot","request":{"op":"subscribe","args":["depthl2:btc_usdt_spot"]}}
< {
"table": "depthl2",
"action": "snapshot",
"data": {
"instrument": "btc_usdt_spot",
"bids": [
{
"price": "41787.99",
"qty": "0.00019"
},
{
"price": "41786.99",
"qty": "0.00019"
},
{
"price": "41785.99",
"qty": "0.00019"
},
],
"asks": [
{
"price": "41893.88",
"qty": "0.00025"
},
{
"price": "41894.88",
"qty": "0.00025"
},
{
"price": "41895.88",
"qty": "0.00025"
},
]
}
}
...
Upon subscription, you will receive an image of the existing data, so you can get started. This comes through as a snapshot action.
You may receive other messages before the snapshot comes through. In that case, drop any messages received until you have received the snapshot.
Some notes on this response:
- After the subscription acknowledgement, you will receive a message with "action": "snapshot". This is an image of the table, after which you can apply incremental changes.
- If you receive any messages before the snapshot, ignore them.
- The partial also contains some table information, like keys, types. Depending on your application, this data may be useful.
- Columns listed in keys always come back on an insert, delete, or update. Use them to look up which items to modify in your storage.
You may unsubscribe using the 'unsubscribe' operation. The formatting is identical to 'subscribe'. Several stream channels are described below.
WS Instruments
Connecting and Query/Request
websocat -E "wss://api.bitwyre.com/stream"
Query Response
> {"op": "subscribe", "args": ["instruments:crypto_spot_ID"]}
< {"success":true,"subscribe":"instruments:crypto_spot_ID","request":{"op":"subscribe","args":["instruments:crypto_spot_ID"]}}
< {
"table":"instruments:crypto_spot_ID",
"keys":["instrument", "symbol"],
"types": {"str", "str"}
"action": "snapshot",
"data": [
{"instrument": "btc_idr_spot", "symbol" : "BTC/IDR"},
{"instrument": "bch_idr_spot", "symbol": "BCH/IDR"},
{"instrument": "eth_idr_spot", "symbol": "ETH/IDR"},
...
]
}
...
Returns an underscore _
delimited tradable asset instruments array.
A sample response for a futures market in crypto:
Request
websocat -E "wss://api.bitwyre.com/stream"
Response
> {"op": "subscribe", "args": ["instruments:crypto_futures_PA"]}
< {"success":true,"subscribe":"instruments:crypto_futures_PA","request":{"op":"subscribe","args":["instruments:crypto_futures_PA"]}}
< {
"table":"instruments:crypto_futures_PA",
"keys":["instrument", "symbol"],
"types": {"str", "str"}
"action": "snapshot",
"data": [
{"instrument": "btcusdtx_usdt_200607F1000000", "symbol" : "BTCM0"}, # BTC USD Index, futures contract, settled in USD, delivery on June 7th 2020, strike price of 10000 USD
{"instrument": "bchusdtx_usdt_200607F30000", "symbol": "BCHM0"}, # BCH USD Index, futures contract, settled in USD, delivery on June 7th 2020, strike price of 300 USD
{"instrument": "ethusdtx_usdt_200607F50000", "symbol": "ETHM0"}, # ETH USD Index, futures contract, settled in USD, delivery on June 7th 2020, strike price of 300 USD
...
]
}
...
We are using an _
(underscore) delimited convention to refer our futures and options product: underlying_settlementcurrency_productdetails
.
- Underlying financial instrument price.
btcusdtx
here is the Bitcoin to USD index on Bitwyre's exchange; a weighted average of worldwide Bitcoin spot market index price. - Settlement currency,
USD
. - Product details:
- Expiration date: 6 digits in the
YYMMDD
format. - Products:
F
for Futures.- For Options, either
P
forput
orC
forcall
. S
for Swaps.
- Strike price: settlement currency in cents (For this
USD
example,10000
here means100
dollars).
- Expiration date: 6 digits in the
A sample response for an options market in crypto:
Request
websocat -E "wss://api.bitwyre.com/stream"
Response
> {"op": "subscribe", "args": ["instruments:crypto_futures_PA"]}
< {"success":true,"subscribe":"instruments:crypto_futures_PA","request":{"op":"subscribe","args":["instruments:crypto_futures_PA"]}}
< {
"table":"instruments:crypto_futures_PA",
"keys":["instrument", "symbol"],
"types": {"str", "str"}
"action": "snapshot",
"data": [
{"instrument": "btcusdtx_usdt_200607C1000000", "symbol" : "BTCM0"}, # BTC USD Index, call options, settled in USD, delivery on June 7th 2020, strike price of 10000 USD
{"instrument": "bchusdtx_usdt_200607C30000", "symbol" : "BCHM0"}, # BCH USD Index, call options, settled in USD, delivery on June 7th 2020, strike price of 300 USD
{"instrument": "ethusdtx_usdt_200607C50000", "symbol" : "ETHM0"}, # ETH USD Index, call options, settled in USD, delivery on June 7th 2020, strike price of 300 USD
{"instrument": "btcusdtx_usdt_200607P500000", "symbol" : "BTCM0"}, # BTC USD Index, put options, settled in USD, delivery on June 7th 2020, strike price of 5000 USD
{"instrument": "bchusdtx_usdt_200607P10000", "symbol" : "BCHM0"}, # BCH USD Index, put options, settled in USD, delivery on June 7th 2020, strike price of 100 USD
{"instrument": "ethusdtx_usdt_200607P10000", "symbol" : "ETHM0"}, # ETH USD Index, put options, settled in USD, delivery on June 7th 2020, strike price of 100 USD
...
]
}
...
The product btcusdtx_usdt_200607C1000000
means a call contract
with delivery on June 7th, 2020
, at the strike price of 10,000
of the underlying financial instrument BTCUSDX
). btcusdtx_usdt_200607P200000
means a put contract
with delivery on June 7th, 2020
, at the strike price of 2,000
of the underlying financial instrument BTCUSDX
).
Returns a comma delimited tradable asset instruments array.
WS Endpoint
wss://api.bitwyre.com/ws/public/instruments
WS Request Fields/Parameters
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"market" | string | true | crypto , equities , fixed_income , or commodities |
"product" | string | true | spot , futures , options , or swaps |
"country" | string | true | ISO 3166-2 Country Code. Only ID or PA for now |
WS Response Types (JSON Array)
JSON Field | Data Type | Remark |
---|---|---|
JSON-array | string | base asset, quote asset, product filter, delimited with an _ (underscore). |
WS Ticker
Connecting
websocat -E "wss://api.bitwyre.com/stream"
Streaming Responses (on new ticker)
> {"op": "subscribe", "args": ["ticker:btc_usdt_spot"]}
< {"success":true,"subscribe":"ticker:btc_usdt_spot","request":{"op":"subscribe","args":["ticker:btc_usdt_spot"]}}
< {
"table":"ticker:btc_usdt_spot",
"keys":["instrument", "asset_base", "asset_quote", "high", "low", "percent_change", "vol_base", "vol_quote", "percent_change", "vol_base", "vol_quote", "last", "best_bid", "best_ask", "timestamp", "market", "product", "is_frozen"],
"types": {"str", "str", "str", "str", "str", "str", "str", "str", "str", "str", "str", "str", "str", "str", "bool"}
"action": "insert",
"data": {
"instrument": "btc_usdt_spot",
"asset_base": "btc",
"asset_quote": "usdt",
"high": "126989000",
"low": "115201000",
"percent_change": "-2.123",
"vol_base": "611.66499447",
"vol_quote": "7434324.9431",
"last": "124783000",
"best_bid": "124761000",
"best_ask": "124777000",
"timestamp": 1571744594571020435,
"market": "crypto",
"product": "spot",
"is_frozen": false
}
}
...
...
Streams new ticker information for an asset pair, if no asset pair specified the websocket service will stream all instruments ticker.
WS Endpoint
wss://api.bitwyre.com/stream
WS Request Fields/Parameters (during handshake)
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"instrument" | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
If the instrument
paremeter is empty or omitted, will return the ticker data of all available asset instruments.
WS Streaming Data Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
"instrument" | string | base asset, quote asset, product filter, delimited with an _ (underscore). |
"asset_base" | string | base asset in the trade pair |
"asset_quote" | string | quote asset in the trade pair |
"high" | float-string | highest market price in the last 24 hours |
"low" | float-string | lowest market price in the last 24 hours |
"percent_change" | float-string | market price change percentage in the last 24 hours (up to 8 precision). |
"vol_base" | float-string | total market volume of the base asset in the last 24 hours |
"vol_quote" | float-string | total market volume of the quote asset in the last 24 hours |
"last" | float-string | last market price for the base asset |
"best_bid" | float-string | current highest bid price |
"best_ask" | float-string | current lowest ask price |
"timestamp" | big-integer | ticker timestamp, unixtime in nanoseconds |
"market" | enum-string | "spot", "futures", "perpetual_swap", "options" |
"is_frozen" | boolean | market frozen status |
WS Trades
Connecting
websocat -E "wss://api.bitwyre.com/stream"
Streaming Responses (on new trade)
> {"op": "subscribe", "args": ["trades:btc_usdt_options"]}
< {"success":true,"subscribe":"trades:btc_usdt_options","request":{"op":"subscribe","args":["trades:btc_usdt_options"]}}
< {
"table":"trades:btc_usdt_options",
"keys":["instrument", "price", "volume", "value", "side". "id", "timestamp"],
"types": {"str", "str", "str", "str", "str", "str", "int"}
"action": "insert",
"data": {
"instrument": "btc_usdt_options",
"price": "9000",
"volume": "2",
"value": "18000",
"side": 1,
"id": "a911b7c0-e431-424f-9f05-49a8ef0c7d93",
"timestamp": 1571744594571020435
}
}
...
Streams new trade information for an asset pair, if no asset pair specified the websocket service will stream all instruments new trade.
WS Endpoint
wss://api.bitwyre.com/stream
WS Request Fields/Parameters (during handshake)
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"instrument" | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
WS Streaming Data Types (Array of JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
"instrument" | string | base asset, quote asset, product filter, delimited with an _ (underscore). |
"price" | float-string | price/quote asset of the traded base asset |
"volume" | float-string | volume of the traded base asset |
"value" | float-string | quote value (price x volume) |
"side" | enum-number | trade type ( 1 - buy; 2 - sell ) |
"id" | uuid-string | universal unique id of the trade |
"timestamp" | big-integer | trade timestamp, unixtime in nanoseconds |
WS Depth L2
Connecting
websocat -E "wss://api.bitwyre.com/stream"
Streaming Responses (on orderbook change)
> {"op": "subscribe", "args": ["depthl2:btc_usdt_spot"]}
< {"success":true,"subscribe":"depthl2:btc_usdt_spot","request":{"op":"subscribe","args":["depthl2:btc_usdt_spot"]}}
< {
"table": "depthl2",
"action": "snapshot",
"data": {
"instrument": "btc_usdt_spot",
"bids": [
{
"price": "41787.99",
"qty": "0.00019"
},
{
"price": "41786.99",
"qty": "0.00019"
},
{
"price": "41785.99",
"qty": "0.00019"
},
],
"asks": [
{
"price": "41893.88",
"qty": "0.00025"
},
{
"price": "41894.88",
"qty": "0.00025"
},
{
"price": "41895.88",
"qty": "0.00025"
},
]
}
}
...
...
Streams full L2 orderbook data.
WS Endpoint
wss://api.bitwyre.com/stream
WS Request Fields/Parameters (during handshake)
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"instrument" | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
WS Streaming Data Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
"bids" | array-of-float-string-tuple | current bid orders in the orderbook |
"asks" | array-of-float-string-tuple | current ask orders in the orderbook |
"is_frozen" | boolean | market frozen status |
WS Depth L2 Top 25 Snapshot
Connecting
websocat -E "wss://api.bitwyre.com/stream"
Streaming Responses
> {"op": "subscribe", "args": ["depthl2_25:btcusdtx_usdt_200607F1000000"]}
< {"success":true,"subscribe":"depthl2_25:btcusdtx_usdt_200607F1000000","request":{"op":"subscribe","args":["depthl2_25:btcusdtx_usdt_200607F1000000"]}}
< {
"table":"depthl2_25",
"keys":["instrument", "sequence_number", "bids", "asks", "is_frozen"],
"types": {"str", "int", "list", "list", "bool"}
"action": "snapshot",
"data":{
"instrument": "btcusdtx_usdt_200607F1000000",
"sequence_number": 100000,
"bids": [["124112000", "0.18154050"], ["124110000", "0.47319750"]] ..., # length 25
"asks": [["124130000", "0.03701609"], ["124251000", "0.03223585"]] ..., # length 25
"is_frozen": false
}
}
< {
"table":"depthl2_25",
"action":"update",
"data":{
"instrument": "btc_usdt_spot",
"sequence_number": 100001,
"timestamp": 1591592172780386000,
"price": 9000,
"qty": 2,
}
}
< {
"table":"depthl2_25",
"action":"insert",
"data":{
"instrument": "btc_usdt_spot",
"sequence_number": 100002,
"timestamp": 1591592172780386000,
"price": -9000, # could be negative for asks
"qty": 2, # positive for insertion
}
}
< {
"table":"depthl2_25",
"action": "delete",
"data":{
"instrument": "btc_usdt_spot",
"sequence_number": 100003,
"timestamp": 1591592172780386000,
"price": 9000, # positive for bids
"qty": -2, # negative for removal of liquidity
}
}
...
Streams orderbook depthL2 top 25 levels for bids and asks.
WS Endpoint
wss://api.bitwyre.com/stream?=depthl2_25:<instrument>
WS Request Fields/Parameters (during handshake)
Query Parameter | Data Type | Required | Remark |
---|---|---|---|
"instrument" | string | false | base asset, quote asset, product filter, delimited with an _ (underscore). |
WS Streaming Data Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
"bids" | array-of-float-string-tuple | current bid orders in the orderbook |
"asks" | array-of-float-string-tuple | current ask orders in the orderbook |
"is_frozen" | boolean | market frozen status |
WS Announcement
Connecting
websocat -E "wss://api.bitwyre.com/stream"
Streaming Responses (1 Hz)
> {"op": "subscribe", "args": ["announcement"]}
< {"success":true,"subscribe":"announcement","request":{"op":"subscribe","args":["announcement"]}}
< {
"table":"announcement",
"keys":["unixtime", "announcement"],
"types": {"str", "str"}
"action": "snapshot",
"data":{
{"unixtime":1571744594571020435, "announcement": "halting btc_usdt_spot trading"},
{"unixtime":1571744594571020435, "announcement": "restoring btc_usdt_spot trading"},
}
}
< {
"table":"announcement",
"keys":["unixtime", "announcement"],
"types": {"str", "str"}
"action": "incremental",
"data":{
{"unixtime":1571744594571020435, "announcement": "halting eth_usdt_spot trading"},
}
}
Streams server's time every second an announcement for at least 1 minute full for an announcement of event
WS Endpoint
wss://api.bitwyre.com/stream
WS Request Fields/Parameters
WS Streaming Data Types (JSON Object)
JSON Field | Data Type | Remark |
---|---|---|
"unixtime" | big-integer | unix time in nanoseconds |
"announcement" | string | announcement |
WS Contract
Connecting
websocat -E "wss://api.bitwyre.com/stream"
Streaming Responses (1 Hz)
> {"op": "subscribe", "args": ["contract:btcusdtx_usdt_200607F1000000"]}
< {"success":true,"subscribe":"contract:btcusdtx_usdt_200607F1000000","request":{"op":"subscribe","args":["contract:btcusdtx_usdt_200607F1000000"