main_peerblocks.py 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. #!/usr/bin/env python3
  2. #
  3. # mmgen = Multi-Mode GENerator, command-line Bitcoin cold storage solution
  4. # Copyright (C)2013-2021 The MMGen Project <mmgen@tuta.io>
  5. #
  6. # This program is free software: you can redistribute it and/or modify it under
  7. # the terms of the GNU General Public License as published by the Free Software
  8. # Foundation, either version 3 of the License, or (at your option) any later
  9. # version.
  10. #
  11. # This program is distributed in the hope that it will be useful, but WITHOUT
  12. # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  13. # FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
  14. # details.
  15. #
  16. # You should have received a copy of the GNU General Public License along with
  17. # this program. If not, see <http://www.gnu.org/licenses/>.
  18. """
  19. mmnode-peerblocks: List blocks in flight, disconnect stalling nodes
  20. """
  21. from mmgen.opts import init
  22. from mmgen.util import async_run
  23. opts_data = {
  24. 'text': {
  25. 'desc': 'List blocks in flight, disconnect stalling nodes',
  26. 'usage': '[opts]',
  27. 'options': """
  28. -h, --help Print this help message
  29. --, --longhelp Print help message for long options (common options)
  30. """
  31. }
  32. }
  33. async def main():
  34. init(opts_data)
  35. from mmgen.protocol import init_proto_from_opts
  36. proto = init_proto_from_opts()
  37. from mmgen.rpc import rpc_init
  38. rpc = await rpc_init(proto)
  39. from .PeerBlocks import BlocksDisplay,PeersDisplay
  40. blocks = BlocksDisplay()
  41. peers = PeersDisplay()
  42. while True:
  43. await blocks.run(rpc)
  44. await peers.run(rpc)
  45. async_run(main())