@sujith I have been using this method for long, fetching order history after getting the order_id, but I have never seen such a "success" in any status updates; that's why I wanted to ensure where it is coming from. Do you have any sample approach?
@sujith I have been getting only the order_id, not getting like this as a success message:
{
"status": "success",
"data": {
"order_id": "151220000000000"
}
}
How to get this status JSON message? I have tried exceptions and debu…
@Sujith I am not using WS order updates for my specific use case, so I just want to retrieve order history for one order_id, not the entire list of orders. So I hope this approach is efficient, as I am not fetching the entire list of orders in the o…
@sujith
I didn't get you. Can you elaborate?
Out of order/async status updates in WS on_order_updates, so I wanted to know that the polling order updates are out of order like on_order_updates.
orderstatus = order_history[-1]['status']
If fetchin…
@sujith I have not tried polling for order updates; WS is out of order, so polling is also out of order?
eg: If we use this approach, history[-1]['status'], will I get the latest order status in an exact order?
@kauphylover I don't think that it will be added to the API logic. The core reason is that Kite Connect is purely an execution platform, and it doesn't provide strategy or any logic that is related to the client's strategy.
Your logic is easy to do…
Brokers already collect IPs for orders as part of reporting requirements. However, there (are) were people out there who end up sharing their login and API credentials with others who then trade on their behalf. This was basically like a pseudo-PMS …
Only thing that changes is API users will have to acquire a static IP if they don't already have one and get it whitelisted with broker.
@Matti I don't get the logic. Why does the regulator need the user's IP address if he doesn't want to place an …
@QF8157 I will explain it very simply. It seems you are a beginner in this domain and want to do algo trading, do not have coding skills?
The reality is no one shares their working ideas, or even if it works, it has a 40% success rate or below. If…
I mean there is a time delay for order placement averaging 80-150 ms, so once I placed the order, then modified the order parameters, what is the time delay between this process within Zerodha, RMS, and OMS validations? Will each order modification …
Check the instrument dump file for the correct symbol and instrument token, and then check the price details.
Download the dump file: Instrument dump file
@Dileep Not Micorseconds , it is milliseconds
Here are some issues that I observed:
1. who will include the microseconds to the "timestamp" parameter? whether the Exchange or the Zerodha(broker).
I don't know the format of tick data they are getti…
@Dileep Each tick has volume, so the issue arises when the two ticks with the same timestamp will create an out-of-order issue, so only the possible way from their end is to simply include milliseconds so each tick will be unique as milliseconds are…
@Dileep am also facing same issue. I am using API quotes.
Quote API is just a snap of WS, so whatever ticks you are getting is solely based on the WS stream service.
@rakeshr @sujith Please consider including milleseconds in the exchange timestamp so it will avoid these out-of-order issues. All other data providers (paid or free) have this feature, or they will pass the ticks only if they have sorted the ticks's…
I just checked ticks log for the mentioned instrument and timestamp.
The log time and streaming tick time are the same in your system? or after streaming the ticks, then it stores and sorts the time in the logs?
@rakeshr I have checked with TrueData ticks. I am using both Kite and Truedata, the same code I am using with Truedata, and I have been checking for 1 hour, and I am sure I am not getting volume-decreasing issues with Truedata.
I am converting to …
@ketansp I have been able to achieve 5ms benchmark for 9000 instruments by doing all the processing in application memory.
What programming language are you using? I am using Python. 5 ms is very good, but there are some other issues that may affect…
@TradeTastic I would say 9K is a fantasy count. Actual liquidity/active tradable instruments are very very less than 1K, say 500 instruments. 9K is actually for who makes a candle chart or for doing complete market analysis for companies like broki…
@ketansp What I stated was the performance difference between Postgres and Redis. As said earlier, "the right tool in the right context." I don't need 9K instruments; even if I have just 10 instruments, that's enough, so in my case, Redis is better …
To conclude: in memory DB for critical operations, disk based DB for non critical operations. Selecting SQL or NOSQL is purely subjective.
Postgres is not good for critical operations, which are disk based. You must consider any in memory database f…
The normal naming convention is not like BANKNIFTY24J1651000PE; it is like BANKNIFTY2471651000PE and BANKNIFTY25MAR48000PE but from October onwards they changed to the month first letter instead of the month number. For March, it is like BANKNIFTY25…
I am sure nobody will answer properly regarding your query. liquidity is a variable, it depends upon the strategy or methodology each person has. Nobody can really find the liquidity; this is the ultimate truth that I hardly understood long ago. I a…
There is no July contract ready in the exchange, so it will not be available in the kite instrument csv dump file as well.
for more deatils you can go through csv file: Here
I have a couple of ML logics that I have developed for long term purposes. I am specializing in LFT, so it really does not work, so not using it right now.
Have been able to achieve profitability without brokerage and transaction costs
Whatever you…
@ketansp Well, if you just want to store and sort tick data, then 1 GB of RAM with i5 or base variant processor is sufficient, but if you want to do many critical operations and heavy computing, then you should have high end. Why do we need to store…
According to your logic, 3 scripts are running synchronously, so your three programmes will call the quote API three times per second or at the same time. This may lead to hit rate limit. 1 r/s per app. If you setup multiple apps, this won't be an i…
@pd_DataFrame The terminology Tick by tick data and tick data are different, Go through: TBT data
To mitigate this, I am considering subscribing to Zerodha's APIs as a backup for tick-by-tick data for all NSE equities.
Zerodha only provides tick da…
I cant understand why you put kws.stop() , kws.conect() inside on_ticks() ?
Don't put any tick calculations inside on_ticks() it will block your ticks if you do that.
try this:
def on_close(ws, code, reason):
ws.stop()
Include this threa…
You can call any trading instrument through loops following with API limits. It does not matter how many numbers of instruments you call; whatever you do should be within the API limit.
Go through: API Limit & FAQ & Kite API Docs
Kite API doesn't provide instant option chain data; Kite provides only WS connections with Rest API service to get basic parameters. To get option chain data, you have to build it at your end with a WS connection. Go through: FAQ
You can also depen…
Hey,
One thing I missed to mention is that the charge of 4K + GST per month is for only 1 websocket connection, and you can't open multiple WS connections like Kite API. This charge is only for 1 WS + 50 tokens without REST API.
You can't use the…
What about option premium? As far as I know, Premium wouldn't remain the same for the whole day as the Spot price.
Option premium will change, and spot price will also change if it is tradable. If premium changes, all other parameters will also chan…
Kite provides historical data for trading options and equity; you may check with other NSE data vendors for expired data. I think it is a very expensive and inappropriate approach to subscribe to other data vendors for historical data. For just 50 t…
KIte API does not provide expired option data, go through: Historical candle data , Thread
The possible way is to setup a WS connection, store tick data in any database, and create a candle for the required time frames. you have to do at you end.
KIte API doesn't provide those data in a single call you have to make at your end.
You can fetch from instrument dump file : Strike Price, Spot Price, Expiry Date
All the other data that you need to develop
Most beginners, or those who are unfamiliar with coding or APIs, will accuse Zerodha of hiding their egos and refuse to acknowledge that they are taking the wrong approach. That is the most common behaviour of humans.
How come you so sure about it? …
@rajdkumar
Choosing good DB,
I want to say that the right tool in the right context. You can use any database, but make sure that you choose the right one for your logic. you can use any open source DB SQL and NOSQL
If you want to do critical ope…
When posting a thread, you forgot to specify the actual problem. At its core, this forum is for developers who are familiar with APIs and algorithmic trading. Kite API does not provide code rewriting code or assistance in developing a strategy or lo…
If you use the API for order placement and the limit is exceeded, you will get an order placement error, which is listed in the exceptions and errors. Check common HTTP error codes and exception types. Read the documentation carefully.
Using the exception method, when your API limit exceeds it will hit the exception with 429: Too many requests to the API (rate limiting)
Go through : Exceptions and Errors
You can get API limits by doing different approaches so that you can avoid …
Yes, the KIte API provides live tick data and not tick-by-tick data that you need to set up a colocation in NSE.
Kite API provides snapshot tick data through websocket streaming; you can fetch and process live tick data through any efficient DB. On…
@ansubur
What should I consider from your quiet response?
I am not a part of Zerodha. I am an independent Python Algo developer. I am helping people who are stuck to start or helping people to solve their logic issues as much as I possibly can. I w…
Go through this thread: Here
If you require multi-login functionality, Zerodha cannot provide it unless you have mass production but you can overcome this by using different efficient approaches. It requires only your coding skills and the right lo…
@ansubur
he live market feed is updating very slowly. Updating just once in every 10 seconds.
This is happening in particularly in NSE Index segment data only.
1. Did you check with another instrument ? And what time period did you get delayed?
2. …
Yes, Postback is also an option but the Kite team says: For individual developers, Postbacks over WebSocket is recommended, where, orders placed for a particular user anywhere, for instance, web, mobile, or desktop platforms, are sent.
So using WS …
Two approach,
1. WS on_order_update, To listen for order updates, you must write your own logic.
2. Polling API for order status
Kite team doesn't suggest polling the order status; a better approach is to listen to the on_order_update efficie…
You may not understand the logic of the iceberg order. You can slice one order into multiple orders with small quantities. This is helpful when you have large orders and slowly place them one by one. This helps reduce the impact cost of execution in…
As per your query, you want to place basket orders, not iceberg orders. A basket order means that you can place multiple orders at the same time. Iceberg orders are different. Kite API does not have a basket order API, so you can't place it via API,…
Basket orders are not available on Kite API. check this thread: Thread
Basket margins API is available Here , You can check basket margins with available margin in your account. Create a list or order queue to place multiple orders. You can pl…
I checked again, For 100 tokens they are charging 4400 + GST. This should be either FNO or EQ. Kite Connect is scalable and low-cost, but those who need less latency can try GDFL.
@kakush30 You can use both GDFL and KIte API.
If you use the KIte API for order placement and GDFL for ticks, then the issue is solved, but it costs more. If you get a good trading income, then it's okay to manage.
@kakush30 Latency is the main issue. The stability of the Kite Connect API is good, but there are some narrow range opportunities for sub minute scalping with the Kite Connect API that we need to dig deep.
There are other data vendors that provide …
@rohanrg What I learned from my experience is that we can't exactly find liquidity because it will generate and vanish in milliseconds or seconds. Most liquidity providers are HFT, and they are market makers. As a retailers, we have many limitation…
@sujith It would be better to close this thread. I have decided to tweak my logic rather than the Kite Connect logic. You could have answered the question about whether it is possible or not.
@tradernoob I had used the TrueData Velocity feature but not the API service, but it is widely used and I am not sure about the latency.
The main problem I am facing is that I am working on a trading strategy that needs the current issue to be solv…
@tradernoob I have read all of your threads before in Q&A. If you are a pure seconds based trader and want to scale up, I think the current issues will kill your strategy.
PS: I look up to Zerodha as the leading stock broker in the API space. An…
@sujith @rakeshr @themohammedfaisal
If there is a few millisecond discrepancy in the timestamp between the current and exchange timestamps, it is acceptable and normal for retailer trading.
Please include milliseconds for all timestamps, as now…
1 second delay will not be a big issue for traders with strategies more than 10 minutes, but this delay will kill traders who trade in seconds.
@tradernoob I am wondering why no one raised this as a serious issue, though a lot of people use the Kit…
+ I don't see any clock drift issues:
Local time: Sat 2024-05-18 11:35:16 IST
Universal time: Sat 2024-05-18 06:05:16 UTC
RTC time: Sat 2024-05-18 06:05:17
Time zone: Asia/Kolkata (IST, +0530)
System clock synchronized: yes
NTP service: active
R…
@themohammedfaisal Yes Agreed. LTT will vary depending on the instrument's liquidity. The current delay is beyond that; the current time and exchange timestamp should match, right? I have checked many times and tested with simple dummy code for time…
Any help would be appreciated. created this thread yesterday. I have been paying KiteConnect for years. I can't take a trade due to this issue.
tick time mismatch:
some ticks have same time:
Today I noticed the same issue. I just added up the exchange timestamp, and it is 1 second below the ticks I am receiving. Some ticks show on time; both the current time in my system and the exchange timestamp are equal.
To sum up, I have noticed some instruments time differences are high, like a difference of 5 seconds or more.
Is this definitely because of the last traded time of illiquid or far OTM instruments?
The last traded time will print when there is a las…
Why do you need an independent program to get on_order_update? You can consume the same in either of those existing ws connections.
The entire order handling program is considered a separate program.
Currently, I am running three subscription programs with the on_order_update program. Is this because of legacy reasons? Any exception for on_order_update in future?
Yes. You can use WebSocket to get order updates. It is not like polling using kite.positions()
You can use on_order_update() and it is an event driven asyncrounous call. You will get order updates as updates are out of order. you have to do at your …