wownero-python/utils/pushtx.py

57 lines
2.2 KiB
Python
Raw Permalink Normal View History

#!/usr/bin/python
2018-01-15 03:12:53 +00:00
import argparse
import logging
import operator
import re
import sys
import six
2018-01-15 03:12:53 +00:00
from monero.backends.jsonrpc import JSONRPCDaemon
2018-01-18 02:02:20 +00:00
from monero.daemon import Daemon
2018-01-25 07:50:09 +00:00
from monero.transaction import Transaction
2018-01-15 03:12:53 +00:00
from monero import exceptions
def url_data(url):
gs = re.compile(
r'^(?P<host>[^:\s]+)(?::(?P<port>[0-9]+))?$'
).match(url).groupdict()
return dict(filter(operator.itemgetter(1), gs.items()))
argsparser = argparse.ArgumentParser(description="Push transaction to network")
2020-08-18 07:41:41 +01:00
argsparser.add_argument('daemon_rpc_url', nargs='?', type=url_data, default='127.0.0.1:34568',
2018-01-15 03:12:53 +00:00
help="Daemon RPC URL [host[:port]]")
argsparser.add_argument('-v', dest='verbosity', action='count', default=0,
help="Verbosity (repeat to increase; -v for INFO, -vv for DEBUG")
argsparser.add_argument('-p', dest='proxy_url', nargs='?', type=str, default=None,
help="Proxy URL")
2019-05-10 23:41:10 +01:00
argsparser.add_argument('-t', dest='timeout', type=int, default=30, help="Request timeout")
2018-01-15 03:12:53 +00:00
argsparser.add_argument('-i', dest='tx_filenames', nargs='+', default=None,
help="Files with transaction data. Will read from stdin if not given.")
argsparser.add_argument('--no-relay', dest='relay', action='store_false',
help="Do not relay the transaction (it will stay at the node unless mined or expired)")
2018-01-15 03:12:53 +00:00
args = argsparser.parse_args()
level = logging.WARNING
if args.verbosity == 1:
level = logging.INFO
elif args.verbosity > 1:
level = logging.DEBUG
logging.basicConfig(level=level, format="%(asctime)-15s %(message)s")
if args.tx_filenames:
blobs = [(f, open(f, 'rb').read()) for f in args.tx_filenames]
2018-01-15 03:12:53 +00:00
else:
blobs = [('transaction', sys.stdin.buffer.read() if six.PY3 else sys.stdin.read())]
d = Daemon(JSONRPCDaemon(timeout=args.timeout, proxy_url=args.proxy_url, **args.daemon_rpc_url))
2018-01-15 03:12:53 +00:00
for name, blob in blobs:
logging.debug("Sending {}".format(name))
2018-01-25 07:50:09 +00:00
tx = Transaction(blob=blob)
2018-01-15 03:12:53 +00:00
try:
res = d.send_transaction(tx, relay=args.relay)
2018-01-15 03:12:53 +00:00
except exceptions.TransactionBroadcastError as e:
print("{} not sent, reason: {}".format(name, e.details['reason']))
logging.debug(e.details)
continue
if res['not_relayed']:
print("{} not relayed".format(name))
else:
print("{} successfully sent".format(name))