Drop invalid status msg, linting cleanups
							parent
							
								
									c034ea742f
								
							
						
					
					
						commit
						88306a6c1e
					
				|  | @ -124,11 +124,11 @@ class Trade(BaseModel): | |||
|     Trade class that helps parse and validate ownTrades stream | ||||
| 
 | ||||
|     ''' | ||||
|     reqid: str # kraken order transaction id | ||||
|     action: str # buy or sell | ||||
|     price: str # price of asset | ||||
|     size: str # vol of asset | ||||
|     broker_time: str # e.g GTC, GTD | ||||
|     reqid: str  # kraken order transaction id | ||||
|     action: str  # buy or sell | ||||
|     price: str  # price of asset | ||||
|     size: str  # vol of asset | ||||
|     broker_time: str  # e.g GTC, GTD | ||||
| 
 | ||||
| 
 | ||||
| @dataclass | ||||
|  | @ -446,7 +446,6 @@ class Client: | |||
|             raise SymbolNotFound(json['error'][0] + f': {symbol}') | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @asynccontextmanager | ||||
| async def get_client() -> Client: | ||||
| 
 | ||||
|  | @ -578,7 +577,9 @@ async def handle_order_requests( | |||
| 
 | ||||
|             err = resp['error'] | ||||
|             if err: | ||||
|                 log.error(f'Failed to submit order') | ||||
|                 oid = order.oid | ||||
|                 log.error(f'Failed to submit order: {oid}') | ||||
| 
 | ||||
|                 await ems_order_stream.send( | ||||
|                     BrokerdError( | ||||
|                         oid=order.oid, | ||||
|  | @ -616,42 +617,41 @@ async def handle_order_requests( | |||
|                 reqid=msg.reqid | ||||
|             ) | ||||
| 
 | ||||
|             try: | ||||
|                 # Check to make sure there was no error returned by | ||||
|                 # the kraken endpoint. Assert one order was cancelled | ||||
|                 assert resp['error'] == [] | ||||
|                 assert resp['result']['count'] == 1 | ||||
|             # Check to make sure there was no error returned by | ||||
|             # the kraken endpoint. Assert one order was cancelled | ||||
|             assert resp['error'] == [] | ||||
|             assert resp['result']['count'] == 1 | ||||
| 
 | ||||
|             # Check to make sure the cancellation is NOT pending, | ||||
|             # then send the confirmation to the ems order stream | ||||
|             pending = resp['result'].get('pending') | ||||
|             if pending: | ||||
| 
 | ||||
|                 oid = order.oid | ||||
|                 log.error(f'Order {oid} cancel was not successful') | ||||
| 
 | ||||
|                 # TODO: Change this code using .get | ||||
|                 try: | ||||
|                     pending = resp['result']['pending'] | ||||
|                 # Check to make sure the cancellation is NOT pending, | ||||
|                 # then send the confirmation to the ems order stream | ||||
|                 except KeyError: | ||||
|                     await ems_order_stream.send( | ||||
|                         BrokerdStatus( | ||||
|                             reqid=msg.reqid, | ||||
|                             account=msg.account, | ||||
|                             time_ns=time.time_ns(), | ||||
|                             status='cancelled', | ||||
|                             reason='Order cancelled', | ||||
|                             broker_details={'name': 'kraken'} | ||||
|                         ).dict() | ||||
|                     ) | ||||
|             except AssertionError: | ||||
|                 log.error(f'Order cancel was not successful') | ||||
|                 await ems_order_stream.send( | ||||
|                     BrokerdError( | ||||
|                         oid=order.oid, | ||||
|                         oid=oid, | ||||
|                         reqid=temp_id, | ||||
|                         symbol=order.symbol, | ||||
|                         reason="Failed order cancel", | ||||
|                         broker_details=resp | ||||
|                     ).dict() | ||||
|                 ) | ||||
| 
 | ||||
|         else: | ||||
|             log.error(f'Unknown order command: {request_msg}') | ||||
|             else: | ||||
|                 await ems_order_stream.send( | ||||
|                     BrokerdStatus( | ||||
|                         reqid=msg.reqid, | ||||
|                         account=msg.account, | ||||
|                         time_ns=time.time_ns(), | ||||
|                         status='cancelled', | ||||
|                         reason='Order cancelled', | ||||
|                         broker_details={'name': 'kraken'} | ||||
|                     ).dict() | ||||
|                 ) | ||||
|     else: | ||||
|         log.error(f'Unknown order command: {request_msg}') | ||||
| 
 | ||||
| 
 | ||||
| @tractor.context | ||||
|  | @ -694,7 +694,7 @@ async def trades_dialogue( | |||
|     async with get_client() as client: | ||||
|         if not client._api_key: | ||||
|             log.error('Missing Kraken API key: Trades WS connection failed') | ||||
|             await ctx.started(({}, {'paper',})) | ||||
|             await ctx.started(({}, ['paper'])) | ||||
| 
 | ||||
|             async with ( | ||||
|                 ctx.open_stream() as ems_stream, | ||||
|  | @ -713,7 +713,7 @@ async def trades_dialogue( | |||
|                     _positions={}, | ||||
|                 ) | ||||
| 
 | ||||
|                 ## TODO: maybe add multiple accounts | ||||
|                 # TODO: maybe add multiple accounts | ||||
|                 n.start_soon(handle_order_requests, client, ems_stream) | ||||
| 
 | ||||
|         acc_name = 'kraken.' + client._name | ||||
|  | @ -724,7 +724,7 @@ async def trades_dialogue( | |||
|         await ctx.started((position_msgs, (acc_name,))) | ||||
| 
 | ||||
|         # Get websocket token for authenticated data stream | ||||
|         # Assert that a token was actually received  | ||||
|         # Assert that a token was actually received. | ||||
|         resp = await client.endpoint('GetWebSocketsToken', {}) | ||||
|         assert resp['error'] == [] | ||||
|         token = resp['result']['token'] | ||||
|  | @ -733,7 +733,7 @@ async def trades_dialogue( | |||
|             ctx.open_stream() as ems_stream, | ||||
|             trio.open_nursery() as n, | ||||
|         ): | ||||
|             ## TODO: maybe add multiple accounts | ||||
|             # TODO: maybe add multiple accounts | ||||
|             n.start_soon(handle_order_requests, client, ems_stream) | ||||
| 
 | ||||
|             # Process trades msg stream of ws | ||||
|  | @ -746,24 +746,8 @@ async def trades_dialogue( | |||
|                     for trade in msg: | ||||
|                         # check the type of packaged message | ||||
|                         assert type(trade) == Trade | ||||
|                         # prepare and send a status update for line update | ||||
|                         trade_msg = BrokerdStatus( | ||||
|                             reqid=trade.reqid, | ||||
|                             time_ns=time.time_ns(), | ||||
| 
 | ||||
|                             account='kraken.spot', | ||||
|                             status='executed', | ||||
|                             filled=float(trade.size), | ||||
|                             reason='Order filled by kraken', | ||||
|                             # remaining='' # TODO: not sure what to do here. | ||||
|                             broker_details={ | ||||
|                                 'name': 'kraken', | ||||
|                                 'broker_time': trade.broker_time | ||||
|                             } | ||||
|                         ) | ||||
|                          | ||||
|                         await ems_stream.send(trade_msg.dict()) | ||||
| 
 | ||||
|                         # prepare and send a filled status update | ||||
|                         filled_msg = BrokerdStatus( | ||||
|                             reqid=trade.reqid, | ||||
|                             time_ns=time.time_ns(), | ||||
|  | @ -772,11 +756,19 @@ async def trades_dialogue( | |||
|                             status='filled', | ||||
|                             filled=float(trade.size), | ||||
|                             reason='Order filled by kraken', | ||||
|                             # remaining='' # TODO: not sure what to do here. | ||||
|                             broker_details={ | ||||
|                                 'name': 'kraken', | ||||
|                                 'broker_time': trade.broker_time | ||||
|                             } | ||||
|                             }, | ||||
| 
 | ||||
|                             # TODO: figure out if kraken gives a count | ||||
|                             # of how many units of underlying were | ||||
|                             # filled. Alternatively we can decrement | ||||
|                             # this value ourselves by associating and | ||||
|                             # calcing from the diff with the original | ||||
|                             # client-side request, see: | ||||
|                             # https://github.com/pikers/piker/issues/296 | ||||
|                             remaining=0, | ||||
|                         ) | ||||
| 
 | ||||
|                         await ems_stream.send(filled_msg.dict()) | ||||
|  | @ -899,10 +891,10 @@ async def process_trade_msgs( | |||
|     async for msg in stream_messages(ws): | ||||
| 
 | ||||
|         try: | ||||
|             # check that we are on the ownTrades stream and that msgs are  | ||||
|             # arriving in sequence with kraken | ||||
|             # For clarification the kraken ws api docs for this stream:  | ||||
|             #   https://docs.kraken.com/websockets/#message-ownTrades | ||||
|             # check that we are on the ownTrades stream and that msgs | ||||
|             # are arriving in sequence with kraken For clarification the | ||||
|             # kraken ws api docs for this stream: | ||||
|             # https://docs.kraken.com/websockets/#message-ownTrades | ||||
|             assert msg[1] == 'ownTrades' | ||||
|             assert msg[2]['sequence'] > sequence_counter | ||||
|             sequence_counter += 1 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue