-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy pathworker_donations.py
76 lines (65 loc) · 2.16 KB
/
worker_donations.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
65
66
67
68
69
70
71
72
73
74
75
76
import yaml
from pprint import pprint
import sys
import json
from bitshares import BitShares
from bitshares.account import Account
from bitshares.blockchain import Blockchain
import logging
from logging.handlers import SMTPHandler, RotatingFileHandler
config = yaml.load(open("config.yml").read())
log = logging.getLogger(__name__)
# Logging
log_handler_mail = SMTPHandler(config["mail_host"].split(":"),
config["mail_from"],
config["admins"],
'[faucet] Donation Error',
(config["mail_user"],
config["mail_pass"]))
log_handler_mail.setFormatter(logging.Formatter(
"Message type: %(levelname)s\n" +
"Location: %(pathname)s:%(lineno)d\n" +
"Module: %(module)s\n" +
"Function: %(funcName)s\n" +
"Time: %(asctime)s\n" +
"\n" +
"Message:\n" +
"\n" +
"%(message)s\n"
))
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
log_handler_mail.setLevel(logging.WARN)
log_handler_stdout = logging.StreamHandler(sys.stdout)
log_handler_stdout.setFormatter(formatter)
log.addHandler(log_handler_mail)
log.addHandler(log_handler_stdout)
bitshares = BitShares(
"wss://node.testnet.bitshares.eu",
keys=[config["wif"]],
nobroadcast=False
)
def run(begin=None, end=None):
blockchain = Blockchain(
mode="head",
bitshares_instance=bitshares
)
for op in blockchain.stream(
opNames=["account_create"],
start=int(begin) if begin else None,
stop=int(end) if end else None,
):
blockid = op.get("block_num")
timestamp = op.get("timestamp")
if not blockid % 100:
print("Blockid: %d (%s)" % (blockid, timestamp), flush=True)
try:
pprint(bitshares.transfer(
op["name"],
config["donation_amount"], config["donation_asset"],
account=config["registrar"]
))
except Exception as e:
log.error(str(e))
pass
if __name__ == '__main__':
run()