`binance`: facepalm, swap price/size_tick methods..

Wow not sure how that happened, but we should probably use the correct
market precision info for the correct parameter..

Also, use `@lru_cache` on new `get_mkt_info()` ep, seems to work?
rekt_pps
Tyler Goodlet 2023-04-16 17:55:44 -04:00
parent 10a39ca42c
commit 0d2e713e9a
1 changed files with 8 additions and 5 deletions
piker/brokers

View File

@ -23,6 +23,7 @@ Binance backend
"""
from contextlib import asynccontextmanager as acm
from datetime import datetime
from functools import lru_cache
from decimal import Decimal
from typing import (
Any, Union, Optional,
@ -131,14 +132,16 @@ class Pair(Struct, frozen=True):
permissions: list[str]
@property
def size_tick(self) -> Decimal:
def price_tick(self) -> Decimal:
# XXX: lul, after manually inspecting the response format we
# just directly pick out the info we need
return Decimal(self.filters['PRICE_FILTER']['tickSize'].rstrip('0'))
step_size: str = self.filters['PRICE_FILTER']['tickSize'].rstrip('0')
return Decimal(step_size)
@property
def price_tick(self) -> Decimal:
return Decimal(self.filters['LOT_SIZE']['stepSize'].rstrip('0'))
def size_tick(self) -> Decimal:
step_size: str = self.filters['LOT_SIZE']['stepSize'].rstrip('0')
return Decimal(step_size)
class OHLC(Struct):
@ -473,6 +476,7 @@ async def open_history_client(
yield get_ohlc, {'erlangs': 3, 'rate': 3}
@lru_cache
async def get_mkt_info(
fqme: str,
@ -481,7 +485,6 @@ async def get_mkt_info(
async with open_cached_client('binance') as client:
pair: Pair = await client.exch_info(fqme.upper())
mkt = MktPair(
dst=Asset(
name=pair.baseAsset,