forked from bitphage/golos-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtransfer.py
executable file
·64 lines (51 loc) · 1.72 KB
/
transfer.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!/usr/bin/env python
import sys
import json
import argparse
import logging
import yaml
import traceback
from golos import Steem
import functions
log = logging.getLogger('functions')
def main():
parser = argparse.ArgumentParser(
description='transfer',
epilog='Report bugs to: https://github.com/bitfag/golos-scripts/issues')
parser.add_argument('-d', '--debug', action='store_true',
help='enable debug output'),
parser.add_argument('--broadcast', action='store_true', default=False,
help='broadcast transactions'),
parser.add_argument('-c', '--config', default='./common.yml',
help='specify custom path for config file')
parser.add_argument('f',
help='from'),
parser.add_argument('to',
help='to'),
parser.add_argument('amount',
help='amount'),
parser.add_argument('asset',
help='asset'),
parser.add_argument('memo',
help='memo'),
args = parser.parse_args()
# create logger
if args.debug == True:
log.setLevel(logging.DEBUG)
else:
log.setLevel(logging.INFO)
handler = logging.StreamHandler()
formatter = logging.Formatter("%(asctime)s %(levelname)s: %(message)s")
handler.setFormatter(formatter)
log.addHandler(handler)
# parse config
with open(args.config, 'r') as ymlfile:
conf = yaml.load(ymlfile)
# initialize steem instance
log.debug('broadcast: %s', args.broadcast)
# toggle args.broadcast
b = not args.broadcast
golos = Steem(nodes=conf['nodes_old'], no_broadcast=b, keys=conf['keys'])
functions.transfer(golos, args.f, args.to, args.amount, args.asset, args.memo)
if __name__ == '__main__':
main()