mirror of
https://github.com/aljazceru/bitfinex-api-py.git
synced 2025-12-19 14:54:21 +01:00
188 lines
10 KiB
Python
188 lines
10 KiB
Python
from typing import List, Union, Literal, Optional, Any, cast
|
|
|
|
from .types import *
|
|
|
|
from . import serializers
|
|
|
|
from .enums import Config, Sort
|
|
from decimal import Decimal
|
|
|
|
from ._Requests import _Requests
|
|
|
|
class _RestPublicEndpoints(_Requests):
|
|
def conf(self, config: Config) -> Any:
|
|
return self._GET(f"conf/{config}")[0]
|
|
|
|
def get_platform_status(self) -> PlatformStatus:
|
|
return serializers.PlatformStatus.parse(*self._GET("platform/status"))
|
|
|
|
def get_tickers(self, symbols: List[str]) -> List[Union[TradingPairTicker, FundingCurrencyTicker]]:
|
|
data = self._GET("tickers", params={ "symbols": ",".join(symbols) })
|
|
|
|
parsers = { "t": serializers.TradingPairTicker.parse, "f": serializers.FundingCurrencyTicker.parse }
|
|
|
|
return [ cast(Union[TradingPairTicker, FundingCurrencyTicker], parsers[sub_data[0][0]](*sub_data)) for sub_data in data ]
|
|
|
|
def get_t_tickers(self, pairs: Union[List[str], Literal["ALL"]]) -> List[TradingPairTicker]:
|
|
if isinstance(pairs, str) and pairs == "ALL":
|
|
return [ cast(TradingPairTicker, sub_data) for sub_data in self.get_tickers([ "ALL" ]) if cast(str, sub_data.symbol).startswith("t") ]
|
|
|
|
data = self.get_tickers([ "t" + pair for pair in pairs ])
|
|
|
|
return cast(List[TradingPairTicker], data)
|
|
|
|
def get_f_tickers(self, currencies: Union[List[str], Literal["ALL"]]) -> List[FundingCurrencyTicker]:
|
|
if isinstance(currencies, str) and currencies == "ALL":
|
|
return [ cast(FundingCurrencyTicker, sub_data) for sub_data in self.get_tickers([ "ALL" ]) if cast(str, sub_data.symbol).startswith("f") ]
|
|
|
|
data = self.get_tickers([ "f" + currency for currency in currencies ])
|
|
|
|
return cast(List[FundingCurrencyTicker], data)
|
|
|
|
def get_t_ticker(self, pair: str) -> TradingPairTicker:
|
|
return serializers.TradingPairTicker.parse(*self._GET(f"ticker/t{pair}"), skip=["SYMBOL"])
|
|
|
|
def get_f_ticker(self, currency: str) -> FundingCurrencyTicker:
|
|
return serializers.FundingCurrencyTicker.parse(*self._GET(f"ticker/f{currency}"), skip=["SYMBOL"])
|
|
|
|
def get_tickers_history(self, symbols: List[str], start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None) -> List[TickersHistory]:
|
|
return [ serializers.TickersHistory.parse(*sub_data) for sub_data in self._GET("tickers/hist", params={
|
|
"symbols": ",".join(symbols),
|
|
"start": start, "end": end,
|
|
"limit": limit
|
|
}) ]
|
|
|
|
def get_t_trades(self, pair: str, limit: Optional[int] = None, start: Optional[str] = None, end: Optional[str] = None, sort: Optional[Sort] = None) -> List[TradingPairTrade]:
|
|
params = { "limit": limit, "start": start, "end": end, "sort": sort }
|
|
data = self._GET(f"trades/{'t' + pair}/hist", params=params)
|
|
return [ serializers.TradingPairTrade.parse(*sub_data) for sub_data in data ]
|
|
|
|
def get_f_trades(self, currency: str, limit: Optional[int] = None, start: Optional[str] = None, end: Optional[str] = None, sort: Optional[Sort] = None) -> List[FundingCurrencyTrade]:
|
|
params = { "limit": limit, "start": start, "end": end, "sort": sort }
|
|
data = self._GET(f"trades/{'f' + currency}/hist", params=params)
|
|
return [ serializers.FundingCurrencyTrade.parse(*sub_data) for sub_data in data ]
|
|
|
|
def get_t_book(self, pair: str, precision: Literal["P0", "P1", "P2", "P3", "P4"], len: Optional[Literal[1, 25, 100]] = None) -> List[TradingPairBook]:
|
|
return [ serializers.TradingPairBook.parse(*sub_data) for sub_data in self._GET(f"book/{'t' + pair}/{precision}", params={ "len": len }) ]
|
|
|
|
def get_f_book(self, currency: str, precision: Literal["P0", "P1", "P2", "P3", "P4"], len: Optional[Literal[1, 25, 100]] = None) -> List[FundingCurrencyBook]:
|
|
return [ serializers.FundingCurrencyBook.parse(*sub_data) for sub_data in self._GET(f"book/{'f' + currency}/{precision}", params={ "len": len }) ]
|
|
|
|
def get_t_raw_book(self, pair: str, len: Optional[Literal[1, 25, 100]] = None) -> List[TradingPairRawBook]:
|
|
return [ serializers.TradingPairRawBook.parse(*sub_data) for sub_data in self._GET(f"book/{'t' + pair}/R0", params={ "len": len }) ]
|
|
|
|
def get_f_raw_book(self, currency: str, len: Optional[Literal[1, 25, 100]] = None) -> List[FundingCurrencyRawBook]:
|
|
return [ serializers.FundingCurrencyRawBook.parse(*sub_data) for sub_data in self._GET(f"book/{'f' + currency}/R0", params={ "len": len }) ]
|
|
|
|
def get_stats_hist(
|
|
self,
|
|
resource: str,
|
|
sort: Optional[Sort] = None, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None
|
|
) -> List[Statistic]:
|
|
params = { "sort": sort, "start": start, "end": end, "limit": limit }
|
|
data = self._GET(f"stats1/{resource}/hist", params=params)
|
|
return [ serializers.Statistic.parse(*sub_data) for sub_data in data ]
|
|
|
|
def get_stats_last(
|
|
self,
|
|
resource: str,
|
|
sort: Optional[Sort] = None, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None
|
|
) -> Statistic:
|
|
params = { "sort": sort, "start": start, "end": end, "limit": limit }
|
|
data = self._GET(f"stats1/{resource}/last", params=params)
|
|
return serializers.Statistic.parse(*data)
|
|
|
|
def get_candles_hist(
|
|
self,
|
|
symbol: str, tf: str = "1m",
|
|
sort: Optional[Sort] = None, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None
|
|
) -> List[Candle]:
|
|
params = { "sort": sort, "start": start, "end": end, "limit": limit }
|
|
data = self._GET(f"candles/trade:{tf}:{symbol}/hist", params=params)
|
|
return [ serializers.Candle.parse(*sub_data) for sub_data in data ]
|
|
|
|
def get_candles_last(
|
|
self,
|
|
symbol: str, tf: str = "1m",
|
|
sort: Optional[Sort] = None, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None
|
|
) -> Candle:
|
|
params = { "sort": sort, "start": start, "end": end, "limit": limit }
|
|
data = self._GET(f"candles/trade:{tf}:{symbol}/last", params=params)
|
|
return serializers.Candle.parse(*data)
|
|
|
|
def get_derivatives_status(self, keys: Union[List[str], Literal["ALL"]]) -> List[DerivativesStatus]:
|
|
if keys == "ALL":
|
|
params = { "keys": "ALL" }
|
|
else: params = { "keys": ",".join(keys) }
|
|
|
|
data = self._GET(f"status/deriv", params=params)
|
|
|
|
return [ serializers.DerivativesStatus.parse(*sub_data) for sub_data in data ]
|
|
|
|
def get_derivatives_status_history(
|
|
self,
|
|
type: str, symbol: str,
|
|
sort: Optional[Sort] = None, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None
|
|
) -> List[DerivativesStatus]:
|
|
params = { "sort": sort, "start": start, "end": end, "limit": limit }
|
|
data = self._GET(f"status/{type}/{symbol}/hist", params=params)
|
|
return [ serializers.DerivativesStatus.parse(*sub_data, skip=[ "KEY" ]) for sub_data in data ]
|
|
|
|
def get_liquidations(self, sort: Optional[Sort] = None, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None) -> List[Liquidation]:
|
|
params = { "sort": sort, "start": start, "end": end, "limit": limit }
|
|
data = self._GET("liquidations/hist", params=params)
|
|
return [ serializers.Liquidation.parse(*sub_data[0]) for sub_data in data ]
|
|
|
|
def get_seed_candles(self, symbol: str, tf: str = '1m', sort: Optional[Sort] = None, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None) -> List[Candle]:
|
|
params = {"sort": sort, "start": start, "end": end, "limit": limit}
|
|
data = self._GET(f"candles/trade:{tf}:{symbol}/hist?limit={limit}&start={start}&end={end}&sort={sort}", params=params)
|
|
return [ serializers.Candle.parse(*sub_data) for sub_data in data ]
|
|
|
|
def get_leaderboards_hist(
|
|
self,
|
|
resource: str,
|
|
sort: Optional[Sort] = None, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None
|
|
) -> List[Leaderboard]:
|
|
params = { "sort": sort, "start": start, "end": end, "limit": limit }
|
|
data = self._GET(f"rankings/{resource}/hist", params=params)
|
|
return [ serializers.Leaderboard.parse(*sub_data) for sub_data in data ]
|
|
|
|
def get_leaderboards_last(
|
|
self,
|
|
resource: str,
|
|
sort: Optional[Sort] = None, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None
|
|
) -> Leaderboard:
|
|
params = { "sort": sort, "start": start, "end": end, "limit": limit }
|
|
data = self._GET(f"rankings/{resource}/last", params=params)
|
|
return serializers.Leaderboard.parse(*data)
|
|
|
|
def get_funding_stats(self, symbol: str, start: Optional[str] = None, end: Optional[str] = None, limit: Optional[int] = None) -> List[FundingStatistic]:
|
|
params = { "start": start, "end": end, "limit": limit }
|
|
data = self._GET(f"funding/stats/{symbol}/hist", params=params)
|
|
return [ serializers.FundingStatistic.parse(*sub_data) for sub_data in data ]
|
|
|
|
def get_pulse_profile(self, nickname: str) -> PulseProfile:
|
|
return serializers.PulseProfile.parse(*self._GET(f"pulse/profile/{nickname}"))
|
|
|
|
def get_pulse_history(self, end: Optional[str] = None, limit: Optional[int] = None) -> List[PulseMessage]:
|
|
messages = list()
|
|
|
|
for subdata in self._GET("pulse/hist", params={ "end": end, "limit": limit }):
|
|
subdata[18] = subdata[18][0]
|
|
message = serializers.PulseMessage.parse(*subdata)
|
|
messages.append(message)
|
|
|
|
return messages
|
|
|
|
def get_trading_market_average_price(self, symbol: str, amount: Union[Decimal, float, str], price_limit: Optional[Union[Decimal, float, str]] = None) -> TradingMarketAveragePrice:
|
|
return serializers.TradingMarketAveragePrice.parse(*self._POST("calc/trade/avg", body={
|
|
"symbol": symbol, "amount": amount, "price_limit": price_limit
|
|
}))
|
|
|
|
def get_funding_market_average_price(self, symbol: str, amount: Union[Decimal, float, str], period: int, rate_limit: Optional[Union[Decimal, float, str]] = None) -> FundingMarketAveragePrice:
|
|
return serializers.FundingMarketAveragePrice.parse(*self._POST("calc/trade/avg", body={
|
|
"symbol": symbol, "amount": amount, "period": period, "rate_limit": rate_limit
|
|
}))
|
|
|
|
def get_fx_rate(self, ccy1: str, ccy2: str) -> FxRate:
|
|
return serializers.FxRate.parse(*self._POST("calc/fx", body={ "ccy1": ccy1, "ccy2": ccy2 })) |