I am implementing the websocket client from scratch. After the successful connection, and subscribe that returns no errors , the callback function only returns the heartbeat binary data and nothing else. I also have a python websocket client running in parallel to check if the ticks are being generated for that particular instrument token. The python client websocket returns valid ticks but my client only returns heartbeats. Is there any step that I am missing and must know.
You get error messages in the text format. You need to listen to text messages to know the error. You might be sending a wrong subscribe message to the Kite Ticker.
Earlier I had received messages about “unable to parse instrument tokens” etc as text message and I fixed them.
Now i have no reference as to why I do not receive any ticks-no text message or otherwise.
Is there a way to verify at the backend using logs what may be the issue with the payload ? I have no more information to proceed further from my side.
Here's the output from my program. It gets connected. The subscribe and mode messages are successfully sent with no text message callback. Later, only the heartbeats follow but no ticks.
connected! {"a":"subscribe","v":[738561]} buffer size: 0 Successfully sent the subscribe message! Successfully sent the mode message! {"a":"mode","v":["full"[738561]]} buffer size: 0 buffer size: 0 buffer size: 0 buffer size: 0 buffer size: 0
@sujith Any pointer to what could be the possible cause for this issue would be helpful. The subscribe and mode messages seems to be alright and I do not get a text message back from the websocket. I am implementing a C++ client. Do you have any reference implementation for the same?
@sujith I have written that comment in code and I am the author of the code itself. So, I know what I am doing ! Do you see an if condition before that checks for buffer size. I receive a binary buffer of zero bytes from the web socket. If you are receiving zero bytes there’s no point of parsing that ( that’s why u see the comment there)
The point here is that the websocket fails silently without any valid error. This seems like some validation in kite api is not handled properly. May be a corner case, but I am hitting it. So, it may be worthwhile for you to investigate.
Hi, If you follow the documentation, the length of the message can be obtained with msg.length(). Also, streambuf isn't really required to read the message body. You can read the from msg.body() directly, like so:
The bitswaps are done because we stream BigEndian whereas libcpprest assumes LittleEndian (atleast on my system: x86_64 GNU/Linux).
With the above tweaks and some cleanups, I was able to parse packets successfully.
Also, if you want people to help you, you should post a working, complete example. The file you provided has no header includes, no proper namespace conventions, no build steps and you didn't even bother mentioning which websocket library you are using.
@nikhilR Thank you for your help. I tested after applying the above tweaks for BigEndian and it worked. Now, I could move on to the next steps. For windows platform, with visual studio C++ compiler, I used _byteswap_ushort:
You might be sending a wrong subscribe message to the Kite Ticker.
Now i have no reference as to why I do not receive any ticks-no text message or otherwise.
Is there a way to verify at the backend using logs what may be the issue with the payload ? I have no more information to proceed further from my side.
connected!
{"a":"subscribe","v":[738561]}
buffer size: 0
Successfully sent the subscribe message!
Successfully sent the mode message! {"a":"mode","v":["full"[738561]]}
buffer size: 0
buffer size: 0
buffer size: 0
buffer size: 0
buffer size: 0
https://github.com/web3ninja/test_kite_ws/blob/master/kite_ws.c
If you follow the documentation, the length of the message can be obtained with
msg.length().Also,
streambufisn't really required to read the message body.You can read the from
msg.body()directly, like so: The bitswaps are done because we stream BigEndian whereas libcpprest assumes LittleEndian (atleast on my system:x86_64 GNU/Linux).With the above tweaks and some cleanups, I was able to parse packets successfully.
Also, if you want people to help you, you should post a working, complete example. The file you provided has no header includes, no proper namespace conventions, no build steps and you didn't even bother mentioning which websocket library you are using.
For windows platform, with visual studio C++ compiler, I used _byteswap_ushort: