2017-10-06 10:22:04 +00:00
|
|
|
from abc import ABC, abstractmethod
|
2017-10-31 23:13:23 +00:00
|
|
|
from typing import List, Optional, Dict
|
2017-10-06 10:22:04 +00:00
|
|
|
|
|
|
|
import arrow
|
|
|
|
|
|
|
|
|
|
|
|
class Exchange(ABC):
|
|
|
|
@property
|
|
|
|
def name(self) -> str:
|
|
|
|
"""
|
|
|
|
Name of the exchange.
|
|
|
|
:return: str representation of the class name
|
|
|
|
"""
|
|
|
|
return self.__class__.__name__
|
|
|
|
|
2017-10-31 23:13:23 +00:00
|
|
|
@property
|
|
|
|
def fee(self) -> float:
|
|
|
|
"""
|
|
|
|
Fee for placing an order
|
|
|
|
:return: percentage in float
|
|
|
|
"""
|
|
|
|
return 0.0
|
|
|
|
|
2017-10-06 10:22:04 +00:00
|
|
|
@property
|
|
|
|
@abstractmethod
|
|
|
|
def sleep_time(self) -> float:
|
|
|
|
"""
|
|
|
|
Sleep time in seconds for the main loop to avoid API rate limits.
|
|
|
|
:return: float
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def buy(self, pair: str, rate: float, amount: float) -> str:
|
|
|
|
"""
|
|
|
|
Places a limit buy order.
|
|
|
|
:param pair: Pair as str, format: BTC_ETH
|
|
|
|
:param rate: Rate limit for order
|
|
|
|
:param amount: The amount to purchase
|
|
|
|
:return: order_id of the placed buy order
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def sell(self, pair: str, rate: float, amount: float) -> str:
|
|
|
|
"""
|
|
|
|
Places a limit sell order.
|
|
|
|
:param pair: Pair as str, format: BTC_ETH
|
|
|
|
:param rate: Rate limit for order
|
|
|
|
:param amount: The amount to sell
|
|
|
|
:return: order_id of the placed sell order
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def get_balance(self, currency: str) -> float:
|
|
|
|
"""
|
|
|
|
Gets account balance.
|
|
|
|
:param currency: Currency as str, format: BTC
|
|
|
|
:return: float
|
|
|
|
"""
|
|
|
|
|
2017-10-29 15:57:57 +00:00
|
|
|
@abstractmethod
|
|
|
|
def get_balances(self) -> List[dict]:
|
|
|
|
"""
|
|
|
|
Gets account balances across currencies
|
|
|
|
:return: List of dicts, format: [
|
|
|
|
{
|
|
|
|
'Currency': str,
|
|
|
|
'Balance': float,
|
|
|
|
'Available': float,
|
|
|
|
'Pending': float,
|
|
|
|
}
|
|
|
|
...
|
|
|
|
]
|
|
|
|
"""
|
|
|
|
|
2017-10-06 10:22:04 +00:00
|
|
|
@abstractmethod
|
|
|
|
def get_ticker(self, pair: str) -> dict:
|
|
|
|
"""
|
|
|
|
Gets ticker for given pair.
|
|
|
|
:param pair: Pair as str, format: BTC_ETC
|
|
|
|
:return: dict, format: {
|
|
|
|
'bid': float,
|
|
|
|
'ask': float,
|
|
|
|
'last': float
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
2017-11-05 22:47:59 +00:00
|
|
|
def get_ticker_history(self, pair: str, minimum_date: Optional[arrow.Arrow] = None) -> List:
|
2017-10-06 10:22:04 +00:00
|
|
|
"""
|
|
|
|
Gets ticker history for given pair.
|
|
|
|
:param pair: Pair as str, format: BTC_ETC
|
|
|
|
:param minimum_date: Minimum date (optional)
|
2017-11-05 22:47:59 +00:00
|
|
|
:return: list, format: [
|
|
|
|
{
|
|
|
|
'O': float, (Open)
|
|
|
|
'H': float, (High)
|
|
|
|
'L': float, (Low)
|
|
|
|
'C': float, (Close)
|
|
|
|
'V': float, (Volume)
|
|
|
|
'T': datetime, (Time)
|
|
|
|
'BV': float, (Base Volume)
|
|
|
|
},
|
|
|
|
...
|
|
|
|
]
|
2017-10-06 10:22:04 +00:00
|
|
|
"""
|
|
|
|
|
2017-10-31 23:13:23 +00:00
|
|
|
def get_order(self, order_id: str) -> Dict:
|
2017-10-06 10:22:04 +00:00
|
|
|
"""
|
2017-10-31 23:13:23 +00:00
|
|
|
Get order details for the given order_id.
|
2017-10-06 10:22:04 +00:00
|
|
|
:param order_id: ID as str
|
2017-10-31 23:13:23 +00:00
|
|
|
:return: dict, format: {
|
|
|
|
'id': str,
|
|
|
|
'type': str,
|
|
|
|
'pair': str,
|
|
|
|
'opened': str ISO 8601 datetime,
|
|
|
|
'closed': str ISO 8601 datetime,
|
|
|
|
'rate': float,
|
|
|
|
'amount': float,
|
|
|
|
'remaining': int
|
|
|
|
}
|
2017-10-06 10:22:04 +00:00
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
2017-10-31 23:13:23 +00:00
|
|
|
def cancel_order(self, order_id: str) -> None:
|
2017-10-06 10:22:04 +00:00
|
|
|
"""
|
2017-10-31 23:13:23 +00:00
|
|
|
Cancels order for given order_id.
|
|
|
|
:param order_id: ID as str
|
|
|
|
:return: None
|
2017-10-06 10:22:04 +00:00
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def get_pair_detail_url(self, pair: str) -> str:
|
|
|
|
"""
|
|
|
|
Returns the market detail url for the given pair.
|
|
|
|
:param pair: Pair as str, format: BTC_ETC
|
|
|
|
:return: URL as str
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def get_markets(self) -> List[str]:
|
|
|
|
"""
|
|
|
|
Returns all available markets.
|
|
|
|
:return: List of all available pairs
|
|
|
|
"""
|