lbry-sdk/lbry/wallet/usage_payment.py

78 lines
2.8 KiB
Python
Raw Normal View History

2020-01-06 01:29:48 -03:00
import asyncio
import logging
2020-02-21 10:05:46 -05:00
from lbry.error import (
ServerPaymentFeeAboveMaxAllowedError,
ServerPaymentInvalidAddressError,
ServerPaymentWalletLockedError
)
2020-05-01 09:33:10 -04:00
from lbry.blockchain.dewies import lbc_to_dewies
from lbry.event import EventController
2020-01-06 01:29:48 -03:00
log = logging.getLogger(__name__)
class WalletServerPayer:
def __init__(self, payment_period=24 * 60 * 60, max_fee='1.0', analytics_manager=None):
2020-02-11 22:05:49 -03:00
self.ledger = None
self.wallet = None
2020-01-06 01:29:48 -03:00
self.running = False
self.task = None
2020-02-11 22:05:49 -03:00
self.payment_period = payment_period
self.analytics_manager = analytics_manager
self.max_fee = max_fee
2020-05-01 09:33:10 -04:00
self._on_payment_controller = EventController()
self.on_payment = self._on_payment_controller.stream
self.on_payment.listen(None, on_error=lambda e: logging.warning(e.args[0]))
2020-01-06 01:29:48 -03:00
async def pay(self):
while self.running:
2020-02-11 22:05:49 -03:00
await asyncio.sleep(self.payment_period)
features = await self.ledger.network.retriable_call(self.ledger.network.get_server_features)
2020-01-06 01:29:48 -03:00
address = features['payment_address']
amount = str(features['daily_fee'])
if not address or not amount:
continue
2020-01-06 01:29:48 -03:00
if not self.ledger.is_valid_address(address):
2020-02-21 10:05:46 -05:00
self._on_payment_controller.add_error(ServerPaymentInvalidAddressError(address))
2020-02-11 22:05:49 -03:00
continue
2020-02-21 10:05:46 -05:00
2020-01-06 01:29:48 -03:00
if self.wallet.is_locked:
2020-02-21 10:05:46 -05:00
self._on_payment_controller.add_error(ServerPaymentWalletLockedError())
2020-02-11 22:05:49 -03:00
continue
2020-01-06 01:29:48 -03:00
amount = lbc_to_dewies(features['daily_fee']) # check that this is in lbc and not dewies
limit = lbc_to_dewies(self.max_fee)
if amount > limit:
self._on_payment_controller.add_error(
2020-02-21 10:05:46 -05:00
ServerPaymentFeeAboveMaxAllowedError(features['daily_fee'], self.max_fee)
)
continue
2020-01-06 01:29:48 -03:00
2020-06-05 00:35:22 -04:00
# tx = await Transaction.create(
# [],
# [Output.pay_pubkey_hash(amount, self.ledger.address_to_hash160(address))],
# self.wallet.get_accounts_or_all(None),
# self.wallet.get_account_or_default(None)
# )
#
# await self.ledger.broadcast(tx)
# if self.analytics_manager:
# await self.analytics_manager.send_credits_sent()
# self._on_payment_controller.add(tx)
2020-01-06 01:29:48 -03:00
async def start(self, ledger=None, wallet=None):
if lbc_to_dewies(self.max_fee) < 1:
return
2020-02-11 22:05:49 -03:00
self.ledger = ledger
self.wallet = wallet
2020-01-06 01:29:48 -03:00
self.running = True
self.task = asyncio.ensure_future(self.pay())
self.task.add_done_callback(lambda _: log.info("Stopping wallet server payments."))
async def stop(self):
if self.running:
self.running = False
self.task.cancel()