# Lighter
Python client for Lighter (v1).
## Installation
```bash
pip install lighter-python-v1
```
## Getting Started
The `Client` object has two main modules;
- `Api`: allows interaction with the lighter api
- `Blockchain`: allows interaction with ligter contracts
`Client` can be created with private key or not depending on whether you are going to use the api or interract with the contracts. For more complete examples, see the [examples](./examples/) directory.
### API
Following parameters are required to use `Api` module:
- `api_auth`: You should get the key from our servers.
- `web3_provider_url`: You need a node to interact with the contract. We suggest alchemy which provides 300M free compute units monthly, You can register and get your keys [here](https://www.alchemy.com/)
```python
from lighter.lighter_client import Client
import os
from lighter.modules.blockchain import OrderSide
from lighter.constants import ORDERBOOK_WETH_USDC
api_auth = os.environ.get("API_AUTH")
# You don't need to provide private key if you only want to use the api module.
client = Client(api_auth=api_auth, web3_provider_url="ALCHEMY_URL")
# Let's get available blockchains and their details from the api module.
blockchains = client.api.get_blockchains().data
```
### Blockchain
Following parameters are required to use `Blockchain` module:
- `api_auth`: You should get the key from our servers.
- `private_key`: You need to provide your wallet private key to sign your transactions.
- `web3_provider_url`: You need a node to interact with the contract. We suggest alchemy which provides 300M free compute units monthly, You can register and get your keys [here](https://www.alchemy.com/)
```python
from lighter.lighter_client import Client
import os
from lighter.modules.blockchain import OrderSide
from lighter.constants import ORDERBOOK_WETH_USDC
private_key = os.environ.get("SOURCE_PRIVATE_KEY")
api_auth = os.environ.get("API_AUTH")
client = Client(
private_key=private_key, api_auth=api_auth, web3_provider_url="ALCHEMY_URL"
)
x = client.blockchain # initialize the blockchain module before using it
# Let's create a batch of limit orders
sizes = ["0.001", "0.001", "0.001"]
prices = ["1050", "1200", "1000"]
sides = [OrderSide.BUY, OrderSide.SELL, OrderSide.BUY]
tx_hash = client.blockchain.create_limit_order_batch("WETH_USDC", sizes, prices, sides)
# if you want to wait for the transaction to be mined and get order id and other details,
# you can use the following method.
# alternatively you can wait the data from websocket
result = client.blockchain.get_create_order_transaction_result(tx_hash, "WETH_USDC")
```
Raw data
{
"_id": null,
"home_page": "https://github.com/elliottech/lighter-python-v1",
"name": "lighter-python-v1",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "lighter exchange rest api defi ethereum optimism l2 eth",
"author": "Elliot",
"author_email": "ahmet@elliot.ai",
"download_url": "https://files.pythonhosted.org/packages/1a/73/bb583977db5a93963d8403000570b514ddc5bca36f094c8bdab41c89ad4d/lighter-python-v1-1.0.0.tar.gz",
"platform": null,
"description": "# Lighter\n\nPython client for Lighter (v1).\n\n## Installation\n\n```bash\npip install lighter-python-v1 \n```\n\n## Getting Started\n\nThe `Client` object has two main modules;\n\n- `Api`: allows interaction with the lighter api\n- `Blockchain`: allows interaction with ligter contracts\n\n`Client` can be created with private key or not depending on whether you are going to use the api or interract with the contracts. For more complete examples, see the [examples](./examples/) directory.\n\n### API\n\nFollowing parameters are required to use `Api` module:\n\n- `api_auth`: You should get the key from our servers.\n- `web3_provider_url`: You need a node to interact with the contract. We suggest alchemy which provides 300M free compute units monthly, You can register and get your keys [here](https://www.alchemy.com/)\n\n```python\nfrom lighter.lighter_client import Client\nimport os\nfrom lighter.modules.blockchain import OrderSide\nfrom lighter.constants import ORDERBOOK_WETH_USDC\n\napi_auth = os.environ.get(\"API_AUTH\")\n\n# You don't need to provide private key if you only want to use the api module.\n\nclient = Client(api_auth=api_auth, web3_provider_url=\"ALCHEMY_URL\")\n\n# Let's get available blockchains and their details from the api module.\nblockchains = client.api.get_blockchains().data\n```\n\n### Blockchain\n\nFollowing parameters are required to use `Blockchain` module:\n\n- `api_auth`: You should get the key from our servers.\n- `private_key`: You need to provide your wallet private key to sign your transactions.\n- `web3_provider_url`: You need a node to interact with the contract. We suggest alchemy which provides 300M free compute units monthly, You can register and get your keys [here](https://www.alchemy.com/)\n\n```python\nfrom lighter.lighter_client import Client\nimport os\nfrom lighter.modules.blockchain import OrderSide\nfrom lighter.constants import ORDERBOOK_WETH_USDC\n\n\nprivate_key = os.environ.get(\"SOURCE_PRIVATE_KEY\")\napi_auth = os.environ.get(\"API_AUTH\")\n\n\nclient = Client(\n private_key=private_key, api_auth=api_auth, web3_provider_url=\"ALCHEMY_URL\"\n)\n\n\nx = client.blockchain # initialize the blockchain module before using it\n\n\n# Let's create a batch of limit orders\n\nsizes = [\"0.001\", \"0.001\", \"0.001\"]\nprices = [\"1050\", \"1200\", \"1000\"]\nsides = [OrderSide.BUY, OrderSide.SELL, OrderSide.BUY]\n\n\ntx_hash = client.blockchain.create_limit_order_batch(\"WETH_USDC\", sizes, prices, sides)\n\n# if you want to wait for the transaction to be mined and get order id and other details,\n# you can use the following method.\n# alternatively you can wait the data from websocket\nresult = client.blockchain.get_create_order_transaction_result(tx_hash, \"WETH_USDC\")\n```\n",
"bugtrack_url": null,
"license": "Apache 2.0",
"summary": "lighter Python rest api and blockchain interactions for Limit Orders",
"version": "1.0.0",
"split_keywords": [
"lighter",
"exchange",
"rest",
"api",
"defi",
"ethereum",
"optimism",
"l2",
"eth"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "fa8643bd1b76c6b83a04de9c18b5f97809f6942a6569146259866849c4287109",
"md5": "312984d35f116e299f8202a9a4e238b7",
"sha256": "62396532973ac6773e2f09c7ecaffb095e60e77100c0e03b6bf5e11abf030fd8"
},
"downloads": -1,
"filename": "lighter_python_v1-1.0.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "312984d35f116e299f8202a9a4e238b7",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 22966,
"upload_time": "2023-01-24T11:16:36",
"upload_time_iso_8601": "2023-01-24T11:16:36.574353Z",
"url": "https://files.pythonhosted.org/packages/fa/86/43bd1b76c6b83a04de9c18b5f97809f6942a6569146259866849c4287109/lighter_python_v1-1.0.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "1a73bb583977db5a93963d8403000570b514ddc5bca36f094c8bdab41c89ad4d",
"md5": "cb773f22205ddfd917859f1b7a5f9936",
"sha256": "bb3f68880b3c060e8a2e41fe42e133691d06b68bb14df7a8d56d169a9eca5c59"
},
"downloads": -1,
"filename": "lighter-python-v1-1.0.0.tar.gz",
"has_sig": false,
"md5_digest": "cb773f22205ddfd917859f1b7a5f9936",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 20944,
"upload_time": "2023-01-24T11:16:39",
"upload_time_iso_8601": "2023-01-24T11:16:39.534470Z",
"url": "https://files.pythonhosted.org/packages/1a/73/bb583977db5a93963d8403000570b514ddc5bca36f094c8bdab41c89ad4d/lighter-python-v1-1.0.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-01-24 11:16:39",
"github": true,
"gitlab": false,
"bitbucket": false,
"github_user": "elliottech",
"github_project": "lighter-python-v1",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"circle": true,
"requirements": [],
"tox": true,
"lcname": "lighter-python-v1"
}