mirror of
https://github.com/aljazceru/bitfinex-api-py.git
synced 2025-12-18 22:34:21 +01:00
Rewrite implementation for abstract class Connection (_connection.py).
This commit is contained in:
@@ -1,5 +1,11 @@
|
|||||||
from typing import \
|
from typing import \
|
||||||
TYPE_CHECKING, Optional, cast
|
TYPE_CHECKING, TypeVar, Callable, \
|
||||||
|
Awaitable, Optional, Any, \
|
||||||
|
cast
|
||||||
|
|
||||||
|
from abc import ABC, abstractmethod
|
||||||
|
|
||||||
|
from typing_extensions import ParamSpec, Concatenate
|
||||||
|
|
||||||
from bfxapi.websocket.exceptions import \
|
from bfxapi.websocket.exceptions import \
|
||||||
ConnectionNotOpen, ActionRequiresAuthentication
|
ConnectionNotOpen, ActionRequiresAuthentication
|
||||||
@@ -7,7 +13,13 @@ from bfxapi.websocket.exceptions import \
|
|||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
from websockets.client import WebSocketClientProtocol
|
from websockets.client import WebSocketClientProtocol
|
||||||
|
|
||||||
class Connection:
|
_S = TypeVar("_S", bound="Connection")
|
||||||
|
|
||||||
|
_R = TypeVar("_R")
|
||||||
|
|
||||||
|
_P = ParamSpec("_P")
|
||||||
|
|
||||||
|
class Connection(ABC):
|
||||||
HEARTBEAT = "hb"
|
HEARTBEAT = "hb"
|
||||||
|
|
||||||
def __init__(self, host: str) -> None:
|
def __init__(self, host: str) -> None:
|
||||||
@@ -34,9 +46,15 @@ class Connection:
|
|||||||
def _websocket(self, protocol: "WebSocketClientProtocol") -> None:
|
def _websocket(self, protocol: "WebSocketClientProtocol") -> None:
|
||||||
self.__protocol = protocol
|
self.__protocol = protocol
|
||||||
|
|
||||||
|
@abstractmethod
|
||||||
|
async def start(self) -> None:
|
||||||
|
...
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def require_websocket_connection(function):
|
def require_websocket_connection(
|
||||||
async def wrapper(self, *args, **kwargs):
|
function: Callable[Concatenate[_S, _P], Awaitable[_R]]
|
||||||
|
) -> Callable[Concatenate[_S, _P], Awaitable["_R"]]:
|
||||||
|
async def wrapper(self: _S, *args: Any, **kwargs: Any) -> _R:
|
||||||
if self.open:
|
if self.open:
|
||||||
return await function(self, *args, **kwargs)
|
return await function(self, *args, **kwargs)
|
||||||
|
|
||||||
@@ -45,8 +63,10 @@ class Connection:
|
|||||||
return wrapper
|
return wrapper
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def require_websocket_authentication(function):
|
def require_websocket_authentication(
|
||||||
async def wrapper(self, *args, **kwargs):
|
function: Callable[Concatenate[_S, _P], Awaitable[_R]]
|
||||||
|
) -> Callable[Concatenate[_S, _P], Awaitable[_R]]:
|
||||||
|
async def wrapper(self: _S, *args: Any, **kwargs: Any) -> _R:
|
||||||
if not self.authentication:
|
if not self.authentication:
|
||||||
raise ActionRequiresAuthentication("To perform this action you need to " \
|
raise ActionRequiresAuthentication("To perform this action you need to " \
|
||||||
"authenticate using your API_KEY and API_SECRET.")
|
"authenticate using your API_KEY and API_SECRET.")
|
||||||
|
|||||||
Reference in New Issue
Block a user