forked from OmniLayer/omniEngine
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcacheBalances.py
34 lines (26 loc) · 1 KB
/
cacheBalances.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
from balancehelper import *
from cacher import *
import json, time, datetime
def printmsg(msg):
print str(datetime.datetime.now())+str(" ")+str(msg)
sys.stdout.flush()
def updateBalancesCache():
while True:
printmsg("Checking for balance updates")
for space in rKeys("omniwallet:balances:addresses*"):
try:
addresses=rGet(space)
if addresses != None:
addresses = json.loads(addresses)
printmsg("loaded "+str(len(addresses))+" addresses from redis "+str(space))
balances=get_bulkbalancedata(addresses)
rSet("omniwallet:balances:balbook"+str(space[29:]),json.dumps(balances))
#expire balance data after 10 minutes (prevent stale data in case we crash)
rExpire("omniwallet:balances:balbook"+str(space[29:]),600)
except Exception as e:
printmsg("error updating balances: "+str(space)+' '+str(e))
dbCommit()
time.sleep(30)
def main():
updateBalancesCache()
if __name__ == "__main__":main() ## with if