Final Order status

Shabari
Hi,

How can I get the last update on the order. I'm trying to place a SL/Target order after checking the status of previous buy order. When I use below code to check the status after 20sec delay.
time.sleep(20)
print(oid)
order_history = kite.order_history(oid)
print(order_history)
order_status = pd.DataFrame(order_history)
order_status = order_status['status'].iloc[0]
print("Order Status:", order_status)

getting below list of all the status stages start from 'order received' till 'completed. and order_status is picking initial status only.

[{'account_id': 'XXXXX', 'placed_by': 'XXXXX', 'order_id': '241216000712759', 'exchange_order_id': None, 'parent_order_id': None, 'status': 'PUT ORDER REQ RECEIVED', 'status_message': None, 'status_message_raw': None, 'order_timestamp': datetime.datetime(2024, 12, 16, 10, 39), 'exchange_update_timestamp': None, 'exchange_timestamp': None, 'variety': 'regular', 'modified': False, 'exchange': 'NFO', 'tradingsymbol': 'NIFTY24D1924750CE', 'instrument_token': 12139778, 'order_type': 'LIMIT', 'transaction_type': 'BUY', 'validity': 'IOC', 'validity_ttl': 0, 'product': 'MIS', 'quantity': 50, 'disclosed_quantity': 0, 'price': 139.55, 'trigger_price': 0, 'average_price': 0, 'filled_quantity': 0, 'pending_quantity': 50, 'cancelled_quantity': 0, 'market_protection': 0, 'meta': {}, 'tag': None, 'guid': '129062XQJwM3ZCs7rlI'}, {'account_id': 'XXXXX', 'placed_by': 'XXXXX', 'order_id': '241216000712759', 'exchange_order_id': None, 'parent_order_id': None, 'status': 'VALIDATION PENDING', 'status_message': None, 'status_message_raw': None, 'order_timestamp': datetime.datetime(2024, 12, 16, 10, 39), 'exchange_update_timestamp': None, 'exchange_timestamp': None, 'variety': 'regular', 'modified': False, 'exchange': 'NFO', 'tradingsymbol': 'NIFTY24D1924750CE', 'instrument_token': 12139778, 'order_type': 'LIMIT', 'transaction_type': 'BUY', 'validity': 'IOC', 'validity_ttl': 0, 'product': 'MIS', 'quantity': 50, 'disclosed_quantity': 0, 'price': 139.55, 'trigger_price': 0, 'average_price': 0, 'filled_quantity': 0, 'pending_quantity': 50, 'cancelled_quantity': 0, 'market_protection': 0, 'meta': {}, 'tag': None, 'guid': '129062XQJwM3ZCs7rlI'}, {'account_id': 'XXXXX', 'placed_by': 'XXXXX', 'order_id': '241216000712759', 'exchange_order_id': None, 'parent_order_id': None, 'status': 'OPEN PENDING', 'status_message': None, 'status_message_raw': None, 'order_timestamp': datetime.datetime(2024, 12, 16, 10, 39), 'exchange_update_timestamp': None, 'exchange_timestamp': None, 'variety': 'regular', 'modified': False, 'exchange': 'NFO', 'tradingsymbol': 'NIFTY24D1924750CE', 'instrument_token': 12139778, 'order_type': 'LIMIT', 'transaction_type': 'BUY', 'validity': 'IOC', 'validity_ttl': 0, 'product': 'MIS', 'quantity': 50, 'disclosed_quantity': 0, 'price': 139.55, 'trigger_price': 0, 'average_price': 0, 'filled_quantity': 0, 'pending_quantity': 50, 'cancelled_quantity': 0, 'market_protection': 0, 'meta': {}, 'tag': None, 'guid': '129062XQJwM3ZCs7rlI'}, {'account_id': 'XXXXX', 'placed_by': 'XXXXX', 'order_id': '241216000712759', 'exchange_order_id': '1300000060066380', 'parent_order_id': None, 'status': 'OPEN', 'status_message': None, 'status_message_raw': None, 'order_timestamp': datetime.datetime(2024, 12, 16, 10, 39), 'exchange_update_timestamp': '2024-12-16 10:39:00', 'exchange_timestamp': datetime.datetime(2024, 12, 16, 10, 39), 'variety': 'regular', 'modified': False, 'exchange': 'NFO', 'tradingsymbol': 'NIFTY24D1924750CE', 'instrument_token': 12139778, 'order_type': 'LIMIT', 'transaction_type': 'BUY', 'validity': 'IOC', 'validity_ttl': 0, 'product': 'MIS', 'quantity': 50, 'disclosed_quantity': 0, 'price': 139.55, 'trigger_price': 0, 'average_price': 0, 'filled_quantity': 0, 'pending_quantity': 50, 'cancelled_quantity': 0, 'market_protection': 0, 'meta': {}, 'tag': None, 'guid': '129062XQJwM3ZCs7rlI'}, {'account_id': 'XXXXX', 'placed_by': 'XXXXX', 'order_id': '241216000712759', 'exchange_order_id': '1300000060066380', 'parent_order_id': None, 'status': 'COMPLETE', 'status_message': None, 'status_message_raw': None, 'order_timestamp': datetime.datetime(2024, 12, 16, 10, 39), 'exchange_update_timestamp': '2024-12-16 10:39:00', 'exchange_timestamp': datetime.datetime(2024, 12, 16, 10, 39), 'variety': 'regular', 'modified': False, 'exchange': 'NFO', 'tradingsymbol': 'NIFTY24D1924750CE', 'instrument_token': 12139778, 'order_type': 'LIMIT', 'transaction_type': 'BUY', 'validity': 'IOC', 'validity_ttl': 0, 'product': 'MIS', 'quantity': 50, 'disclosed_quantity': 0, 'price': 139.55, 'trigger_price': 0, 'average_price': 139.25, 'filled_quantity': 50, 'pending_quantity': 0, 'cancelled_quantity': 0, 'market_protection': 0, 'meta': {}, 'tag': None, 'guid': '129062XQJwM3ZCs7rlI'}]

