mirror of
https://github.com/aljazceru/bitfinex-api-py.git
synced 2025-12-19 14:54:21 +01:00
Add support for new rest public endpoints (in BfxRestInterface.py, serializers.py and typings.py).
This commit is contained in:
@@ -1,12 +1,62 @@
|
|||||||
import requests
|
import requests
|
||||||
|
|
||||||
|
from http import HTTPStatus
|
||||||
|
|
||||||
|
from typing import List, Union, Optional
|
||||||
|
|
||||||
from . import serializers
|
from . import serializers
|
||||||
from .typings import PlatformStatus
|
from .typings import PlatformStatus, TradingPairTicker, FundingCurrencyTicker, TickerHistory, TradingPairTrade, FundingCurrencyTrade
|
||||||
|
from .exceptions import RequestParametersError
|
||||||
|
|
||||||
class BfxRestInterface(object):
|
class BfxRestInterface(object):
|
||||||
def __init__(self, host):
|
def __init__(self, host):
|
||||||
self.host = host
|
self.host = host
|
||||||
|
|
||||||
|
def __GET(self, endpoint, params = None):
|
||||||
|
data = requests.get(f"{self.host}/{endpoint}", params=params).json()
|
||||||
|
|
||||||
|
if data[0] == "error":
|
||||||
|
if data[1] == 10020:
|
||||||
|
raise RequestParametersError(f"The request was rejected with the following parameter error: <{data[2]}>")
|
||||||
|
|
||||||
|
return data
|
||||||
|
|
||||||
def platform_status(self) -> PlatformStatus:
|
def platform_status(self) -> PlatformStatus:
|
||||||
return serializers.PlatformStatus.parse(
|
return serializers.PlatformStatus.parse(*self.__GET("platform/status"))
|
||||||
*requests.get(f"{self.host}/platform/status").json()
|
|
||||||
)
|
def tickers(self, symbols: List[str]) -> List[Union[TradingPairTicker, FundingCurrencyTicker]]:
|
||||||
|
return [
|
||||||
|
{
|
||||||
|
"t": serializers.TradingPairTicker.parse,
|
||||||
|
"f": serializers.FundingCurrencyTicker.parse
|
||||||
|
}[subdata[0][0]](*subdata)
|
||||||
|
|
||||||
|
for subdata in self.__GET("tickers", params={ "symbols": ",".join(symbols) })
|
||||||
|
]
|
||||||
|
|
||||||
|
def ticker(self, symbol: str) -> Union[TradingPairTicker, FundingCurrencyTicker]:
|
||||||
|
return {
|
||||||
|
"t": serializers.TradingPairTicker.parse,
|
||||||
|
"f": serializers.FundingCurrencyTicker.parse
|
||||||
|
}[symbol[0]](*self.__GET(f"ticker/{symbol}"), skip=["SYMBOL"])
|
||||||
|
|
||||||
|
def tickers_hist(self, symbols: List[str], start: Optional[int] = None, end: Optional[int] = None, limit: Optional[int] = None) -> List[TickerHistory]:
|
||||||
|
params = {
|
||||||
|
"symbols": ",".join(symbols),
|
||||||
|
"start": start, "end": end,
|
||||||
|
"limit": limit
|
||||||
|
}
|
||||||
|
|
||||||
|
return [ serializers.TickerHistory.parse(*subdata) for subdata in self.__GET("tickers/hist", params=params) ]
|
||||||
|
|
||||||
|
def trades(self, symbol: str, limit: Optional[int] = None, start: Optional[str] = None, end: Optional[str] = None, sort: Optional[int] = None) -> Union[List[TradingPairTrade], List[FundingCurrencyTicker]]:
|
||||||
|
params = { "symbol": symbol, "limit": limit, "start": start, "end": end, "sort": sort }
|
||||||
|
|
||||||
|
return [
|
||||||
|
{
|
||||||
|
"t": serializers.TradingPairTrade.parse,
|
||||||
|
"f": serializers.FundingCurrencyTrade.parse
|
||||||
|
}[symbol[0]](*subdata)
|
||||||
|
|
||||||
|
for subdata in self.__GET(f"trades/{symbol}/hist", params=params)
|
||||||
|
]
|
||||||
@@ -1,6 +1,17 @@
|
|||||||
|
__all__ = [
|
||||||
|
"RequestParametersError"
|
||||||
|
]
|
||||||
|
|
||||||
class BfxRestException(Exception):
|
class BfxRestException(Exception):
|
||||||
"""
|
"""
|
||||||
Base class for all exceptions defined in bfxapi/rest/exceptions.py.
|
Base class for all exceptions defined in bfxapi/rest/exceptions.py.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class RequestParametersError(BfxRestException):
|
||||||
|
"""
|
||||||
|
This error indicates that there are some invalid parameters sent along with an HTTP request.
|
||||||
|
"""
|
||||||
|
|
||||||
|
pass
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
from typing import Generic, TypeVar, Iterable, List, Any
|
from typing import Generic, TypeVar, Iterable, Optional, List, Any
|
||||||
|
|
||||||
from . import typings
|
from . import typings
|
||||||
|
|
||||||
@@ -7,19 +7,21 @@ from .exceptions import BfxRestException
|
|||||||
T = TypeVar("T")
|
T = TypeVar("T")
|
||||||
|
|
||||||
class _Serializer(Generic[T]):
|
class _Serializer(Generic[T]):
|
||||||
def __init__(self, name: str, labels: List[str]):
|
def __init__(self, name: str, labels: List[str], IGNORE: List[str] = [ "_PLACEHOLDER" ]):
|
||||||
self.name, self.__labels = name, labels
|
self.name, self.__labels, self.__IGNORE = name, labels, IGNORE
|
||||||
|
|
||||||
def __serialize(self, *args: Any, IGNORE: List[str] = [ "_PLACEHOLDER" ]) -> Iterable[T]:
|
def __serialize(self, *args: Any, skip: Optional[List[str]]) -> Iterable[T]:
|
||||||
if len(self.__labels) != len(args):
|
labels = list(filter(lambda label: label not in (skip or list()), self.__labels))
|
||||||
raise BfxRestException("<self.__labels> and <*args> arguments should contain the same amount of elements.")
|
|
||||||
|
|
||||||
for index, label in enumerate(self.__labels):
|
if len(labels) != len(args):
|
||||||
if label not in IGNORE:
|
raise BfxRestException("<labels> and <*args> arguments should contain the same amount of elements.")
|
||||||
|
|
||||||
|
for index, label in enumerate(labels):
|
||||||
|
if label not in self.__IGNORE:
|
||||||
yield label, args[index]
|
yield label, args[index]
|
||||||
|
|
||||||
def parse(self, *values: Any) -> T:
|
def parse(self, *values: Any, skip: Optional[List[str]] = None) -> T:
|
||||||
return dict(self.__serialize(*values))
|
return dict(self.__serialize(*values, skip=skip))
|
||||||
|
|
||||||
#region Serializers definition for Rest Public Endpoints
|
#region Serializers definition for Rest Public Endpoints
|
||||||
|
|
||||||
@@ -27,4 +29,69 @@ PlatformStatus = _Serializer[typings.PlatformStatus]("PlatformStatus", labels=[
|
|||||||
"OPERATIVE"
|
"OPERATIVE"
|
||||||
])
|
])
|
||||||
|
|
||||||
|
TradingPairTicker = _Serializer[typings.TradingPairTicker]("TradingPairTicker", labels=[
|
||||||
|
"SYMBOL",
|
||||||
|
"BID",
|
||||||
|
"BID_SIZE",
|
||||||
|
"ASK",
|
||||||
|
"ASK_SIZE",
|
||||||
|
"DAILY_CHANGE",
|
||||||
|
"DAILY_CHANGE_RELATIVE",
|
||||||
|
"LAST_PRICE",
|
||||||
|
"VOLUME",
|
||||||
|
"HIGH",
|
||||||
|
"LOW"
|
||||||
|
])
|
||||||
|
|
||||||
|
FundingCurrencyTicker = _Serializer[typings.FundingCurrencyTicker]("FundingCurrencyTicker", labels=[
|
||||||
|
"SYMBOL",
|
||||||
|
"FRR",
|
||||||
|
"BID",
|
||||||
|
"BID_PERIOD",
|
||||||
|
"BID_SIZE",
|
||||||
|
"ASK",
|
||||||
|
"ASK_PERIOD",
|
||||||
|
"ASK_SIZE",
|
||||||
|
"DAILY_CHANGE",
|
||||||
|
"DAILY_CHANGE_RELATIVE",
|
||||||
|
"LAST_PRICE",
|
||||||
|
"VOLUME",
|
||||||
|
"HIGH",
|
||||||
|
"LOW",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"FRR_AMOUNT_AVAILABLE"
|
||||||
|
])
|
||||||
|
|
||||||
|
TickerHistory = _Serializer[typings.TickerHistory]("TickerHistory", labels=[
|
||||||
|
"SYMBOL",
|
||||||
|
"BID",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"ASK",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"_PLACEHOLDER",
|
||||||
|
"MTS"
|
||||||
|
])
|
||||||
|
|
||||||
|
TradingPairTrade = _Serializer[typings.TradingPairTrade]("TradingPairTrade", labels=[
|
||||||
|
"ID",
|
||||||
|
"MTS",
|
||||||
|
"AMOUNT",
|
||||||
|
"PRICE"
|
||||||
|
])
|
||||||
|
|
||||||
|
FundingCurrencyTrade = _Serializer[typings.FundingCurrencyTrade]("FundingCurrencyTrade", labels=[
|
||||||
|
"ID",
|
||||||
|
"MTS",
|
||||||
|
"AMOUNT",
|
||||||
|
"RATE",
|
||||||
|
"PERIOD"
|
||||||
|
])
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
@@ -6,4 +6,48 @@ PlatformStatus = TypedDict("PlatformStatus", {
|
|||||||
"OPERATIVE": int
|
"OPERATIVE": int
|
||||||
})
|
})
|
||||||
|
|
||||||
|
TradingPairTicker = TypedDict("TradingPairTicker", {
|
||||||
|
"SYMBOL": Optional[str],
|
||||||
|
"BID": float,
|
||||||
|
"BID_SIZE": float,
|
||||||
|
"ASK": float,
|
||||||
|
"ASK_SIZE": float,
|
||||||
|
"DAILY_CHANGE": float,
|
||||||
|
"DAILY_CHANGE_RELATIVE": float,
|
||||||
|
"LAST_PRICE": float,
|
||||||
|
"VOLUME": float,
|
||||||
|
"HIGH": float,
|
||||||
|
"LOW": float
|
||||||
|
})
|
||||||
|
|
||||||
|
FundingCurrencyTicker = TypedDict("FundingCurrencyTicker", {
|
||||||
|
"SYMBOL": Optional[str],
|
||||||
|
"FRR": float,
|
||||||
|
"BID": float,
|
||||||
|
"BID_PERIOD": int,
|
||||||
|
"BID_SIZE": float,
|
||||||
|
"ASK": float,
|
||||||
|
"ASK_PERIOD": int,
|
||||||
|
"ASK_SIZE": float,
|
||||||
|
"DAILY_CHANGE": float,
|
||||||
|
"DAILY_CHANGE_RELATIVE": float,
|
||||||
|
"LAST_PRICE": float,
|
||||||
|
"VOLUME": float,
|
||||||
|
"HIGH": float,
|
||||||
|
"LOW": float,
|
||||||
|
"FRR_AMOUNT_AVAILABLE": float
|
||||||
|
})
|
||||||
|
|
||||||
|
TickerHistory = TypedDict("TickerHistory", {
|
||||||
|
"SYMBOL": str,
|
||||||
|
"BID": float,
|
||||||
|
"ASK": float,
|
||||||
|
"MTS": int
|
||||||
|
})
|
||||||
|
|
||||||
|
(TradingPairTrade, FundingCurrencyTrade) = (
|
||||||
|
TypedDict("TradingPairTrade", { "ID": int, "MTS": int, "AMOUNT": float, "PRICE": float }),
|
||||||
|
TypedDict("FundingCurrencyTrade", { "ID": int, "MTS": int, "AMOUNT": float, "RATE": float, "PERIOD": int })
|
||||||
|
)
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
Reference in New Issue
Block a user