52 lines
2.5 KiB
Python
52 lines
2.5 KiB
Python
|
import logging
|
||
|
|
||
|
logger = logging.getLogger(__name__)
|
||
|
|
||
|
MAX_NOTIFICATIONS_COUNT = 5
|
||
|
|
||
|
|
||
|
class Handler:
|
||
|
def __init__(self, pool_name, exchange_rate=None, currency=None, notifier=None):
|
||
|
self.pool_name = pool_name
|
||
|
self.exchange_rate = exchange_rate
|
||
|
self.currency = currency
|
||
|
self.notifier = notifier
|
||
|
|
||
|
def _watch_miner_balance(self, miner, last_balance=None):
|
||
|
logger.debug('watching miner balance')
|
||
|
if miner.raw_balance != last_balance:
|
||
|
logger.info('miner balance has changed')
|
||
|
if self.notifier:
|
||
|
logger.debug('sending balance notification')
|
||
|
arguments = {'pool': self.pool_name, 'address': miner.address, 'url': miner.url,
|
||
|
'balance': miner.balance, 'balance_fiat': miner.balance_fiat,
|
||
|
'balance_percentage': miner.balance_percentage}
|
||
|
try:
|
||
|
self.notifier.notify_balance(**arguments)
|
||
|
logger.info('balance notification sent')
|
||
|
except Exception as err:
|
||
|
logger.error('failed to send notification')
|
||
|
logger.exception(err)
|
||
|
return miner.raw_balance
|
||
|
|
||
|
def _watch_miner_payments(self, miner, last_transaction=None):
|
||
|
if miner.last_transaction and miner.last_transaction.txid != last_transaction:
|
||
|
logger.debug('watching miner payments')
|
||
|
# send notifications for recent payements only
|
||
|
for transaction in miner.transactions[MAX_NOTIFICATIONS_COUNT:]:
|
||
|
if not last_transaction or transaction.txid > last_transaction:
|
||
|
logger.info(f'new payment {transaction.txid}')
|
||
|
if self.notifier:
|
||
|
logger.debug('sending payment notification')
|
||
|
arguments = {'pool': self.pool_name, 'address': miner.address, 'txid': transaction.txid,
|
||
|
'amount': transaction.amount, 'amount_fiat': transaction.amount_fiat,
|
||
|
'time': transaction.time, 'duration': transaction.duration}
|
||
|
try:
|
||
|
self.notifier.notify_payment(**arguments)
|
||
|
logger.info('payment notification sent')
|
||
|
except Exception as err:
|
||
|
logger.error('failed to send notification')
|
||
|
logger.exception(err)
|
||
|
if miner.last_transaction and miner.last_transaction.txid:
|
||
|
return miner.last_transaction.txid
|