Name | zerodha-tickersaver JSON |
Version |
1.1.2
JSON |
| download |
home_page | |
Summary | Get the latest price of instruments via web-sockets from zerodha |
upload_time | 2023-03-22 17:24:51 |
maintainer | |
docs_url | None |
author | |
requires_python | >=3.9 |
license | |
keywords |
zerodha
websockets
ltp
tick
nfo
options
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# Zerodha WebSocket Ticker Saver
<h2 align="center">
<a href="https://httpie.io" target="blank_">
<img height="100" alt="Ticker Saver" src="https://github.com/simonmh2u/TickerSaver/blob/main/docs/logo.png?raw=true" />
</a>
<br>
Free web-socket wrapper client for Zerodha Trading platform
</h2>
# What
TickerSaver is a web-socket wrapper client for Zerodha trading platform which can listen to the Zerodha web-socket stream for any stock or index instruments on the Trading platform and saves the current price of the instrument in sqlite database.
Any backend Live Trading Algo program can now use this live tick current price data by reading from the sql-lite database which is continuously getting updated by the TickerSaver application.
**It does this all free without the 2000 INR monthly cost that Zerodha charges for WebSocket live tick data.**
# Install
# How
- User needs to have a valid account on Zerodha Trading platform - Kite
- User will need log into the Kite Web on any browser and copy the user token and username from the browser and provide it to the TickerSaver application
- TickerSaver will now connect to your account and connect to Zerodha WebSocket server to get live tick data for any subscribed instruments
- It will save the current price of all subscribed instruments in a sql-lite database which can then be used by any of your applications like Live Trading bots to get the current live price from this sql-lite db which is constantly getting updated
# Features
- Costs 0 rupees to get live tick data
- Saves the current price of all subscribed instruments in sql-lite database which can be used by live trading bots
- At startup it can subscribe to get and save the current price of all instruments showing up in the current positions in Zerodha account based on config ```subscribe_current_positions```.
- Can dynamically subscribe to new instruments when the application is already running by adding the Zerodha instrument_id , tradingsymbol in the ```conf/ticker_instruments.csv``` file For example: ```12628226,BANKNIFTY22N0339500PE```
- When new positions are taken in Zerodha account after application startup and if they need to be subscribed to dynamically then just create a file ```touch instrument_touch.txt``` which will load all current positions from Zerodha account and subscribe to them and start saving the current price .
# Usage
### Installation
- Install the package
``` pip install zerodha_tickersaver```
OR
- Download the source
```git clone https://github.com/simonmh2u/TickerSaver.git```
### Config file
- Takes as an input a json config file
- dbpath : absolute path of the sqlite file where it needs to be created
- tickerfile_path: absolute path of the csv file which stores the instrument file that are subscribed by the application
- subscribe_current_positions : If true reads the current positions in the users zerodha account and subscribes to those instruments to get the current price
- default_instruments: list of zerodha instruments that will get subscribed to by default even if not present in the tickerfile csv
- zusername: userid copied from browser
- zwsstoken: token copied from the browser
```
{
"dbpath": "/Users/johnwick/ticker_instruments.csv/live_price.db",
"tickerfile_path": "/Users/johnwick/ticker_instruments.csv",
"subscribe_current_positions": true,
"default_instruments": [
256265,
264969,
260105
],
"zusername":"",
"zwsstoken":""
}
```
### Startup Steps
- User needs to manually login into Kite on any browser , and copy the below token and user from the Cookie section of the developer console.
<a href="https://httpie.io" target="blank_">
<img height="100" alt="Ticker Saver" src="https://github.com/simonmh2u/TickerSaver/blob/main/docs/cookie.png?raw=true" />
</a>
<br>
- Needs to set the username and token as environment variables "ZUSERNAME" and "ZWSSTOKEN" respectively
- Needs to add "zusername" and "zwsstoken" configs in the user supplied config file path(this overrides the above env variables)
``` { "zusername":"YL1111", "zwsstoken":"XXXXXXX" } ```
- Fire up the application
- ```tickersaver -c config.json``` (when package installed)
- ``` python tickersaver/fetcher/kite/ws_tick_fetcher.py -c config.json``` (when source downloaded)
# Disclaimer
TickerSaver is an application built for self learning and as a Jugaad *(definition: a resourceful approach to problem-solving)* to understand the working of web-sockets and to see if the live tick data from zerodha can be extracted and saved locally tick by tick for free without paying for monthly charges for API access. Please use at your own discretion.
Raw data
{
"_id": null,
"home_page": "",
"name": "zerodha-tickersaver",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": "",
"keywords": "zerodha,websockets,ltp,tick,nfo,options",
"author": "",
"author_email": "Simon <simonmh2u@gmail.com>",
"download_url": "https://files.pythonhosted.org/packages/d5/d2/3cae154794ced87db42e590d59ffe15190f5d0762c2a0c618c2295a2222f/zerodha_tickersaver-1.1.2.tar.gz",
"platform": null,
"description": "\n# Zerodha WebSocket Ticker Saver \n \n<h2 align=\"center\"> \n <a href=\"https://httpie.io\" target=\"blank_\"> \n <img height=\"100\" alt=\"Ticker Saver\" src=\"https://github.com/simonmh2u/TickerSaver/blob/main/docs/logo.png?raw=true\" /> \n </a> \n <br> \n Free web-socket wrapper client for Zerodha Trading platform \n</h2> \n \n# What \n \nTickerSaver is a web-socket wrapper client for Zerodha trading platform which can listen to the Zerodha web-socket stream for any stock or index instruments on the Trading platform and saves the current price of the instrument in sqlite database. \nAny backend Live Trading Algo program can now use this live tick current price data by reading from the sql-lite database which is continuously getting updated by the TickerSaver application. \n**It does this all free without the 2000 INR monthly cost that Zerodha charges for WebSocket live tick data.** \n \n# Install \n \n \n# How \n \n- User needs to have a valid account on Zerodha Trading platform - Kite \n- User will need log into the Kite Web on any browser and copy the user token and username from the browser and provide it to the TickerSaver application \n- TickerSaver will now connect to your account and connect to Zerodha WebSocket server to get live tick data for any subscribed instruments \n- It will save the current price of all subscribed instruments in a sql-lite database which can then be used by any of your applications like Live Trading bots to get the current live price from this sql-lite db which is constantly getting updated \n \n \n# Features \n- Costs 0 rupees to get live tick data \n- Saves the current price of all subscribed instruments in sql-lite database which can be used by live trading bots \n- At startup it can subscribe to get and save the current price of all instruments showing up in the current positions in Zerodha account based on config ```subscribe_current_positions```. \n- Can dynamically subscribe to new instruments when the application is already running by adding the Zerodha instrument_id , tradingsymbol in the ```conf/ticker_instruments.csv``` file For example: ```12628226,BANKNIFTY22N0339500PE``` \n- When new positions are taken in Zerodha account after application startup and if they need to be subscribed to dynamically then just create a file ```touch instrument_touch.txt``` which will load all current positions from Zerodha account and subscribe to them and start saving the current price . \n \n# Usage \n### Installation \n- Install the package \n\t ``` pip install zerodha_tickersaver``` \n\nOR\n\n- Download the source\n```git clone https://github.com/simonmh2u/TickerSaver.git```\n\n \n### Config file \n- Takes as an input a json config file\n- dbpath : absolute path of the sqlite file where it needs to be created\n- tickerfile_path: absolute path of the csv file which stores the instrument file that are subscribed by the application\n- subscribe_current_positions : If true reads the current positions in the users zerodha account and subscribes to those instruments to get the current price\n- default_instruments: list of zerodha instruments that will get subscribed to by default even if not present in the tickerfile csv\n- zusername: userid copied from browser\n- zwsstoken: token copied from the browser\n``` \n{ \n \"dbpath\": \"/Users/johnwick/ticker_instruments.csv/live_price.db\", \n \"tickerfile_path\": \"/Users/johnwick/ticker_instruments.csv\", \n \"subscribe_current_positions\": true, \n \"default_instruments\": [ \n 256265, \n 264969, \n 260105 \n ],\n \"zusername\":\"\",\n \"zwsstoken\":\"\"\n } \n``` \n \n### Startup Steps \n- User needs to manually login into Kite on any browser , and copy the below token and user from the Cookie section of the developer console. \n\n <a href=\"https://httpie.io\" target=\"blank_\"> \n <img height=\"100\" alt=\"Ticker Saver\" src=\"https://github.com/simonmh2u/TickerSaver/blob/main/docs/cookie.png?raw=true\" /> \n </a> \n <br> \n \n- Needs to set the username and token as environment variables \"ZUSERNAME\" and \"ZWSSTOKEN\" respectively \n- Needs to add \"zusername\" and \"zwsstoken\" configs in the user supplied config file path(this overrides the above env variables) \n ``` { \"zusername\":\"YL1111\", \"zwsstoken\":\"XXXXXXX\" } ```\n- Fire up the application\n\n - ```tickersaver -c config.json``` (when package installed)\n\n - ``` python tickersaver/fetcher/kite/ws_tick_fetcher.py -c config.json``` (when source downloaded)\n\n\n# Disclaimer \nTickerSaver is an application built for self learning and as a Jugaad *(definition: a resourceful approach to problem-solving)* to understand the working of web-sockets and to see if the live tick data from zerodha can be extracted and saved locally tick by tick for free without paying for monthly charges for API access. Please use at your own discretion.\n",
"bugtrack_url": null,
"license": "",
"summary": "Get the latest price of instruments via web-sockets from zerodha",
"version": "1.1.2",
"split_keywords": [
"zerodha",
"websockets",
"ltp",
"tick",
"nfo",
"options"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "eed4aca09a4da1c720ab04f428bf31aeb2c586cf7c33c2499cd76f0395276373",
"md5": "c0ed520d8032dc027920e0198872523b",
"sha256": "ac792533d51c79b3219563a8e01b70633ea78ea3a7068562172acb756d767b70"
},
"downloads": -1,
"filename": "zerodha_tickersaver-1.1.2-py3-none-any.whl",
"has_sig": false,
"md5_digest": "c0ed520d8032dc027920e0198872523b",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.9",
"size": 9843,
"upload_time": "2023-03-22T17:24:49",
"upload_time_iso_8601": "2023-03-22T17:24:49.533828Z",
"url": "https://files.pythonhosted.org/packages/ee/d4/aca09a4da1c720ab04f428bf31aeb2c586cf7c33c2499cd76f0395276373/zerodha_tickersaver-1.1.2-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "d5d23cae154794ced87db42e590d59ffe15190f5d0762c2a0c618c2295a2222f",
"md5": "b73bce3e302accff97266b9ffe11473c",
"sha256": "78a1f50bf95c54e50e481ff28c219e63c02e71948d88e39b8118d1c7b5b0481f"
},
"downloads": -1,
"filename": "zerodha_tickersaver-1.1.2.tar.gz",
"has_sig": false,
"md5_digest": "b73bce3e302accff97266b9ffe11473c",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 10439,
"upload_time": "2023-03-22T17:24:51",
"upload_time_iso_8601": "2023-03-22T17:24:51.303017Z",
"url": "https://files.pythonhosted.org/packages/d5/d2/3cae154794ced87db42e590d59ffe15190f5d0762c2a0c618c2295a2222f/zerodha_tickersaver-1.1.2.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-03-22 17:24:51",
"github": false,
"gitlab": false,
"bitbucket": false,
"lcname": "zerodha-tickersaver"
}