Order Status: PUT ORDER REQ RECEIVED
  • psnbaba
    No need to convert to dataframe try this

    orderstatus = order_history[-1]['status']

    if this is COMPLETE then go ahead
  • sujith
    You seem to be fetching the order it history, it contains all the states the order has gone through in the system. For latest order status, you need to check the last item in the list. You may go through documentation to know more.
  • ANL
    @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?
  • sujith
    sujith edited January 10
    @ANL,
    @sujith I have not tried polling for order updates; WS is out of order, so polling is also out of order?
    I didn't get you. Can you elaborate?

    eg: If we use this approach, history[-1]['status'], will I get the latest order status in an exact order?
    Yes, the last item in the order history gives you the latest status of the order. You may also fetch orderbook and find by order_id and check the status.
  • ANL
    @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 fetching the order book and retrieving the last dict values are considered as the latest and in the exact order and no async like Ws on_order_update. I have noticed an out of order issue while polling order status today after 3 pm.

    1 . Is WS on_order_update faster than the conventional polling method? Or both are updating at the same time?
    2. Is there any possibility of having a flakeout while polling for order updates?
    3. Is it possible to depreciate the polling method in the future, as I am considering switching from WS order updates to conventional polling for certain use cases?
  • sujith
    The orderbook API is fetching list of orders, it is not fetching order history.

    The async order updates is because of the async notification behavior from OMS. But the order history will have all the states of the order that it has traversed through all the systems. The last item will be the latest status of the order. It is equal to fetching list of orders and checking the status of the order.

    The optimal solution is to fetch orders after you receive 200 status for placing an order and then look for the status for the order_id that you receive in place order response. And then fetch orders to check the latest status when you receive order_update from the Websocket API.
  • ANL
    @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 order book.
    The optimal solution is to fetch orders after you receive 200 status for placing an order and then look for the status for the order_id that you receive in place order response. And then fetch orders to check the latest status when you receive order_update from the Websocket API.
    You said the 200 response is ideal, so where can I find this as an example? The 200 status is a JSON, right? So, I need to log in with details or should I call it separately?
  • sujith
    I was referring to HTTP status code 200. For placing an order, you will receive an order_id in success response, you may use that and fetch order history as well.
    You can check out the response structure for place order API here.
  • ANL
    @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 debug, but I am not getting this format. Could you please provide some insight?
  • sujith
    You need to make another API call to order history endpoint using this order_id. You can check out the order history API documentation here.
  • ANL
    ANL edited January 14
    @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
    We don't consume that field in the client libraries. It is implicit that if the https status is 200 then required response is inside data field and if there is error then it is always in the following format.
    {
    "status": "error",
    "message": "Error message",
    "error_type": "GeneralException"
    }
    Hence, we directly look for message and error_type for non 200 https status code responses.
Sign In or Register to comment.