Factor out outgoing processor

This commit is contained in:
lash 2022-05-04 05:41:00 +00:00
parent 42aa809500
commit abc619d7b2
Signed by: lash
GPG Key ID: 21D2E7BB88C2A746
4 changed files with 19 additions and 34 deletions

1
.gitignore vendored
View File

@ -6,3 +6,4 @@ build/
*.egg-info *.egg-info
*.sqlite *.sqlite
.coverage .coverage
.chaind

View File

@ -28,11 +28,12 @@ from chainqueue.cache import CacheTokenTx
from chainlib.encode import TxHexNormalizer from chainlib.encode import TxHexNormalizer
from chainlib.chain import ChainSpec from chainlib.chain import ChainSpec
from chaind.adapters.fs import ChaindFsAdapter from chaind.adapters.fs import ChaindFsAdapter
from chaind.dispatch import DispatchProcessor
# local imports # local imports
from chaind.eth.dispatch import EthDispatcher
from chaind.eth.cache import EthCacheTx from chaind.eth.cache import EthCacheTx
from chaind.eth.settings import ChaindEthSettings from chaind.eth.settings import ChaindEthSettings
from chaind.eth.dispatch import EthDispatcher
logging.basicConfig(level=logging.WARNING) logging.basicConfig(level=logging.WARNING)
logg = logging.getLogger() logg = logging.getLogger()
@ -66,41 +67,16 @@ settings.process(config)
logg.debug('settings:\n{}'.format(settings)) logg.debug('settings:\n{}'.format(settings))
def process_outgoing(chain_spec, adapter, rpc, limit=50):
adapter = None
process_err = None
adapter = ChaindFsAdapter(
settings.get('CHAIN_SPEC'),
settings.dir_for('queue'),
EthCacheTx,
dispatcher,
)
upcoming = adapter.upcoming(limit=limit)
logg.info('processor has {} candidates for {}, processing with limit {} adapter {} rpc {}'.format(len(upcoming), chain_spec, limit, adapter, rpc))
i = 0
for tx_hash in upcoming:
if adapter.dispatch(tx_hash):
i += 1
return i
chain_spec = ChainSpec.from_chain_str(config.get('CHAIN_SPEC'))
rpc = chainlib.eth.cli.Rpc() rpc = chainlib.eth.cli.Rpc()
conn = rpc.connect_by_config(config) conn = rpc.connect_by_config(config)
tx_normalizer = TxHexNormalizer().tx_hash tx_normalizer = TxHexNormalizer().tx_hash
token_cache_store = CacheTokenTx(chain_spec, normalizer=tx_normalizer) token_cache_store = CacheTokenTx(settings.get('CHAIN_SPEC'), normalizer=tx_normalizer)
dispatcher = EthDispatcher(conn)
queue_adapter = ChaindFsAdapter( dispatcher = EthDispatcher(conn)
settings.get('CHAIN_SPEC'), processor = DispatchProcessor(settings.get('CHAIN_SPEC'), settings.dir_for('queue'), dispatcher)
settings.dir_for('queue'), ctrl = SessionController(settings, processor.process)
EthCacheTx,
dispatcher,
)
ctrl = SessionController(settings, queue_adapter, process_outgoing)
signal.signal(signal.SIGINT, ctrl.shutdown) signal.signal(signal.SIGINT, ctrl.shutdown)
signal.signal(signal.SIGTERM, ctrl.shutdown) signal.signal(signal.SIGTERM, ctrl.shutdown)
@ -126,6 +102,14 @@ def main():
ctrl.process(conn) ctrl.process(conn)
continue continue
queue_adapter = ChaindFsAdapter(
settings.get('CHAIN_SPEC'),
settings.dir_for('queue'),
EthCacheTx,
dispatcher,
store_sync=False,
)
result_data = None result_data = None
r = 0 # no error r = 0 # no error
try: try:

View File

@ -1,6 +1,6 @@
chaind~=0.2.2 chaind~=0.2.4
hexathon~=0.1.5 hexathon~=0.1.5
chainlib-eth~=0.1.1 chainlib-eth~=0.1.1
pyxdg~=0.27 pyxdg~=0.27
shep~=0.2.3 shep~=0.2.5
funga-eth~=0.6.0 funga-eth~=0.6.0

View File

@ -1,6 +1,6 @@
[metadata] [metadata]
name = chaind-eth name = chaind-eth
version = 0.2.1 version = 0.2.2
description = Queue server for ethereum description = Queue server for ethereum
author = Louis Holbrook author = Louis Holbrook
author_email = dev@holbrook.no author_email = dev@holbrook.no