Name | bluefin-client-sui JSON |
Version |
2.0.0
JSON |
| download |
home_page | |
Summary | Library to interact with firefly exchange protocol including its off-chain api-gateway and on-chain contracts |
upload_time | 2023-08-27 12:54:18 |
maintainer | |
docs_url | None |
author | |
requires_python | >=3.8 |
license | |
keywords |
bluefin
exchange
decentralized
perpetuals
blockchain
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
<div align="center">
<img height="100x" src="https://bluefin.io/images/bluefin-logo.svg" />
<h1 style="margin-top:20px;">Bluefin Python Client Library</h1>
</div>
Python Client for the Bluefin Exchange API and SUI Contracts.
### Install
The package can be installed from [PyPi](https://pypi.org/project/bluefin-client-sui/) using pip:
```
pip install bluefin_client_sui
```
Alternatively, you could run:
```
pip install .
```
The package currently supports python `>=3.8`. Find complete documentation on the library at https://docs.bluefin.io/.
### Getting Started
When initializing the client, users must accept [terms and conditions](https://bluefin.io/terms-of-use) and define network object containing the following values:
```json
{
"apiGateway": "https://dapi.api.sui-prod.bluefin.io",
"socketURL": "wss://dapi.api.sui-prod.bluefin.io",
"dmsURL": "https://dapi.api.sui-prod.bluefin.io",
"webSocketURL": "wss://notifications.api.sui-prod.bluefin.io",
"onboardingUrl": "https://trade.bluefin.io"
}
```
Users can import predefined networks from [constants](https://github.com/fireflyprotocol/bluefin-client-python-sui/blob/main/src/bluefin_client_sui/constants.py):
```python
from bluefin_client_sui import Networks
```
For testing purposes use `Networks[SUI_STAGING]` and for production use `Networks[SUI_PROD]`.
## Initialization example
```python
from config import TEST_ACCT_KEY, TEST_NETWORK
from bluefin_client_sui import BluefinClient, Networks
from pprint import pprint
import asyncio
async def main():
# initialize client
client = BluefinClient(
True, # agree to terms and conditions
Networks[TEST_NETWORK], # network to connect with
TEST_ACCT_KEY, # private key of wallet
)
# on boards user on bluefin. Must be set to true for firs time use
await client.init(True)
print('Account address:', client.get_public_address())
# gets user account on-chain data
data = await client.get_user_account_data()
# close aio http connection
await client.apis.close_session()
pprint(data)
if __name__ == "__main__":
loop = asyncio.new_event_loop()
loop.run_until_complete(main())
loop.close()
```
**Read-only Initialization:**
Bluefin-client can also be initialized in `read-only` mode, below is the example:
```python
from config import TEST_ACCT_KEY, TEST_NETWORK
from bluefin_client_sui import BluefinClient, Networks
from pprint import pprint
import asyncio
async def main():
# initialize client without providing private_key
client = BluefinClient(
True, # agree to terms and conditions
Networks[TEST_NETWORK], # network to connect with
)
# Initializing client for the private key provided. The second argument api_token is optional
await client.init(True,"54b0bfafc9a48728f76e52848a716e96d490263392e3959c2d44f05dea960761")
# close aio http connection
await client.apis.close_session()
await client.dmsApi.close_session()
pprint(data)
if __name__ == "__main__":
loop = asyncio.new_event_loop()
loop.run_until_complete(main())
loop.close()
```
Here is the [list](https://docs.bluefin.io/8/2.readonly-access-data) of APIs that can be accessed in `read-only` mode.
**Placing Orders:**
```python
from config import TEST_ACCT_KEY, TEST_NETWORK
from bluefin_client_sui import BluefinClient, Networks, MARKET_SYMBOLS, ORDER_SIDE, ORDER_TYPE, OrderSignatureRequest
import asyncio
async def main():
# initialize client
client = BluefinClient(
True, # agree to terms and conditions
Networks[TEST_NETWORK], # network to connect with
TEST_ACCT_KEY, # private key of wallet
)
await client.init(True)
user_leverage = await client.get_user_leverage(MARKET_SYMBOLS.ETH)
# creates a LIMIT order to be signed
signature_request = OrderSignatureRequest(
symbol=MARKET_SYMBOLS.ETH, # market symbol
price=1900, # price at which you want to place order
quantity=0.01, # quantity
side=ORDER_SIDE.SELL,
orderType=ORDER_TYPE.LIMIT,
leverage=user_leverage
)
# create signed order
signed_order = client.create_signed_order(signature_request)
print("Placing a limit order")
# place signed order on orderbook
resp = await client.post_signed_order(signed_order)
# returned order with PENDING state
print(resp)
await client.apis.close_session()
if __name__ == "__main__":
loop = asyncio.new_event_loop()
loop.run_until_complete(main())
loop.close()
```
**Listening To Events Using Socket.io:**
```python
from config import TEST_ACCT_KEY, TEST_NETWORK
from bluefin_client_sui import BluefinClient, Networks, SOCKET_EVENTS
import asyncio
import time
def callback(event):
print("Event data:", event)
async def main():
# initialize
client = BluefinClient(
True, # agree to terms and conditions
Networks[TEST_NETWORK], # network to connect with
TEST_ACCT_KEY, # private key of wallet
)
await client.init(True)
# make connection with bluefin exchange
await client.socket.open()
# subscribe to local user events
await client.socket.subscribe_user_update_by_token()
# listen to exchange health updates and trigger callback
await client.socket.listen(SOCKET_EVENTS.EXCHANGE_HEALTH.value, callback)
time.sleep(10)
# unsubscribe from user events
await client.socket.unsubscribe_user_update_by_token()
# close socket connection
await client.socket.close()
if __name__ == "__main__":
loop = asyncio.new_event_loop()
loop.run_until_complete(main())
loop.close()
```
Look at the [example](https://github.com/fireflyprotocol/bluefin-client-python-sui/tree/main/examples) directory to see more examples on how to use this library.
**Listening To Events Using Web Sockets:**
```python
from config import TEST_ACCT_KEY, TEST_NETWORK
from bluefin_client_sui import BluefinClient, Networks, SOCKET_EVENTS, MARKET_SYMBOLS
import time
import asyncio
def callback(event):
print("Event data:", event)
async def main():
# initialize
client = BluefinClient(
True, # agree to terms and conditions
Networks[TEST_NETWORK], # network to connect with
TEST_ACCT_KEY, # private key of wallet
)
await client.init(True)
def on_open(ws):
# subscribe to global events
resp = client.webSocketClient.subscribe_global_updates_by_symbol(symbol=MARKET_SYMBOLS.ETH)
if resp:
print("Subscribed to global updates")
resp = client.webSocketClient.subscribe_user_update_by_token()
if resp:
print("Subscribed to user updates")
# make connection with bluefin exchange
client.webSocketClient.initialize_socket(on_open=on_open)
# listen to user order updates and trigger callback
client.webSocketClient.listen(SOCKET_EVENTS.EXCHANGE_HEALTH.value, callback)
time.sleep(60)
# unsubscribe from global events
client.webSocketClient.unsubscribe_global_updates_by_symbol(symbol=MARKET_SYMBOLS.ETH)
client.webSocketClient.stop()
if __name__ == "__main__":
loop = asyncio.new_event_loop()
loop.run_until_complete(main())
loop.close()
```
Raw data
{
"_id": null,
"home_page": "",
"name": "bluefin-client-sui",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": "",
"keywords": "bluefin,exchange,decentralized,perpetuals,blockchain",
"author": "",
"author_email": "",
"download_url": "https://files.pythonhosted.org/packages/92/15/4176579d4a069259cafe3c77199586f3d54e6eb88bcd3bd4e621b241f48e/bluefin_client_sui-2.0.0.tar.gz",
"platform": null,
"description": "<div align=\"center\">\n <img height=\"100x\" src=\"https://bluefin.io/images/bluefin-logo.svg\" />\n\n <h1 style=\"margin-top:20px;\">Bluefin Python Client Library</h1>\n\n</div>\n\nPython Client for the Bluefin Exchange API and SUI Contracts.\n\u200b\n\n### Install\n\nThe package can be installed from [PyPi](https://pypi.org/project/bluefin-client-sui/) using pip:\n\n```\npip install bluefin_client_sui\n```\n\nAlternatively, you could run:\n\n```\npip install .\n```\n\nThe package currently supports python `>=3.8`. Find complete documentation on the library at https://docs.bluefin.io/.\n\n### Getting Started\n\nWhen initializing the client, users must accept [terms and conditions](https://bluefin.io/terms-of-use) and define network object containing the following values:\n\n```json\n{\n \"apiGateway\": \"https://dapi.api.sui-prod.bluefin.io\",\n \"socketURL\": \"wss://dapi.api.sui-prod.bluefin.io\",\n \"dmsURL\": \"https://dapi.api.sui-prod.bluefin.io\",\n \"webSocketURL\": \"wss://notifications.api.sui-prod.bluefin.io\",\n \"onboardingUrl\": \"https://trade.bluefin.io\"\n}\n```\n\nUsers can import predefined networks from [constants](https://github.com/fireflyprotocol/bluefin-client-python-sui/blob/main/src/bluefin_client_sui/constants.py):\n\n```python\nfrom bluefin_client_sui import Networks\n```\n\nFor testing purposes use `Networks[SUI_STAGING]` and for production use `Networks[SUI_PROD]`.\n\n## Initialization example\u200b\n\n```python\nfrom config import TEST_ACCT_KEY, TEST_NETWORK\nfrom bluefin_client_sui import BluefinClient, Networks\nfrom pprint import pprint\nimport asyncio\n\nasync def main():\n # initialize client\n client = BluefinClient(\n True, # agree to terms and conditions\n Networks[TEST_NETWORK], # network to connect with\n TEST_ACCT_KEY, # private key of wallet\n )\n\n # on boards user on bluefin. Must be set to true for firs time use\n await client.init(True)\n\n print('Account address:', client.get_public_address())\n\n # gets user account on-chain data\n data = await client.get_user_account_data()\n\n # close aio http connection\n await client.apis.close_session()\n\n pprint(data)\n\nif __name__ == \"__main__\":\n loop = asyncio.new_event_loop()\n loop.run_until_complete(main())\n loop.close()\n```\n\n**Read-only Initialization:**\nBluefin-client can also be initialized in `read-only` mode, below is the example:\n\n```python\nfrom config import TEST_ACCT_KEY, TEST_NETWORK\nfrom bluefin_client_sui import BluefinClient, Networks\nfrom pprint import pprint\nimport asyncio\n\nasync def main():\n # initialize client without providing private_key\n client = BluefinClient(\n True, # agree to terms and conditions\n Networks[TEST_NETWORK], # network to connect with\n )\n\n # Initializing client for the private key provided. The second argument api_token is optional\n await client.init(True,\"54b0bfafc9a48728f76e52848a716e96d490263392e3959c2d44f05dea960761\")\n\n # close aio http connection\n await client.apis.close_session()\n await client.dmsApi.close_session()\n\n pprint(data)\n\nif __name__ == \"__main__\":\n loop = asyncio.new_event_loop()\n loop.run_until_complete(main())\n loop.close()\n```\n\n\u200bHere is the [list](https://docs.bluefin.io/8/2.readonly-access-data) of APIs that can be accessed in `read-only` mode.\n\n**Placing Orders:**\n\n```python\nfrom config import TEST_ACCT_KEY, TEST_NETWORK\nfrom bluefin_client_sui import BluefinClient, Networks, MARKET_SYMBOLS, ORDER_SIDE, ORDER_TYPE, OrderSignatureRequest\nimport asyncio\n\nasync def main():\n # initialize client\n client = BluefinClient(\n True, # agree to terms and conditions\n Networks[TEST_NETWORK], # network to connect with\n TEST_ACCT_KEY, # private key of wallet\n )\n\n await client.init(True)\n\n user_leverage = await client.get_user_leverage(MARKET_SYMBOLS.ETH)\n\n # creates a LIMIT order to be signed\n signature_request = OrderSignatureRequest(\n symbol=MARKET_SYMBOLS.ETH, # market symbol\n price=1900, # price at which you want to place order\n quantity=0.01, # quantity\n side=ORDER_SIDE.SELL,\n orderType=ORDER_TYPE.LIMIT,\n leverage=user_leverage\n )\n\n # create signed order\n signed_order = client.create_signed_order(signature_request)\n\n print(\"Placing a limit order\")\n # place signed order on orderbook\n resp = await client.post_signed_order(signed_order)\n\n # returned order with PENDING state\n print(resp)\n\n await client.apis.close_session()\n\n\nif __name__ == \"__main__\":\n loop = asyncio.new_event_loop()\n loop.run_until_complete(main())\n loop.close()\n```\n\n\u200b\n**Listening To Events Using Socket.io:**\n\n```python\nfrom config import TEST_ACCT_KEY, TEST_NETWORK\nfrom bluefin_client_sui import BluefinClient, Networks, SOCKET_EVENTS\nimport asyncio\nimport time\n\ndef callback(event):\n print(\"Event data:\", event)\n\nasync def main():\n # initialize\n client = BluefinClient(\n True, # agree to terms and conditions\n Networks[TEST_NETWORK], # network to connect with\n TEST_ACCT_KEY, # private key of wallet\n )\n await client.init(True)\n # make connection with bluefin exchange\n await client.socket.open()\n\n # subscribe to local user events\n await client.socket.subscribe_user_update_by_token()\n\n # listen to exchange health updates and trigger callback\n await client.socket.listen(SOCKET_EVENTS.EXCHANGE_HEALTH.value, callback)\n time.sleep(10)\n # unsubscribe from user events\n await client.socket.unsubscribe_user_update_by_token()\n # close socket connection\n await client.socket.close()\n\nif __name__ == \"__main__\":\n loop = asyncio.new_event_loop()\n loop.run_until_complete(main())\n loop.close()\u200b\n```\n\nLook at the [example](https://github.com/fireflyprotocol/bluefin-client-python-sui/tree/main/examples) directory to see more examples on how to use this library.\n\n**Listening To Events Using Web Sockets:**\n\n```python\nfrom config import TEST_ACCT_KEY, TEST_NETWORK\nfrom bluefin_client_sui import BluefinClient, Networks, SOCKET_EVENTS, MARKET_SYMBOLS\nimport time\nimport asyncio\n\ndef callback(event):\n print(\"Event data:\", event)\n\nasync def main():\n # initialize\n client = BluefinClient(\n True, # agree to terms and conditions\n Networks[TEST_NETWORK], # network to connect with\n TEST_ACCT_KEY, # private key of wallet\n )\n\n await client.init(True)\n\n def on_open(ws):\n # subscribe to global events\n resp = client.webSocketClient.subscribe_global_updates_by_symbol(symbol=MARKET_SYMBOLS.ETH)\n if resp:\n print(\"Subscribed to global updates\")\n resp = client.webSocketClient.subscribe_user_update_by_token()\n if resp:\n print(\"Subscribed to user updates\")\n\n # make connection with bluefin exchange\n client.webSocketClient.initialize_socket(on_open=on_open)\n # listen to user order updates and trigger callback\n client.webSocketClient.listen(SOCKET_EVENTS.EXCHANGE_HEALTH.value, callback)\n\n time.sleep(60)\n\n # unsubscribe from global events\n client.webSocketClient.unsubscribe_global_updates_by_symbol(symbol=MARKET_SYMBOLS.ETH)\n client.webSocketClient.stop()\n\n\nif __name__ == \"__main__\":\n loop = asyncio.new_event_loop()\n loop.run_until_complete(main())\n loop.close()\n```\n",
"bugtrack_url": null,
"license": "",
"summary": "Library to interact with firefly exchange protocol including its off-chain api-gateway and on-chain contracts",
"version": "2.0.0",
"project_urls": {
"Bug Reports": "https://github.com/fireflyprotocol/bluefin-client-python-sui/issues",
"Homepage": "https://github.com/fireflyprotocol/bluefin-client-python-sui",
"Source": "https://github.com/fireflyprotocol/bluefin-client-python-sui"
},
"split_keywords": [
"bluefin",
"exchange",
"decentralized",
"perpetuals",
"blockchain"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "6ea3172ca627faeade2f40c056d2ba688492800a493947fbc44ca963eed73d7f",
"md5": "b338d19d480d63205610b52cd70b5204",
"sha256": "346d5aacdfb6cd4a903f8238d90ca4cbf3f20691c2e80076ee5fefbd4e6f0386"
},
"downloads": -1,
"filename": "bluefin_client_sui-2.0.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "b338d19d480d63205610b52cd70b5204",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 28700,
"upload_time": "2023-08-27T12:54:16",
"upload_time_iso_8601": "2023-08-27T12:54:16.858893Z",
"url": "https://files.pythonhosted.org/packages/6e/a3/172ca627faeade2f40c056d2ba688492800a493947fbc44ca963eed73d7f/bluefin_client_sui-2.0.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "92154176579d4a069259cafe3c77199586f3d54e6eb88bcd3bd4e621b241f48e",
"md5": "034d618b3243a9c64d7a48b97c98e9a3",
"sha256": "621ad030071e020d2df079cf1d9390ee09fcf923dd22862abed2de18efd0efb9"
},
"downloads": -1,
"filename": "bluefin_client_sui-2.0.0.tar.gz",
"has_sig": false,
"md5_digest": "034d618b3243a9c64d7a48b97c98e9a3",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 25065,
"upload_time": "2023-08-27T12:54:18",
"upload_time_iso_8601": "2023-08-27T12:54:18.516085Z",
"url": "https://files.pythonhosted.org/packages/92/15/4176579d4a069259cafe3c77199586f3d54e6eb88bcd3bd4e621b241f48e/bluefin_client_sui-2.0.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-08-27 12:54:18",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "fireflyprotocol",
"github_project": "bluefin-client-python-sui",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "bluefin-client-sui"
}