معرفی شرکت ها


bitbnspy-0.3.1


Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر

توضیحات

This project is designed to assist you make your own projects that interact with the Bitbns API. This project seeks to have complete API coverage and WebSockets
ویژگی مقدار
سیستم عامل -
نام فایل bitbnspy-0.3.1
نام bitbnspy
نسخه کتابخانه 0.3.1
نگهدارنده []
ایمیل نگهدارنده []
نویسنده Prashant Singh
ایمیل نویسنده prashant@buyhatke.com
آدرس صفحه اصلی https://github.com/bitbns-official/bitbnspy
آدرس اینترنتی https://pypi.org/project/bitbnspy/
مجوز MIT
change log ========== 0.3.1 (2022-07-15) ================== - Adding in new history endpoints - Providing support for futures testnet - Updating futures to mainnet - Adding futures documentation - Fixing minor bugs 0.2.5 (2022-04-18) ================== - Making new post request method for new endpoints - Added endpoints for SWAP Market - Added endpoints for FIP - Added partner APIs - Added payment gateway API - Code refactored and documentation errors fixed - Updated documentation for all endpoints - Updated socket endpoint - Live executed orders endpoint not available - Fixed minor bugs - Porting new V1 endpoints for stop & bracket order status 0.2.4 (2021-10-25) ================== - Minor spell check - Added market order for cost and quantity - Updated market order - Updated documentation - Updated setup - Added market orders 0.2.3 (2021-09-14) ================== - Merge branch 'master' of https://github.com/bitbns-official/bitbnspy - updating readme - updated documentation - Merge pull request #68 from its-mohnish/master - updated - Updated readme.md - Updated bitbns to include public endpoints - Merge pull request #67 from sanket-buyhatke/public-endpoints - adding public endpoint - fetchOHLCV - addin public endpoints - fetchTrades - adding public endpoints - fetchOrderBook - adding public endpoints - fetchTickers - Merge pull request #65 from its-mohnish/master - Merge branch 'bitbns-official:master' into master - Adding github headers - final - Adding github headers for direct links - Merge pull request #64 from its-mohnish/master - Update README.md - Update README.md - Update README.md - updating version to 0.2.2 - Updating changelog for version 0.2.2 - Updating github repo 0.2.2 (2021-08-18) ================== - Merge branch 'master' of https://github.com/bitbns-official/bitbnspy - 'Updated setup and bitbnspy' - Merge pull request #63 from its-mohnish/master - Removed package_dir - Added Retries - Merge pull request #61 from sanket-buyhatke/master - updated docs websockets to support ticker data - updated websockets to support stream ticker data - Merge pull request #55 from sanket-buyhatke/master - minor changes in documentation - Added socket documentation - Merge pull request #53 from its-mohnish/patch-6 0.2.1 (2021-06-21) ================== - updating additional package - Merge pull request #47 from its-mohnish/master - Delete python-package.yml - Delete sample_test.py - Adding python-package.yml - sample python testing - Merge branch 'master' into master - Merge pull request #36 from its-mohnish/patch-5 - Merge pull request #35 from its-mohnish/patch-4 - Merge pull request #34 from its-mohnish/patch-3 - Merge pull request #33 from its-mohnish/patch-2 - Removed unnecessary files, fixed python installation issue - Merge pull request #31 from its-mohnish/patch-1 - Merge pull request #37 from sanket-buyhatke/master - adding bug report template for issues =================== # Bitbns Python API This project is designed to assist you make your own projects that interact with the Bitbns API. This project seeks to have complete API coverage and WebSockets. <code><b>Use Python 3.7+</b></code><br><br> <h3>Installation</h3> <code> pip3 install bitbnspy </code> <h3> Getting Started </h3> Now we support public and private endpoints. One does not have to provide API Keys in case they just want to use our public endpoints. <br>In case one wants to use both public and private endpoints, they can do so by following the instatiation method for private endpoints. <h4> Instantiation for Public Endpoints </h2> ``` from bitbnspy import bitbns bitbnsObj = bitbns.publicEndpoints() print(bitbnsObj.fetchTickers()) ``` <h4> Instantiation for Private Endpoints </h2> ``` from bitbnspy import bitbns key = 'yourKey' secretKey = 'yourSecretKey' bitbnsObj = bitbns(key, secretKey) print(bitbnsObj.getSellOrderBook('XRPUSDT')) ``` <br> <h2>API Access</h2> <div id ="api_summary_table" style ="border:1px solid"> <table style = "width:55%"> <tr> <th>PERMISSIONS</th> <th>Read</th> <th>Write</th> </tr> <tr> <th></th> <th></th> <th></th> </tr> <tr> <th>List Open Orders</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>List Open Stop Limit</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Api Usages Status</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Current Coin Balance</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Deposit History</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Withdrawal History</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Order Status</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Buy Stop Loss Order</th> <th>&#x2716;</th> <th>&#10003;</th> </tr> <tr> <th>Sell Stop Loss Order</th> <th>&#x2716;</th> <th>&#10003;</th> </tr> <tr> <th>Buy Order</th> <th>&#x2716;</th> <th>&#10003;</th> </tr> <tr> <th>Sell Order</th> <th>&#x2716;</th> <th>&#10003;</th> </tr> <tr> <th>Get Coin Address</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Cancel Order</th> <th>&#x2716;</th> <th>&#10003;</th> </tr> <tr> <th>Cancel Stop Loss Order</th> <th>&#x2716;</th> <th>&#10003;</th> </tr> <tr> <th>Platform Status</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Ticker API</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Buy OrderBook</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> <tr> <th>Sell OrderBook</th> <th>&#10003;</th> <th>&#x2716;</th> </tr> </table> </div><br> <h2>Minimum Volume supported by exchange</h2> <h3> <b> Minimum volume amount per order: </b></h3> - USDT market = <u>0.1 USDT</u> - INR market = <u>10 INR</u> <h2> Public Endpoints </h2> <h4><b> Getting details of tickers </b></h4> <pre> bitbnsObj.fetchTickers() </pre> <details> <summary> View Response </summary> <pre> { data: { 'BTC': { 'highest_buy_bid': 3804776.47, 'lowest_sell_bid': 3809634.1, 'last_traded_price': 3809634.1, 'yes_price': 3817924.68, 'volume': { 'max': '3860000.00', 'min': '3728401.38', 'volume': 29.22102567 } }, 'XRP': { . . . } }, 'error': None, 'status': 1, } <br><br> Explanation of fields: status -> 1 if data is returned successfully error -> describes the error faced while retrieving data if any </pre> </details> <h4><b> Getting order book </b></h4> Depth of the order book can be specified. Default depth is 20. <pre> bitbnsObj.fetchOrderBook('BTC', 'INR', depth = 10) </pre> <details> <summary> View Response </summary> <pre> { 'data': { 'asks': [ [3839997.47, 0.14315922], [3840000, 0.00104478], . . ] 'bids': [ [3836673.24, 0.0002062], [3836673.23, 0.23805619], . . ] 'timestamp': 1630664703000 }, 'error': None, 'status': 1 } <br><br> Explanation of fields: status -> 1 if data is returned successfully error -> describes the error faced while retrieving data if any timestamp -> The timestamp when screenshot of order book was taken </pre> </details> <h4><b> Getting recent trades </b></h4> Limit (nos of trades to be returned) can also be specified. Default limit is 100 <pre> bitbnsObj.fetchTrades('BTC', 'INR', limit = 10) </pre> <details> <summary> View Response </summary> <pre> { 'data': [ { 'base_volume': 0.00106565, 'price': '3837783.20', 'quote_volume': 4099.96, 'timestamp': 1630664966000, 'tradeId': '2468049', 'type': 'buy' }, { . . . } ], 'error': None, 'status': 1 } <br><br> Explanation of fields: status -> 1 if data is returned successfully error -> describes the error faced while retrieving data if any </pre> </details> <h4><b> fetch OHLCV data </b></h4> This endpoint is paginated. Increase page no., to get older data. <pre> bitbnsObj.fetchOHLCV('BTC', 'INR', page = 1) </pre> <details> <summary> View Response </summary> <pre> { 'data':[ { 'close': 3727748.31, 'high': 3727748.31, 'low': 3724656.82, 'open': 3727748.31, 'timestamp': '2021-09-01T11:25:04.000Z', 'vol': 1.07505351 }, { 'close': 3727748.31, 'high': 3749981.02, 'low': 3720000, 'open': 3720000, 'timestamp': '2021-09-01T11:20:04.000Z', 'vol': 0.04898758 }, . . . ] 'error': None, 'status': 1 } <br><br> Explanation of fields: status -> 1 if data is returned successfully error -> describes the error faced while retrieving data if any </pre> </details> <h2> Private Endpoints </h2> <h4><b>Getting Platform Status</b></h4> <pre> bitbnsObj.platformStatus(); </pre> <details> <summary> View Response </summary> <pre> { data: { BTC: { status: 1 }, ETH: { status: 1 }, XRP: { status: 1 } }, status: 1, error: null } Explanation of fields: status -> whether the coin is live on platform </pre> </details> <h4><b>Getting latest price of a symbol</b></h4> Inputting Invalid crypto name would return "undefined" as the price. <pre> bitbnsObj.getTickerApi('BTC') </pre> <details> <summary> View Response </summary> <pre> { "data": { "BTC": { "highest_buy_bid": 484159.43, "lowest_sell_bid": 494800, "last_traded_price": 494805.29 } }, "status": 1, "error": null } Explanation of fields: highest_buy_bid -> top entry of buy order book lowest_sell_bid -> top entry of sell order book last_traded_price -> price at which the last trade had happened </pre> </details> <h4><b>Getting latest price of few symbols</b></h4> <pre> bitbnsObj.getTickerApi('BTC,ETH') </pre> <details> <summary> View Response </summary> <pre> { "data": { "BTC": { "highest_buy_bid": 484159.43, "lowest_sell_bid": 494800, "last_traded_price": 494805.29 }, "ETH": { "highest_buy_bid": 13205.01, "lowest_sell_bid": 13440, "last_traded_price": 13450 } }, "status": 1, "error": null } Explanation of fields: highest_buy_bid -> top entry of buy order book lowest_sell_bid -> top entry of sell order book last_traded_price -> price at which the last trade had happened </pre> </details> <h4><b>Getting latest price of all symbols</b></h4> <pre> bitbnsObj.getTickerApi('') </pre> <details> <summary> View Response </summary> <pre> { "data": { "BTC": { "highest_buy_bid": 480059.8, "lowest_sell_bid": 489000, "last_traded_price": 480059.8 }, "XRP": { "highest_buy_bid": 20, "lowest_sell_bid": 20.16, "last_traded_price": 20.16 }, "NEO": { "highest_buy_bid": 1301, "lowest_sell_bid": 1349.99, "last_traded_price": 1331.92 }, "GAS": { "highest_buy_bid": 406.96, "lowest_sell_bid": 418.46, "last_traded_price": 418.46 }, "ETH": { "highest_buy_bid": 13350, "lowest_sell_bid": 13660.5, "last_traded_price": 13350 }, "XLM": { "highest_buy_bid": 14.75, "lowest_sell_bid": 14.77, "last_traded_price": 14.77 }, "RPX": { "highest_buy_bid": 0.77, "lowest_sell_bid": 0.82, "last_traded_price": 0.8 }, "DBC": { "highest_buy_bid": 0.73, "lowest_sell_bid": 0.77, "last_traded_price": 0.72 }, "LTC": { "highest_buy_bid": 3680, "lowest_sell_bid": 3800, "last_traded_price": 3800 }, "XMR": { "highest_buy_bid": 7555, "lowest_sell_bid": 8000, "last_traded_price": 7600 }, "DASH": { "highest_buy_bid": 13500, "lowest_sell_bid": 14500, "last_traded_price": 13500 }, "DOGE": { "highest_buy_bid": 0.47, "lowest_sell_bid": 0.49, "last_traded_price": 0.49 }, "BCH": { "highest_buy_bid": 33600, "lowest_sell_bid": 34997, "last_traded_price": 34998 }, "SC": { "highest_buy_bid": 0.38, "lowest_sell_bid": 0.42, "last_traded_price": 0.42 }, "TRX": { "highest_buy_bid": 1.35, "lowest_sell_bid": 1.36, "last_traded_price": 1.35 }, "ETN": { "highest_buy_bid": 0.38, "lowest_sell_bid": 0.39, "last_traded_price": 0.39 }, "ONT": { "highest_buy_bid": 126.01, "lowest_sell_bid": 136.1, "last_traded_price": 136.82 }, "ZIL": { "highest_buy_bid": 2.37, "lowest_sell_bid": 2.5, "last_traded_price": 2.51 }, "EOS": { "highest_buy_bid": 365.51, "lowest_sell_bid": 375.1, "last_traded_price": 385 }, "POLY": { "highest_buy_bid": 10.01, "lowest_sell_bid": 10.04, "last_traded_price": 10.04 }, "DGB": { "highest_buy_bid": 1.6, "lowest_sell_bid": 1.83, "last_traded_price": 1.82 }, "NCASH": { "highest_buy_bid": 0.35, "lowest_sell_bid": 0.36, "last_traded_price": 0.36 }, "ADA": { "highest_buy_bid": 4.97, "lowest_sell_bid": 5.09, "last_traded_price": 4.92 }, "ICX": { "highest_buy_bid": 40.01, "lowest_sell_bid": 45.5, "last_traded_price": 40.25 }, "VEN": { "highest_buy_bid": 0.96, "lowest_sell_bid": 1.15, "last_traded_price": 1.15 }, "OMG": { "highest_buy_bid": 239.72, "lowest_sell_bid": 267.71, "last_traded_price": 267.71 }, "REQ": { "highest_buy_bid": 2.22, "lowest_sell_bid": 2.39, "last_traded_price": 2.3 }, "DGD": { "highest_buy_bid": 2385, "lowest_sell_bid": 3000, "last_traded_price": 2385 }, "QLC": { "highest_buy_bid": 3.3, "lowest_sell_bid": 3.96, "last_traded_price": 3.4 }, "POWR": { "highest_buy_bid": 10.02, "lowest_sell_bid": 11.4, "last_traded_price": 10.01 }, "WPR": { "highest_buy_bid": 1.18, "lowest_sell_bid": 1.25, "last_traded_price": 1.17 }, "WAVES": { "highest_buy_bid": 150.1, "lowest_sell_bid": 179, "last_traded_price": 150 }, "WAN": { "highest_buy_bid": 58.51, "lowest_sell_bid": 69.9, "last_traded_price": 53.55 }, "ACT": { "highest_buy_bid": 2.21, "lowest_sell_bid": 2.68, "last_traded_price": 2.21 }, "XEM": { "highest_buy_bid": 5.7, "lowest_sell_bid": 7.51, "last_traded_price": 10 }, "XVG": { "highest_buy_bid": 0.89, "lowest_sell_bid": 0.92, "last_traded_price": 0.88 }, "BLZ": { "highest_buy_bid": 7.61, "lowest_sell_bid": 7.8, "last_traded_price": 7.8 }, "SUB": { "highest_buy_bid": 7.06, "lowest_sell_bid": 8.5, "last_traded_price": 7.45 }, "LRC": { "highest_buy_bid": 6.5, "lowest_sell_bid": 9.95, "last_traded_price": 6.7 }, "NEXO": { "highest_buy_bid": 3.91, "lowest_sell_bid": 4.19, "last_traded_price": 3.91 }, "EFX": { "highest_buy_bid": 0.69, "lowest_sell_bid": 0.9, "last_traded_price": 0.7 }, "CPX": { "highest_buy_bid": 1.05, "lowest_sell_bid": 1.27, "last_traded_price": 1.05 }, "ZRX": { "highest_buy_bid": 38.09, "lowest_sell_bid": 39.49, "last_traded_price": 37.77 }, "REP": { "highest_buy_bid": 1050, "lowest_sell_bid": 1200, "last_traded_price": 1025 }, "LOOM": { "highest_buy_bid": 5.06, "lowest_sell_bid": 6.7, "last_traded_price": 6.7 }, "EOSD": { "highest_buy_bid": 3.51, "lowest_sell_bid": 3.88, "last_traded_price": 3.51 }, "STORM": { "highest_buy_bid": 0.47, "lowest_sell_bid": 0.5, "last_traded_price": 0.48 }, "GNT": { "highest_buy_bid": 9.25, "lowest_sell_bid": 9.26, "last_traded_price": 9.26 }, "QTUM": { "highest_buy_bid": 235, "lowest_sell_bid": 288.97, "last_traded_price": 247.69 }, "QKC": { "highest_buy_bid": 1.86, "lowest_sell_bid": 2.34, "last_traded_price": 1.76 }, "LSK": { "highest_buy_bid": 230, "lowest_sell_bid": 286, "last_traded_price": 230 }, "NPXS": { "highest_buy_bid": 0.11, "lowest_sell_bid": 0.12, "last_traded_price": 0.11 }, "USDT": { "highest_buy_bid": 74.12, "lowest_sell_bid": 77, "last_traded_price": 74.11 }, "ETC": { "highest_buy_bid": 804.02, "lowest_sell_bid": 850, "last_traded_price": 804 }, "DENT": { "highest_buy_bid": 0.15, "lowest_sell_bid": 0.17, "last_traded_price": 0.17 }, "CLOAK": { "highest_buy_bid": 120.51, "lowest_sell_bid": 159.92, "last_traded_price": 135 }, "KMD": { "highest_buy_bid": 70, "lowest_sell_bid": 77, "last_traded_price": 77.6 }, "GRS": { "highest_buy_bid": 35, "lowest_sell_bid": 39.4, "last_traded_price": 38.4 }, "RAM": { "highest_buy_bid": 0.38, "lowest_sell_bid": 0.4, "last_traded_price": 0.38 }, "LET": { "highest_buy_bid": 0.64, "lowest_sell_bid": 0.68, "last_traded_price": 0.68 }, "SOUL": { "highest_buy_bid": 2.26, "lowest_sell_bid": 2.71, "last_traded_price": 2.7 }, "PHX": { "highest_buy_bid": 0.77, "lowest_sell_bid": 0.82, "last_traded_price": 0.8 }, "VET": { "highest_buy_bid": 0.96, "lowest_sell_bid": 1.15, "last_traded_price": 1.15 }, "TST": { "highest_buy_bid": 23, "lowest_sell_bid": 27.5, "last_traded_price": 25 } }, "status": 1, "error": null } </pre> </details> <h4><b>Getting current balance of crypto asset</b><br></h4> Inputing "INR" in place of crypto asset would list your inr balance . <pre> bitbnsObj.currentCoinBalance('BTC') </pre> <details> <summary> View Response </summary> <pre> { "data": { "inorderBTC": 8.34, "availableorderBTC": 15.76 }, "status": 1, "error": null } Explanation of fields: inorderBTC -> volume which is the order book availableorderBTC -> volume which is present in wallet </pre> </details> <h4><b>Get Deposit History</b><br></h4> <pre> bitbnsObj.depositHistory('BTC', 0) </pre> <details> <summary> View Response </summary> <pre> { data: [ { type: 'BTC deposited', typeI: 1, amount: 0.00159302, date: '2018-08-21T14:35:02.000Z', unit: 'BTC', factor: 100000000, fee: 0, delh_btc: 0, delh_inr: 0, rate: 0, del_btc: 159302, del_inr: 0 }, { type: 'BTC deposited', typeI: 1, amount: 0.00142951, date: '2018-08-21T14:35:02.000Z', unit: 'BTC', factor: 100000000, fee: 0, delh_btc: 0, delh_inr: 0, rate: 0, del_btc: 142951, del_inr: 0 } ], status: 1, error: null } Explanation of fields: type -> type of action typeI -> action id amount -> the amount deposited date -> the time at which this event occured unit -> the symbol name of coin factor -> the division factor del_btc -> delta changes in normal wallet of coin del_inr -> delta changes in normal inr wallet delh_btc -> delta changes in hold wallet of coin </pre> </details> <h4><b>Get Withdrawal History</b><br></h4> <pre>bitbnsObj.withdrawHistory('XRP', 0)</pre> <details> <summary> View Response </summary> <pre> { data: [ { type: 0, amount: 1.1, unit: 'XRP', hash: '42DAD88011C178DCAA1587ABA4458F4D535B30248650A6C353E5E2527', fee: 0.1, to: 'rB1za2ZVgqvrNB7u8LbVN61k5n1ByBUtXCA', status: '-1', canSendMail: 0, cancelable: -1, refer: 5339918, expTime: 'XRP withdraw done' }, { type: 0, amount: 100, unit: 'XRP', hash: '12520219872260A25457E4D03C8F82F696A23EEA558B693B90FF080C5', fee: 0.1, to: 'rLdBnLq5C13ood9wdjY9ZCdgycK8KGevkUj', status: '-1', canSendMail: 0, cancelable: -1, refer: 6531933, expTime: 'XRP withdraw done' } ], status: 1, error: null } </pre> </details> <h4><b>List Open Orders</b><br></h4> <pre> bitbnsObj.listOpenOrders('BTC') </pre> <details> <summary> View Response </summary> <pre> { "data": [ { "entry_id": 322, "btc": 48, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 323, "btc": 100, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 324, "btc": 100, "r ate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 325, "btc": 100, "rate": 25, "time": "2018-0 9-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 326, "btc": 100, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "t ype": 1, "status": 0 }, { "entry_id": 327, "btc": 100, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "e ntry_id": 328, "btc": 100, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 329, "btc": 100, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 330, "btc": 100, "rate": 25, "time": "201 8-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 331, "btc": 100, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 332, "btc": 100, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 333, "btc": 100, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 334, "btc": 100, "rate": 25, "time": "2018-09-10T12:29:52.000Z", "type": 1, "status": 0 }, { "entry_id": 337, "btc": 100, "rate": 25, "time": " 2018-09-10T12:45:51.000Z", "type": 1, "status": 0 }, { "entry_id": 338, "btc": 100, "rate": 25, "time": "2018-09-10T12:46:01.00 0Z", "type": 1, "status": 0 } ], "status": 1, "error": null } Explanation of fields: entry_id -> the unique id assigned to the order btc -> the volume of the coin rate -> the rate at which the order was placed time -> the timestamp at which the order was placed type -> 1 for sell and 0 for buy order status -> -1 for cancelled , 0 for not processed , 1 for partially executed, 2 for fully executed </pre> </details> <h4><b>List Open Stop Loss Orders</b><br></h4> <pre> bitbnsObj.listOpenStopOrders('TST') </pre> <details> <summary> View Response </summary> <pre> { data: [ { entry_id: 28816, btc: 40, rate: 25, t_rate: 24.5, type: 1, status: 0 } ], status: 1, error: null } Explanation of fields: entry_id -> the unique id assigned to the order btc -> the volume of the coin rate -> the rate at which the order was placed t_rate -> the trigger rate at which the order was placed time -> the timestamp at which the order was placed type -> 1 for sell and 0 for buy order status -> -1 for cancelled , 0 for not processed , 1 for partially executed, 2 for fully executed </pre> </details> <h4><b>Get Specify Crypto Coin Address</b><br></h4> <pre> Coins Without Tag bitbnsObj.getCoinAddress('BTC') </pre> <details> <summary> View Response </summary> <pre> { "data": { "token": "3QkuWRDRNcjtMQNneoqFV7hpxQPWW6pupK", "expiry": "2018-09-12 13:04:09" }, "status": 1, "error": null } Explanation of fields: token -> the token address expiry -> the time till which this address is user's valid address </pre> </details> <pre> Coins With Tag bitbnsObj.getCoinAddress('XLM') </pre> <details> <summary> View Response </summary> <pre> { "data": { "token": "GAVQNY45FBHSN5MEPLAF56U7VDCBDG54TQFGJSS2CRPZTWD3CSHP4YPU", "tag": "123151" }, "status": 1, "error": null } Explanation of fields: token -> the token address tag -> the tag to be used for the token Deposits would not be valid unless you specify the tag </pre> </details> <h4><b>Place Sell Order</b><br></h4> <pre>bitbnsObj.placeSellOrder('XRP', 200, 25) 200 -> Quantity 25 -> Rate </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully placed bid to sell at specified price", "status": 1, "error": null, "id": 489 } Explanation of fields: data -> Just a custom message id -> the unique id of the order </pre> </details> <h4><b>Place Market Order via cost</b><br></h4> <pre>bitbnsObj.placeMarketOrder('BTC', 'INR', 'BUY', 100) 'INR' -> Market (INR/USDT) 'BUY' -> Side (BUY/SELL) 100 -> Buy/Sell coin worth Rs 100 </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': 'Successfully placed market order to purchase currency', 'error': None, 'id': 12618790, 'status': 1 } Explanation of fields: data -> Just a custom message id -> the unique id of the order status -> 1 (0 for failure) </pre> </details> <h4><b>Place Market Order via quantity</b><br></h4> <pre>bitbnsObj.placeMarketOrderQuantity('BTC', 'INR', 'BUY', 0.00001) 'INR' -> Market (INR/USDT) 'BUY' -> Side (BUY/SELL) 0.00001 -> Quantity </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': 'Successfully placed market order to purchase currency', 'error': None, 'id': 12578554, 'status': 1 } Explanation of fields: data -> Just a custom message id -> the unique id of the order status -> 1 (0 for failure) </pre> </details> <h4><b>Placing a STOP LOSS order (BUY)</b><br></h4> <pre> bitbnsObj.buyStopLoss('XRP', 40, 24, 24.5) 40 -> Quantity 24 -> Rate 24.5 -> Trigger rate </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully placed order for stop loss buy", "status": 1, "error": null, "id": 28595 } Explanation of fields: data -> Just a custom message id -> the unique id of the order </pre> </details> <h4><b>Place Buy Order</b><br></h4> <pre>bitbnsObj.placeBuyOrder('XRP', 200, 25) 200 -> Quantity 25 -> Rate </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully placed bid to purchase currency", "status": 1, "error": null, "id": 490 } Explanation of fields: data -> Just a custom message id -> the unique id of the order </pre> </details> <h4><b>Placing a STOP LOSS order (BUY)</b><br></h4> <pre> bitbnsObj.buyStopLoss('XRP', 40, 24, 24.5) 40 -> Quantity 24 -> Rate 24.5 -> Trigger rate </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully placed order for stop loss buy", "status": 1, "error": null, "id": 28595 } Explanation of fields: data -> Just a custom message id -> the unique id of the order </pre> </details> <h4><b>Placing a STOP LOSS order (SELL)</b><br></h4> <pre> bitbnsObj.sellStopLoss('XRP', 40, 25, 24.5) 40 -> Quantity 24 -> Rate 24.5 -> Trigger rate </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully placed a stop limit sell order", "status": 1, "error": null, "id": 28596 } Explanation of fields: data -> Just a custom message id -> the unique id of the order </pre> </details> <h4><b>Place Cancel Order</b><br></h4> <pre>bitbnsObj.cancelOrder('XRP', 174) Here 174 is a order id </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully cancelled the order", "status": 1, "error": null } Explanation of fields: data -> just a custom message status -> status of cancellation 1 for success </pre> </details> <h4><b>Getting Sell Order Book for BTC</b><br></h4> <pre> bitbnsObj.getSellOrderBook('BTC') </pre> <details> <summary> View Response </summary> <pre> { data: [ { rate: 481847.56, btc: 6352679 }, { rate: 481700, btc: 5540000 }, { rate: 481551, btc: 5000000 }, { rate: 481000, btc: 11406 }, { rate: 480000, btc: 208021 }, { rate: 479366.65, btc: 5265026 }, { rate: 479345, btc: 453445 }, { rate: 478854.18, btc: 642042 }, { rate: 478749.87, btc: 208356 }, { rate: 478511.87, btc: 2446067 }, { rate: 478000, btc: 80253706 }, { rate: 477900, btc: 6261808 }, { rate: 477777, btc: 208900000 }, { rate: 477740, btc: 15000000 }, { rate: 477706.19, btc: 5003424 } ], status: 1, error: null } Explanation of fields: rate -> the amount of the order btc -> the volume of the coin for that order </pre> </details> <h4><b>Getting Sell Order Book for BTCUSDT</b><br></h4> <pre> bitbnsObj.getSellOrderBook('BTCUSDT') </pre> <details> <summary> View Response </summary> <pre> { "data": [ { "rate": 13701.34, "btc": 0.145853 }, { "rate": 13701.35, "btc": 0.043633 }, { "rate": 13701.47, "btc": 0.543258 }, { "rate": 13701.69, "btc": 0.664955 }, { "rate": 13701.72, "btc": 0.131749 }, { "rate": 13702.36, "btc": 0.406614 }, { "rate": 13703.18, "btc": 0.253289 }, { "rate": 13713.46, "btc": 0.19549 }, { "rate": 13713.88, "btc": 0.055847 }, { "rate": 13740, "btc": 0.03642294 }, { "rate": 13848.3, "btc": 0.14447299 }, { "rate": 13855, "btc": 0.03 }, { "rate": 13855.11, "btc": 0.0119887 }, { "rate": 13879.39, "btc": 0.0001 }, { "rate": 14000, "btc": 0.00163832 } ], "status": 1, "error": None, "code": 200 } Explanation of fields: rate -> the amount of the order btc -> the volume of the coin for that order </pre> </details> <h4><b>Getting Buy Order Book for BTC</b><br></h4> <pre> bitbnsObj.getBuyOrderBook('BTC') </pre> <details> <summary> View Response </summary> <pre> { data: [ { rate: 481847.56, btc: 6352679 }, { rate: 481700, btc: 5540000 }, { rate: 481551, btc: 5000000 }, { rate: 481000, btc: 11406 }, { rate: 480000, btc: 208021 }, { rate: 479366.65, btc: 5265026 }, { rate: 479345, btc: 453445 }, { rate: 478854.18, btc: 642042 }, { rate: 478749.87, btc: 208356 }, { rate: 478511.87, btc: 2446067 }, { rate: 478000, btc: 80253706 }, { rate: 477900, btc: 6261808 }, { rate: 477777, btc: 208900000 }, { rate: 477740, btc: 15000000 }, { rate: 477706.19, btc: 5003424 } ], status: 1, error: null } Explanation of fields: rate -> the amount of the order btc -> the volume of the coin for that order </pre> </details> <h4><b>Getting Buy Order Book for BTCUSDT</b><br></h4> <pre> bitbnsObj.getBuyOrderBook('BTCUSDT') </pre> <details> <summary> View Response </summary> <pre> { "data": [ { "rate": 13657.14, "btc": 0.245901 }, { "rate": 13656.94, "btc": 0.043868 }, { "rate": 13656.58, "btc": 0.249137 }, { "rate": 13656.57, "btc": 0.215321 }, { "rate": 13656.56, "btc": 0.06557399 }, { "rate": 13656.26, "btc": 0.28264299 }, { "rate": 13621.07, "btc": 0.086085 }, { "rate": 13620.93, "btc": 0.307243 }, { "rate": 13620.77, "btc": 0.466551 }, { "rate": 13620.71, "btc": 0.203805 }, { "rate": 13618.79, "btc": 0.01179179 }, { "rate": 13600, "btc": 0.00461852 }, { "rate": 13150, "btc": 0.07585551 }, { "rate": 13000, "btc": 0.00368308 }, { "rate": 12950, "btc": 0.01540463 } ], "status": 1, "error": None, "code": 200 } Explanation of fields: rate -> the amount of the order btc -> the volume of the coin for that order </pre> </details> <h4><b>Get executed orders</b><br></h4> <pre> symbol = 'EOSUSDT' #symbol = 'EOS' for (EOS/INR market) since_date = '2021-01-01T00:00:00Z' page_no = 0 bitbnsObj.listExecutedOrders(symbol, since=since_date, pageNo=page_no) </pre> <details> <summary> View Response </summary> <pre> { "data":[ { "type":"EOS Buy order executed", "typeI":29, "crypto":28, "amount":28, "rate":"3.3929", "date":"2021-01-06T18:53:25.000Z", "unit":"EOS", "factor":100, "fee":0.01, "delh_btc":0, "delh_inr":-0.96, "del_btc":28, "del_inr":0, "id":"2249410", "log_id":260236056 } ], "status":1, "error":"None", "code":200 } Explanation of fields: type -> type of action typeI -> action id amount -> the amount deposited date -> the time at which this event occurred unit -> the symbol name of coin factor -> the division factor del_btc -> delta changes in normal wallet of coin del_inr -> delta changes in normal inr wallet delh_btc -> delta changes in hold wallet of coin </pre> </details> <h4><b>Get API usage Status</b><br></h4> <pre> bitbnsObj.getApiUsageStatus() </pre> <details> <summary> View Response </summary> <pre> { data: { readLimt : 100, writeLimit : 30, readRateUsed: 0, writeRateUsed: 1, status: 1 }, status: 1, error: null } Explanation of the fields: readLimit -> the read limit of the user writeLimit -> the write limit of the user readRateUsed -> the read requests used writeRateUsed -> the write requests used </pre> </details> <h4><b>Getting Order Status</b><br></h4> <pre> bitbnsObj.orderStatus('BTC', '4221') 4221 -> order id </pre> <details> <summary> View Response </summary> <pre> { data: [ { entry_id: 4221, btc: 0.001, rate: 306929.01, time: '2018-09-20T13:54:21.000Z', type: 0, status: 0 } ], status: 1, error: null } Explanation of fields: entry_id -> the unique id for the order btc -> the volume of the currency placed rate -> the rate at which the order is placed time -> the timestamp of the entry type -> 0 for buy and 1 for sell status -> -1 for cancelled, 0 for not processed, 1 for partially executed, 2 for fully executed </pre> </details> <h4><b>Cancel Stop Loss Order</b><br></h4> <pre> bitbnsObj.cancelStopLossOrder('BTC', 4221) 4221 -> order id </pre> <details> <summary> View Response </summary> <pre> { data: 'Successfully cancelled the order', status: 1, error: null } Explanation of fields: data -> the custom message status -> for successful request the status is 1 </pre> </details> <h4><b>Curl request to get server time</b><br></h4> <pre> curl -H "X-BITBNS-APIKEY: API-KEY" -X GET 'https://api.bitbns.com/api/trade/v1/getServerTime' </pre> <details> <summary> View Response </summary> <pre> { serverTime: '1538150764273', status: 1, error: null } Explanation of fields: serverTime -> the server timestamp status -> the response succeeded </pre> </details> <h3>API V2 (New Features)</h3> <h4><b>Place Orders(BUY or SELL)</b><br></h4> <pre> <b>(Placing Bracket Order)</b> bitbnsObj.placeOrders({'symbol': 'XRP', 'side': 'BUY', 'quantity': 40, 'rate': 4, 'target_rate': 5, 't_rate': 3.5, 'trail_rate': .01}) side -> BUY or SELL symbol -> COIN NAME, quantity -> QUANTITY, rate -> RATE, target_rate -> TARGET RATE, t_rate -> TRRIGER RATE, trail_rate -> TRAIL RATE To Place Simple Buy or Sell Order use <b>rate</b> To Place Stoploss Buy or Sell Order use <b>rate & t_rate</b> To Place Bracket Buy or Sell Order use <b>rate , t_rate, target_rate & trail_rate</b> </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully placed a bracket order", "status": 1, "error": null, "id": 4518726, "code": 200 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 id -> the unique id of the order </pre> </details> <h4><b>Cancel Order</b><br></h4> <pre> bitbnsObj.cancelOrders({'symbol': 'XRP', 'side' : 'cancelOrder', 'entry_id': 462}) side -> "cancelOrder","cancelStopLossOrder", "usdtcancelOrder", "usdtcancelStopLossOrder" symbol -> COIN NAME entry_id : ENTRY ID </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully cancelled the order", "status": 1, "error": null, "code": 200 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 </pre> </details> <h4><b>Place Orders in USDT Market</b><br></h4> <pre> bitbnsObj.placeOrders({'symbol': 'TRX_USDT', 'side': 'BUY', 'quantity': 40, 'rate': 4, 'target_rate': 5, 't_rate': 3.5, 'trail_rate': .01}) side -> BUY or SELL symbol -> COIN NAME(use suffix "_USDT" with coin name) quantity -> QUANTITY, rate -> RATE, target_rate -> TARGET RATE, t_rate -> TRRIGER RATE, trail_rate -> TRAIL RATE To Place Simple Buy or Sell Order use <b>rate</b> To Place Stoploss Buy or Sell Order use <b>rate & t_rate</b> To Place Bracket Buy or Sell Order use <b>rate , t_rate, target_rate & trail_rate</b> </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully placed bid to purchase currency", "status": 1, "error": null, "id": 6743385, "code": 200 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 id -> the unique id of the order </pre> </details> <h4><b>Cancel Order in USDT MARKET</b><br><h4> <pre> bitbnsObj.cancelOrders({'symbol': 'TRX_USDT', 'side' : 'usdtcancelOrder', 'entry_id': 462}) side -> "cancelOrder","cancelStopLossOrder", "usdtcancelOrder", "usdtcancelStopLossOrder" symbol -> COIN NAME(use suffix "_USDT" with coin name) entry_id : ENTRY ID </pre> <details> <summary> View Response </summary> <pre> { "data": "Successfully cancelled the order", "status": 1, "error": null, "code": 200 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 </pre> </details> <h4><b>Get Orders in USDT MARKET</b><br><h4> <pre> bitbnsObj.getOrders({'side' : 'usdtListOpenOrders', 'symbol' : 'TRX_USDT', 'page' : 0}) side -> "listOpenOrders", "listOpenStopOrders", "listOpenBracketOrders", "usdtListOpenBracketOrders", "usdtListOpenStopOrders","usdtListOpenOrders" symbol -> COIN NAME(use suffix "_USDT" with coin name) page -> INTEGER </pre> <details> <summary> View Response </summary> <pre> { "data": [ { "entry_id": 6747351, "btc": 750, "rate": 0.02, "time": "2020-10-31T04:43:30.000Z", "type": 0, "status": 0 } ], "status": 1, "error": null, "code": 200 } Explanation of fields: rate -> the amount of the order btc -> the volume of the coin for that order type -> 1 for sell and 0 for buy order status -> for successful request the status is 1 </pre> </details> <h4><b>Get token to authenticate orders</b><br><h4> <pre> bitbnsObj.getTokenSocket() </pre> <details> <summary> View Response </summary> <pre> { "data": "Lw7P8tgPk72hKg0ue3BYVCHif_10071804", "status": 1, 'error': None, 'code': 200 } <br> Explanation of fields: data -> token-id based on API keys error -> the custom message status -> for successful request the status is 1 </pre> </details> <h4><b>Use socket to get live order book</b><br><h4> <pre> data = bitbnsObj.getOrderBookSocket(coinName = 'BTC', marketName = 'INR') socket = data['socket'] @socket.event def news(data): print(data) @socket.event def disconnect(): print("Disconnected") Pass USDT as market name to get orderbook of USDT market Pass ALL as coin name to get orderbook of all coins </pre> <h4><b>Use socket to get live Ticker data</b><br><h4> <pre> data = bitbnsObj.getTickerSocket(marketName = 'INR') socket = data['socket'] @socket.event def ticker(data): print(data) @socket.event def disconnect(): print("Disconnected") Pass USDT as market name to get ticks of USDT market </pre> <h4><b>Use socket to get live executed order of your account</b><br><h4> Does not work right now! <pre> token = bitbnsObj.getTokenSocket() data = bitbnsObj.getExecutedOrders(token['data']) socket = data['socket'] @socket.event def delta_data(data): print(data) @socket.event def disconnect(): print("Disconnected") </pre> <h3><b>Margin Trading V2 APIs</b><br></h3> <h4><b>Place a margin order</b></h4> <pre> bitbnsObj.placeMarginOrders({'symbol': 'USDT', 'side': 'placeOrder', 'type': 'LEND', 'qnty': 40, 'days': 1, 'rate': 0.0055}) side -> placeOrder type -> BORROW or LEND days -> 1,3,7,15,30 renew -> 0,1,2 symbol -> COIN NAME, qnty -> QUANTITY, rate -> RATE Renew Flags => 0 - Don't renew, 1 -> Renew only Principal, 2 -> Renew with Principal + Interest </pre> <details> <summary> View Response </summary> <pre> { "status": 1, "error": "Successfully placed lend order for Margin trading.", "code": 200 } Explanation of fields: error -> the custom message status -> for successful request the status is 1 </pre> </details> <h4><b>Cancel a margin order</b></h4> <pre> bitbnsObj.cancelMarginOrder({'id': 1, 'side': 'cancelMarginOrder', 'symbol': 'USDT'}) Pass id of the margin transaction you are looking to cancel symbol -> COIN NAME, </pre> <details> <summary> View Response </summary> <pre> { "status": 1, "error": "Successfully cancelled the order", "code": 200 } Explanation of fields: error -> the custom message status -> for successful request the status is 1 </pre> </details> <h4><b>Settle a margin order partially</b></h4> <pre> bitbnsObj.settleMarginPartial({'id': 1, 'side': 'settleMarginOrderPartial', 'amt': 50, 'symbol': 'USDT'}) amt -> Amount to settle Pass id of the margin transaction you are looking to settle and amt you want to settle </pre> <details> <summary> View Response </summary> <pre> { "status": 1, "error": "Successfully settled the margin order", "code": 200 } Explanation of fields: error -> the custom message status -> for successful request the status is 1 </pre> </details> <h4><b>Settle a margin order completely</b></h4> <pre> bitbnsObj.settleMargin({ 'id' : 1, 'side' : 'settleMarginOrder', 'symbol': 'USDT' }) Pass id of the margin transaction you are looking to settle </pre> <details> <summary> View Response </summary> <pre> { "status": 1, "error": "Successfully settled the margin order", "code": 200 } Explanation of fields: error -> the custom message status -> for successful request the status is 1 </pre> </details> <h4><b>Get my margin executed orders</b></h4> <pre> bitbnsObj.listMarginExecuted({'page': 1, 'side': 'listMarginExecuted', 'type': 'BORROW', 'symbol': 'USDT'}) type => LEND or BORROW </pre> <details> <summary> View Response </summary> <pre> response for borrow: { "data": [ { "entry_id": 53298, "worth_required": 8129.82, "worth_current": 26779.7, "margin_taken": 85, "status": 0, "expiry": "2020-11-01T07:03:04.000Z", "phase": 0, "margin_to_return": 85.04, "days": 1, "interest": 0.055, "coin": 54, "margin_partial_return": 0 } ], "status": 1, "error": null, "code": 200 } response for lend: { "data": [ { "entry_id": 114143, "amt": 50, "time": "2020-02-03T02:48:41.000Z", "status": 10, "expiry": "2020-02-18T08:18:41.000Z", "days": 15, "interest": 0.051, "coin": 54, "renew": 0 } ], "status": 1, "error": null, "code": 200 } Explanation of fields: data -> the custom message worth_required -> the amount required to maintain the margin worth_current -> current worth of margin borrwoed margin_taken -> the amount value borrowed expiry -> time of expiry of margin margin_to_return -> amount to be returned. days -> number of days the margin was borrowed or lent. interest -> intreset of margin per day. amt -> the amount of coins lent error -> the custom message status -> for successful request the status is 1 </pre> </details> <h4><b>Get my margin pending orders</b></h4> <pre> bitbnsObj.listMarginPending({'page': 1, 'side': 'listMarginPending', 'symbol': 'USDT'}) </pre> <details> <summary> View Response </summary> <pre> { "data": [ { "entry_id": 215769, "btc": 40, "days": 1, "time": "2020-10-31T06:42:54.000Z", "type": 0, "status": 0, "rate": 0.083 } ], "status": 1, "error": null, "code": 200 } Explanation of fields: data -> the custom message entry_id -> the unique id assigned to the order days -> number of days lent or borrowed btc -> the volume of the coin type -> 1 for borrow and 0 for lend order rate -> the rate at which the margin is lend or borrowed status -> for successful request the status is 1 </pre> </details> <h4><b>Get open orders of margin market - all users</b></h4> <pre> bitbnsObj.listMarginMarketOrders({'type': 'BORROW', 'side': 'listMarketOrders', 'symbol': 'XRP'}) type => LEND or BORROW </pre> <details> <summary> View Response </summary> <pre> { "data": [ { "btc": 486.55, "days": 7, "rate": 0.0539 }, { "btc": 2.31, "days": 1, "rate": 0.055 }, { "btc": 4392.95, "days": 3, "rate": 0.06 }, { "btc": 99.96, "days": 15, "rate": 0.065 }, { "btc": 1242, "days": 30, "rate": 0.065 }, { "btc": 13287.65, "days": 7, "rate": 0.067 }, { "btc": 350, "days": 30, "rate": 0.068 }, { "btc": 5500, "days": 7, "rate": 0.07 }, { "btc": 2119.34, "days": 30, "rate": 0.0749 }, { "btc": 1770.51, "days": 30, "rate": 0.076 }, { "btc": 53.52, "days": 30, "rate": 0.0779 }, { "btc": 3231.92, "days": 15, "rate": 0.078 }, { "btc": 622.69, "days": 15, "rate": 0.079 }, { "btc": 17306, "days": 1, "rate": 0.08 }, { "btc": 7840, "days": 15, "rate": 0.085 }, { "btc": 446.07, "days": 30, "rate": 0.0855 }, { "btc": 762.59, "days": 30, "rate": 0.0856 }, { "btc": 500, "days": 30, "rate": 0.087 }, { "btc": 195.66, "days": 30, "rate": 0.088 }, { "btc": 112.33, "days": 30, "rate": 0.089 }, { "btc": 2769, "days": 1, "rate": 0.09 }, { "btc": 20000, "days": 3, "rate": 0.09 }, { "btc": 7000, "days": 7, "rate": 0.09 }, { "btc": 8525.51, "days": 30, "rate": 0.09 }, { "btc": 206, "days": 1, "rate": 0.091 }, { "btc": 20000, "days": 15, "rate": 0.091 }, { "btc": 2096.32, "days": 30, "rate": 0.099 }, { "btc": 235, "days": 1, "rate": 0.1 }, { "btc": 401780.26, "days": 30, "rate": 0.1 }, { "btc": 50000, "days": 30, "rate": 0.11 }, { "btc": 19999.81, "days": 15, "rate": 0.12 }, { "btc": 61.71, "days": 30, "rate": 0.12 }, { "btc": 107.45, "days": 30, "rate": 0.14 }, { "btc": 43212, "days": 15, "rate": 0.169 }, { "btc": 30000, "days": 7, "rate": 0.17 }, { "btc": 90610.26, "days": 30, "rate": 0.18 } ], "status": 1, "error": null, "code": 200 } Explanation of fields: data -> the custom message days -> number of days lent or borrowed btc -> the volume of the coin rate -> the rate at which the margin is lend or borrowed status -> for successful request the status is 1 </pre> </details> <h3><b>FIP Endpoints</b><br></h3> <h4><b>List All FIPs</b></h4> <pre> bitbnsObj.listAllFIP({'type': 'ONGOING'}) type => COMPLETE || ONGOING || UPCOMING || DISTRIBUTED </pre> <details> <summary> View Response </summary> <pre> { 'data': [{ 'fip_id': 625, 'total_amt': 100, 'amt_raised': 0.77, 'int_rate': 15, 'int_rate_month': 0.015, 'min_instalment': 0.01, 'max_instalment': 50, 'start_date': '2022-02-02T06:30:00.000Z', 'allocation_complete_date': '0000-00-00 00:00:00.0000', 'maturity_date': '0000-00-00 00:00:00.0000', 'usersCount': 3, 'duration': 30, 'coin': 72, 'name': 'BNB Mega FD', 'status': 2, 'withBNS': 1, 'redeemable': 0, 'percentBNS': 1, 'factor': 10000 }, . . }], 'status': 1, 'error': None, 'code': 200 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Enroll for a FIPs</b></h4> <pre> bitbnsObj.enrollForFIP({'fip_id': 441, 'amt': 10}) fip_id => ID of the FIP for which you want to enroll </pre> <details> <summary> View Response </summary> <pre> <!--Add response here--> Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Get All FIP Transactions</b></h4> <pre> For trade History bitbnsObj.getFIPTransactions() </pre> <details> <summary> View Response </summary> <pre> { 'data': [{ 'log_id': 64317, 'fip_id': 614, 'user_id': 1199639, 'time': '2022-02-02T07:55:59.000Z', 'type': 0, 'amt': 10, 'coin': 54, 'lock1': 0, 'lock2': 10, 'bns_amount': 10, 'name': 'USDT FD Monthly', 'factor': 100 }], 'status': 1, 'error': None, 'code': 200 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Get all your ongoing FIPs</b></h4> <pre> bitbnsObj.getOngoingFIP() </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': [{ 'amt_available': 0.2, 'amt_instalment': None, 'amt_invested': 20, 'amt_redeemed': 0, 'days': 3, 'entry_id': 33381, 'fip_details': { 'allocation_complete_date': '2022-02-03T04:30:02.000Z', 'amt_raised': 4000, 'coin': 54, 'days': 4, 'duration': 30, 'factor': 100, 'fip_id': 614, 'int_rate': 21, 'int_rate_month': 0.015, 'maturity_date': '2022-03-05T04:30:02.000Z', 'min_instalment': 1000, 'name': 'USDT FD Monthly', 'percentBNS': 10, 'redeemable': 0, 'start_date': '2022-02-02T06:30:00.000Z', 'status': 3, 'total_amt': 1500000, 'withBNS': 1 }, 'fip_id': 614, 'lock1': 0, 'lock2': 0, 'mat_amount': 2033, 'others': 20, 'status': 0, 'user_id': 1199639, 'utility': 0 }], 'error': None, 'status': 1 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Presubscribe for an FIP</b></h4> <pre> bitbnsObj.preSubscribeForFIP({'fip_id': 614, 'amt': 10}) </pre> <details> <summary> View Response </summary> <pre> { 'data': 'Successfully pre subscribed you for FIP', 'status': 1, 'error': None, 'code': 200 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Fetch all your presubscribed FIPs</b></h4> <pre> bitbnsObj.fetchMySubscriptions() </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': [{ 'amt_invested': 1000, 'entry_id': 9702, 'fip_id': 614, 'status': 1, 'user_id': 1199639 }], 'error': None, 'status': 1 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Fetch different types of historical details</b></h4> <pre> ### Fetch trade history body = { 'method' : 'tradeHistory', 'coin_name' : 'BTC', 'market' : 'INR', 'limit' : 200, 'page': 0 } bitbnsObj.fetchMyHistory(body) ### Fetch INR deposit body = { 'method' : 'depINRHistory', 'limit' : 200, 'page': 0 } bitbnsObj.fetchMyHistory(body) ### Fetch INR withrawal history body = { 'method' : 'withINRHistory', 'limit' : 200, 'page': 0 } bitbnsObj.fetchMyHistory(body) ### Fetch deposits (crypo including airdrops) body = { 'method' : 'depCryptoHistory', 'coin_name': 'BTC', 'limit' : 200, 'page': 0 } bitbnsObj.fetchMyHistory(body) ### Fetch withdrawals (crypto including airdrops) body = { 'method' : 'withCryptoHistory', 'coin_name': 'BTC', 'limit' : 200, 'page': 0 } bitbnsObj.fetchMyHistory(body) ### Fetch deposit crypto blockchain history body = { 'method' : 'depCryptoExternalHistory', 'coin_name': 'BTC', 'limit' : 200, 'page': 0 } bitbnsObj.fetchMyHistory(body) ### Fetch withdrawals crypto blockchain history body = { 'method' : 'withCryptoExternalHistory', 'coin_name': 'BTC', 'limit' : 200, 'page': 0 } bitbnsObj.fetchMyHistory(body) </pre> <details> <summary> View Response </summary> <pre> { 'data': [], 'status': 1, 'error': 'Successfully fetched data', 'code': 417 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h3><b>Swap API Endpoints</b><br></h3> <h4><b>All Supported coins available for Swap</b></h4> <pre> bitbnsObj.swapCoinList() </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': { '1inch': { 'buyEstimate': '1.895', 'buyEstimateINR': 148.7954, 'buyLimit': 200000, 'coinIcon': 'https://s2.coinmarketcap.com/static/img/coins/64x64/8104.png', 'coinId': 125, 'coinName': '1inch', 'floatPlaces': 2, 'inrDecimals': 3, 'isActiveSwap': 1, 'sellEstimate': '1.876', 'sellEstimateINR': 145.85899999999998, 'sellLimit': 200000, 'usdtDecimals': 3 }, . . } }, 'error': None, 'msg': 'Coin Details', 'status': 1 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Place limit order on Swap in INR Market</b></h4> <pre> bitbnsObj.swapLimitINR({'coin': 'BTC', 'quantity':0.000005, 'rate': 3358000, 'type': 1}) type => 0 for buy, 1 for sell </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': 'Successfully placed order.', 'error': None, 'id': 746314, 'status': 1 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any id -> order id </pre> </details> <h4><b>Place limit order on Swap in USDT Market</b></h4> <pre> bitbnsObj.swapLimitUSDT({'coin': 'BTC', 'quantity':0.000005, 'rate': 430000, 'type': 1}) type => 0 for buy, 1 for sell </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': 'Successfully placed order.', 'error': None, 'id': 746317, 'status': 1 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any id -> order id </pre> </details> <h4><b>Place market order on Swap INR market</b></h4> <pre> bitbnsObj.swapMarketINR({'coin': 'BTC', 'quantity':0.000005, 'type': 1}) type => 0 for buy, 1 for sell <br> To place order based on quantity, pass quantity in the dictionary To place order based on volume (max. amount you want to buy irresp. of quantity), pass volume in the dictionary </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': 'Successfully placed order.', 'error': None, 'id': 746328, 'status': 1 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any id -> order id </pre> </details> <h4><b>Place market order on Swap USDT market</b></h4> <pre> bitbnsObj.swapMarketUSDT({'coin': 'BTC', 'quantity':0.000005, 'type': 1}) type => 0 for buy, 1 for sell <br> To place order based on quantity, pass quantity in the dictionary To place order based on volume (max. amount you want to buy irresp. of quantity), pass volume in the dictionary </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': 'Successfully placed order.', 'error': None, 'id': 746338, 'status': 1 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any id -> order id </pre> </details> <h4><b>Get swap orders history</b></h4> <pre> bitbnsObj.swapOrderHistory({'page': 0}) type => 0 for buy, 1 for sell </pre> <details> <summary> View Response </summary> <pre> {'code': 200, 'data': [{'coin_name': {'coin_name': 'BTC'}, 'coin_type': 0, 'credit_amount': 500, 'date': '2022-02-28T07:42:54.000Z', 'exchange': 2, 'executed_inr_rate': 3358000, 'executed_usdt_rate': 42688.66090951, 'extraPaid': 0, 'factor': 100000000, 'id': 779285, 'market': 0, 'order_type': 1, 'quantity': 500, 'rate': 3358000, 'status': 3, 'volume': 1680}, {'coin_name': {'coin_name': 'BTC'}, 'coin_type': 0, 'credit_amount': 500, 'date': '2022-02-28T07:39:14.000Z', 'exchange': 2, 'executed_inr_rate': 3358000, 'executed_usdt_rate': 42688.66090951, 'extraPaid': 0, 'factor': 100000000, 'id': 779283, 'market': 0, 'order_type': 1, 'quantity': 500, 'rate': 3358000, 'status': 3, 'volume': 1680}, {'coin_name': {'coin_name': 'BTC'}, 'coin_type': 0, 'credit_amount': 500, 'date': '2022-02-28T07:29:24.000Z', 'exchange': 2, 'executed_inr_rate': 3083238.016875, 'executed_usdt_rate': 38198.36115429, 'extraPaid': 137, 'factor': 100000000, 'id': 779282, 'market': 0, 'order_type': 0, 'quantity': 500, 'rate': 3358000, 'status': 3, 'volume': 1680}, {'coin_name': {'coin_name': 'BTC'}, 'coin_type': 0, 'credit_amount': 3032, 'date': '2022-02-07T03:11:47.000Z', 'exchange': 1, 'executed_inr_rate': 3298356.72, 'executed_usdt_rate': 42341.16, 'extraPaid': 0, 'factor': 100000000, 'id': 746446, 'market': 0, 'order_type': 1, 'quantity': 3032, 'rate': 3298356.72, 'status': 3, 'volume': 10001}], 'error': None, 'msg': 'Order History', 'status': 1} Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Cancel swap order</b></h4> <pre> bitbnsObj.swapCancelOrder({'order_id': '746342', 'market': 0}) order_id => The id of the order to be cancelled market => 0 for INR, 1 for USDT </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': Successfully cancelled order, 'error': None, 'status': 1 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>List open swap order</b></h4> <pre> bitbnsObj.swapListOpenOrders({'page': 0}) <br> Endpoint is paginated </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': [{'coin_name': {'coin_name': 'BTC'}, 'coin_type': 0, 'credit_amount': 0, 'date': '2022-04-11T06:20:29.000Z', 'exchange': 1, 'executed_inr_rate': 0, 'executed_usdt_rate': 0, 'extraPaid': 0, 'factor': 100000000, 'id': 825865, 'market': 0, 'order_type': 0, 'quantity': 500, 'rate': 3358000, 'status': 0, 'volume': 1680}], 'error': None, 'msg': 'Order List', 'status': 1 } Explanation of fields: data -> the custom message status -> for successful request the status is 1 error -> error message if any </pre> </details> <h3><b>Partner Endpoints</b><br></h3> Bitbns provides support to its partners via the partner endpoints. One needs to get whitelisted by the bitbns team to use these APIs <h4><b>Create new account</b></h4> <pre> body = { 'email' : 'test_bns34324@gmail.com', 'phone' : '8676857590', 'pass' : 'hd237ydkldl', 'dormant' : 1, 'country' : 0 } b.createNewAccount(body = body) </pre> <details> <summary> View Response </summary> <pre> { data: { User_id: 1877083 }, status: 1, error: 'Successfully registered', code: 200 } Explanation of fields: data -> User ID status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Update Account details</b></h4> <pre> ### For pan card addtion body = { 'target_uid' : 1705823, 'type' : 'pan', 'id' : 'DVZPS7302U', 'name' : 'Prashant Singh', 'dob': '12-03-1992' } b.updateUserAccountDetails(body = body) ### For Aadhaar card addition body = { 'target_uid' : 1705823, 'type' : 'aadhaar', 'id' : '782379829288', 'name' : 'Prashant Singh', } b.updateUserAccountDetails(body = body) ### For addition of bank details body = { 'target_uid' : 1705823, 'type' : 'bank', 'acc_id' : '782373229829288', 'name' : 'Prashant Singh', 'branch' : 'Koramangala', 'bank_name' : 'HDFC Bank', 'ifsc' : 'HDFC00000017', 'mob' : '8676857590', 'bank_type' : 'Savings', } b.updateUserAccountDetails(body = body) ### Adding UPI id body = { 'target_uid' : 1705823, 'type' : 'upi', 'vpa' : 'atiprashant@okhdfc' } b.updateUserAccountDetails(body = body) print(response) ### Mark KYC Uploaded body = { 'target_uid' : 1705823, 'type' : 'kycUploaded' } b.updateUserAccountDetails(body = body) </pre> <details> <summary> View Response </summary> <pre> { status: 1, error: 'Successfully updated', code: 200 } Explanation of fields: status -> for successful request the status is 1 error -> error message if any </pre> </details> <h4><b>Fetch user details</b></h4> <pre> b.fetchUserAccountDetails(body = { 'target_uid': 1705823 }) </pre> <details> <summary> View Response </summary> <pre> // In case of rejection { data: { panCard: true, eyeFront: true, eyeBack: true, isTelegramLinked: false, upiList: [], email: 'testing_buyhatke1@gmail.com', phone: '+919090909090', country: 0, phone_verified: 0, video_kyc: 0, '2fa_en': '', kyc_status: 'REJECTED', allBanks: [] }, status: 1, error: null, code: 200 } // In case not submitted { data: { panCard: true, eyeFront: true, eyeBack: true, isTelegramLinked: false, upiList: [], email: 'testing_buyhatke1@gmail.com', phone: '+919090909090', country: 0, phone_verified: 0, video_kyc: 0, '2fa_en': '', kyc_status: 'REJECTED', allBanks: [] }, status: 1, error: null, code: 200 } // In case its pending { data: { panCard: true, eyeFront: true, eyeBack: true, isTelegramLinked: false, upiList: [], email: 'testing_buyhatke1@gmail.com', phone: '+919090909090', country: 0, phone_verified: 0, video_kyc: 0, '2fa_en': '', kyc_status: 'PENDING', pan: 'ABCDE7302T', dob: '1992-03-12', name: 'Test Buyhatke', aadhar: '722319529382', allBanks: [ [Object] ], mobile_bank: '9234567891', bank_name: 'HDFC Bank', ifsc: 'HDFC00000017', branch: 'Koramangala', acc_type: 'Savings', name_bank: 'Test Buyhatke', acc_num: '722675224822281', ibank: '', verified: 0 }, status: 1, error: null, code: 200 } Explanation of fields: code -> code for the request (200 means ok) panCard -> pan card added or not isTelegramLinked -> Telegram linked or not upiList -> List of UPI ids email -> email id of the user phone -> phone no. of the user country -> country of the user phone_verified -> is phone verified or not video_kyc -> Video KYC kyc_status -> Status of KYC allBanks -> List of all banks pan -> pan card id dob -> Date of birth of User name -> name of the user aadhaar -> Aadhaar card of the user bank_name -> name of the bank ifsc -> IFSC code branch -> branch of bank acc_type -> Type of account acc_num -> Account number verified -> Verified or not status -> 0 is for unsuccessful request, 1 is for a successful one </pre> </details> <h4><b>Generate new API Keys</b></h4> <pre> b.generateNewAPIKey(body = { 'target_uid': 1705823 }) </pre> <details> <summary> View Response </summary> <pre> { apiSecret: '502C783C2B50983F8BCD1F4940F54CF6', apiPublic: '63C809662EC27B19396BB1FE12E556D4', status: 1, error: null, code: 200 } Explanation of fields: apiSecret -> API Secret key apiPublic -> API Public Key status -> 1 for a successful request error -> Custom message code -> code for the request (200 means ok) </pre> </details> <h4><b>Transfer funds to Pool account</b></h4> <pre> b.transferToPoolAccount(body = { 'pool_uid' : 64873278, 'amount' : 50, }) </pre> <details> <summary> View Response </summary> <pre> { status: 1, error: 'Successfully transfered funds to pool account', code: 200 } Explanation of fields: code -> code for the request (200 means ok) error -> custom message status -> 0 is for unsuccessful request, 1 is for a successful one </pre> </details> <h4><b>Transfer coin to Pool account</b></h4> <pre> body = { 'pool_uid' : 64873278, 'amount' : 0.01, 'coin_name': 'SOL' } b.transferCoinToPoolAccount(body = body) </pre> <details> <summary> View Response </summary> <pre> { status: 1, error: 'Successfully transfered funds from pool account', code: 200 } Explanation of fields: code -> code for the request (200 means ok) error -> custom message status -> 0 is for unsuccessful request, 1 is for a successful one </pre> </details> <h4><b>Transfer coin from Pool account</b></h4> <pre> body = { 'target_uid' : 64873278, 'amount' : 1, 'coin_name': 'GARI' } b.transferCoinFromPoolAccount(body = body) </pre> <details> <summary> View Response </summary> <pre> { status: 0, error: 'Insufficient permission for this operation 0', code: 416 } Explanation of fields: code -> code for the request (200 means ok) error -> custom message status -> 0 is for unsuccessful request, 1 is for a successful one </pre> </details> <h4><b>Transfer USDT funds from Pool account</b></h4> <pre> b.transferUSDTFromPoolAccount(body = { 'target_uid' : 64873278, 'amount' : 50, }) </pre> <details> <summary> View Response </summary> <pre> { status: 0, error: 'Insufficient permission for this operation', code: 416 } Explanation of fields: code -> code for the request (200 means ok) error -> custom message status -> 0 is for unsuccessful request, 1 is for a successful one </pre> </details> <h4><b>Transfer INR funds from Pool account</b></h4> <pre> b.transferINRFromPoolAccount(body = { 'target_uid': 28746827, 'usdtAmt' : 50, 'inrAmt' : 4000, 'vpa': 'test@pingpay' }) </pre> <details> <summary> View Response </summary> <pre> { status: 0, error: 'Insufficient permission for this operation', code: 416 } Explanation of fields: code -> code for the request (200 means ok) error -> custom message status -> 0 is for unsuccessful request, 1 is for a successful one </pre> </details> <h4><b>Request Coin Withdrawal</b></h4> <pre> b.requestCoinWithdrawFromPoolAccount(body = { 'target_uid' : 23342324, 'amount' : 1, 'coin_name': 'GARI' }) </pre> <details> <summary> View Response </summary> <pre> Explanation of fields: </pre> </details> <h3><b>Payment Gateway</b><br></h3> For people who would want to use bitbns gateway for crypto payments, can do so using the endpoints described in this section. You need two things before you can start to use the portal: <ul> <li>merchant_id</li> <li>merchant_secret</li> </ul> You need to get an approval from the Bitbns dev team for generating and using the gateway. <br><br> To successfully use the gateway, please follow the following steps: <ol> <li>Generate a payment request</li> <li>Step 1 would redirect you to a payment URL</li> <li>On success/failure, Bitbns will redirect you to landing/callback page with fields - status, msg, amount, coin, signature</li> <li>Verify the signature</li> <li>Alternatively, you can also fetch payment status from fetchPGOrderStatus</li> </ol> <h4><b>Create New Payment Gateway Order</b></h4> <pre> body = { 'merchant_id': 1, 'amt': 25, 'coin': "USDT", 'refId': "ORDER_CLIENT123487134", 'email': 'xyz@buyhatke.com' } response = b.createNewPGOrder(body = body) </pre> <details> <summary> View Response </summary> <pre> { data: { order_id: 22, url: 'https://bitbns.com/payments/?oid=22' }, status: 1, error: 'Successfully generated order', code: 200 } Explanation of fields: order_id -> Id of the Order url -> Payment URL status -> 1 for successful request error -> custom message </pre> </details> <h4><b>Fetch Payment Gateway Order</b></h4> <pre> b.createNewPGOrder(body = { 'merchant_id': 1, 'order_id': 21 }) </pre> <details> <summary> View Response </summary> <pre> // If user is on the payment page { data: [ { id: 40, merchant_id: 1, coin: 54, amount: 10000, init_time: '2022-01-05T08:51:26.000Z', payment_time: '0000-00-00 00:00:00', client_ref_id: 'ORDER_CLIENT112', status: 0, user_id: 103602, errMsg: '' } ], status: 1, error: 'Successfully fetched details', code: 200 } // If the user has declined payment { data: [ { id: 40, merchant_id: 1, coin: 54, amount: 10000, init_time: '2022-01-05T08:51:26.000Z', payment_time: '0000-00-00 00:00:00', client_ref_id: 'ORDER_CLIENT112', status: -1, user_id: 103602, errMsg: 'User declined payment' } ], status: 1, error: 'Successfully fetched details', code: 200 } // If user has successfully paid { data: [ { id: 43, merchant_id: 1, coin: 54, amount: 1, init_time: '2022-01-05T11:03:34.000Z', payment_time: '2022-01-05T11:34:04.000Z', client_ref_id: 'ORDER_CLIENT112', status: 1, user_id: 103602, errMsg: '' } ], status: 1, error: 'Successfully fetched details', code: 200 } // Unauthorized payment - order_id or otherwise { status: 0, error: 'Unauthorized to fetch order status ', code: 200 } Explanation of fields: </pre> </details> <h3><b>Futures</b><br></h3> Bitbns is proud to announce the release of futures trading on its platform. Here lies the documentation for the same <h4><b>Active markets</b></h4> <pre> response = b.futuresInstList(body = {'network': 'mainnet'}) </pre> <details> <summary> View Response </summary> <pre> {'code': 200, 'data': {'1': {'coin_id': 477, 'default_leverage': '10', 'factor': 100000000, 'inst_id': 1, 'inst_leverage_json': {'1': 20, '10': 2, '3': 7, '5': 4}, 'margin_bucket_json': {'1': 20, '10': 2.5, '3': 10, '5': 5}, 'min_allowed': 0.0003, 'name': 'IC15USDT Perpetual', 'price_prec': 2, 'qnty_prec': 4, 'status': 0, 'usdt_settled': 1}, '2': {'coin_id': 0, 'default_leverage': '10', 'factor': 100000000, 'inst_id': 2, 'inst_leverage_json': {'1': 30, '10': 3, '3': 10, '5': 6}, 'margin_bucket_json': {'1': 20, '10': 2.5, '3': 10, '5': 5}, 'min_allowed': 0.0003, 'name': 'BTCUSDT Perpetual', 'price_prec': 2, 'qnty_prec': 4, 'status': 0, 'usdt_settled': 1}, '3': {'coin_id': 6, 'default_leverage': '10', 'factor': 100000000, 'inst_id': 3, 'inst_leverage_json': {'1': 500, '10': 50, '3': 175, '5': 100}, 'margin_bucket_json': {'1': 20, '10': 2.5, '3': 10, '5': 5}, 'min_allowed': 0.005, 'name': 'ETHUSDT Perpetual', 'price_prec': 2, 'qnty_prec': 3, 'status': 0, 'usdt_settled': 1}, '4': {'coin_id': 77, 'default_leverage': '3', 'factor': 100, 'inst_id': 4, 'inst_leverage_json': {'1': 12500000, '3': 5000000}, 'margin_bucket_json': {'1': 20, '3': 10}, 'min_allowed': 25000, 'name': 'BNSUSDT Perpetual', 'price_prec': 8, 'qnty_prec': 0, 'status': 0, 'usdt_settled': 1}}, 'error': None, 'msg': 'Instrument Details', 'status': 1} <br> Explanation of fields: coin_id -> Coin ID default_leverage -> default leverage set by trading system factor -> factor in which coin operates inst_id -> Instrument ID min_allowed -> Minimum order quantity name -> Name of the instrument price_prec -> Price precision qnty_prec -> Quantity Precision </pre> </details> <h4><b>Wallet Balance</b></h4> <pre> response = b.futuresWalletBalance(body = {'network': 'mainnet'}) </pre> <details> <summary> View Response </summary> <pre> Explanation of fields: </pre> </details> <h4><b>Allowed Open Position</b></h4> <pre> body = { 'inst_id': 1, 'network': 'mainnet' } response = b.futuresMaxOpenPos(body = body) </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': {'maxOpenPositionsAllowed': {'1': 0}}, 'error': 'Max Open Positions', 'status': 1 } <br> Explanation of fields: data -> max open position allowed for the specified instrument </pre> </details> <h4><b>Update user leverage</b></h4> <pre> body = { 'inst_id': 2, 'leverage': 7, 'network': 'mainnet' } response = b.futuresUpdateLeverage(body = body) </pre> <details> <summary> View Response </summary> <pre> { 'code': 200, 'data': { 'leverage': 7 }, 'error': 'Leverage Updated Successfully', 'status': 1 } <br> Explanation of fields: leverage -> leverage amount it has been updated to </pre> </details> <h4><b>Get Open Orders</b></h4> <pre> body = {'network': 'mainnet'} response = b.futuresOpenOrders() </pre> <details> <summary> View Response </summary> <pre> {'code': 200, 'data': [{'initial_margin': 0.86, 'inst_id': 2, 'order_id': 152538, 'order_time': '2022-07-14T08:10:01.000Z', 'qnty': 0.0003, 'qnty_rem': 0.0003, 'rate': 19700, 'side': 'Long', 'type': 'Open', 'usdt_settled': 1}], 'error': 'Open Orders', 'status': 1} <br> Explanation of fields: data -> An array of open orders initial_margin-> Initial Margin inst_id -> Instrument ID order_id -> Order ID qnty -> Quantity placed qnty_rem -> Remaining quantity to execute rate -> Rate at which the order was placed side -> Long/Short type -> Open/Close </pre> </details> <h4><b>Get Open Positions</b></h4> <pre> body = { 'network': 'mainnet' } response = b.futuresOpenPositions() </pre> <details> <summary> View Response </summary> <pre> {'code': 200, 'data': [{'avg_price': 19977.6, 'factor': 100000000, 'inst_id': 2, 'lock': 0, 'position': 0.001, 'side': 0, 'usdt_settled': 1}], 'error': 'Open Positions', 'status': 1} <br> Explanation of fields: avg_price -> Current average price inst_id -> Instrument ID lock -> Amount locked position -> Size of the position side -> Long/Short </pre> </details> <h4><b>Place Open Orders</b></h4> <pre> posSide => 0/1 (Long/Short) <br> body = { 'inst_id': 2, 'rate': 19700, 'qnty': 0.0003, 'posSide': 0 # Going long 'network': 'mainnet' } response = b.futuresPlaceOpenOrder(body = body) </pre> <details> <summary> View Response </summary> <pre> {'code': 200, 'data': {'order_id': 152538}, 'error': 'Successfully placed order ', 'status': 1} <br> Explanation of fields: order_id -> Order ID of the order </pre> </details> <h4><b>Cancel Open Orders</b></h4> <pre> body = { 'order_id': 152538, 'network': 'mainnet' } response = b.futuresCancelOpenOrder(body = body) </pre> <details> <summary> View Response </summary> <pre> {'code': 412, 'data': {'order_id': '152538'}, 'error': 'Successfully canceled open order', 'status': 1} <br> Explanation of fields: order_id -> Order ID of the order </pre> </details> <h4><b>Place Close Orders</b></h4> <pre> posSide => 0/1 (Long/Short) <br> body = { 'inst_id': 8, 'rate': 98000, 'qnty': 0.1, 'posSide': 0 # Going long 'network': 'mainnet' } response = b.futuresPlaceCloseOrder(body = body) print(response) </pre> <details> <summary> View Response </summary> <pre> {'code': 200, 'data': {'order_id': 153430}, 'error': 'Successfully placed order', 'status': 1} <br> Explanation of fields: order_id -> Order ID of the order </pre> </details> <h4><b>Cancel Close Orders</b></h4> <pre> body = { 'order_id': 152538, 'network': 'mainnet' } response = b.futuresCancelCloseOrder(body = body) print(response) </pre> <details> <summary> View Response </summary> <pre> {'code': 412, 'data': {'order_id': '152538'}, 'error': 'Successfully canceled close order', 'status': 1} <br> Explanation of fields: order_id -> Order ID of the order </pre> </details> <h2>HTTP error status codes </h2> <h3> HTTP error codes would be returned incase of any errors, the body will also cointain an error feild which will explain the cause of the error</h3> <div id ="HTTP_error_code_table" style ="border:1px solid"> <table style = "width:100%"> <tr> <th>Code</th> <th>Meaning</th> </tr> <tr> <th></th> <th></th> </tr> <tr> <th>200</th> <th>null -- requested action has been performed without any problems </th> </tr> <tr> <th>400</th> <th>Invalid Request -- Invalid request format</th> </tr> <tr> <th>401</th> <th>authentication -- Not authorised or invalid API key</th> </tr> <tr> <th>403</th> <th>Undefined -- this request is forbidden</th> </tr> <tr> <th>404</th> <th>Exchange not found -- Unable to find exchange</th> </tr> <tr> <th>406</th> <th>Coin name not supplied or not yet supported -- coin name applied is incorrect</th> </tr> <tr> <th>409</th> <th>parameter type not correct -- parameters entered is incorrect</th> </tr> <tr> <th>412</th> <th>Oops ! Cancellation failed. Something went wrong ! -- Unable to cancel order</th> </tr> <tr> <th>413</th> <th>volume asked not acceptable -- Desired volume is not within bounds</th> </tr> <tr> <th>416</th> <th>Oops ! Not sufficient balance to purchase currency -- wallet balance is not sufficient </th> </tr> <tr> <th>417</th> <th>Oops ! Order doesn't exist any more -- Order has alredy been deleted</th> </tr> <tr> <th>428</th> <th>Price seems Irregular from current market price. -- Entered price is more than current price</th> </tr> <tr> <th>500</th> <th>Problem with our servers, try again later</th> </tr> <tr> <th>503</th> <th>currently down for maintaince</th> </tr> </tr> </table> </div>


نیازمندی

مقدار نام
==0.21.2 bidict
==2021.5.30 certifi
==4.0.0 chardet
==2.10 idna
==4.2.0 python-engineio
==5.3.0 python-socketio
==2.25.1 requests
==1.26.5 urllib3
==1.1.0 websocket-client


زبان مورد نیاز

مقدار نام
>=3.6 Python


نحوه نصب


نصب پکیج whl bitbnspy-0.3.1:

    pip install bitbnspy-0.3.1.whl


نصب پکیج tar.gz bitbnspy-0.3.1:

    pip install bitbnspy-0.3.1.tar.gz