2020-03-19 00:46:17 +01:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
from pyln.client import Plugin
|
|
|
|
|
2020-04-02 05:02:08 +02:00
|
|
|
import json
|
|
|
|
import os.path
|
|
|
|
|
|
|
|
|
2020-03-19 00:46:17 +01:00
|
|
|
plugin = Plugin()
|
|
|
|
|
|
|
|
|
|
|
|
@plugin.init()
|
|
|
|
def init(configuration, options, plugin):
|
2020-04-02 05:02:08 +02:00
|
|
|
if os.path.exists('moves.json'):
|
|
|
|
jd = {}
|
|
|
|
with open('moves.json', 'r') as f:
|
|
|
|
jd = f.read()
|
|
|
|
plugin.coin_moves = json.loads(jd)
|
|
|
|
else:
|
|
|
|
plugin.coin_moves = []
|
2020-03-19 00:46:17 +01:00
|
|
|
|
|
|
|
|
|
|
|
@plugin.subscribe("coin_movement")
|
|
|
|
def notify_coin_movement(plugin, coin_movement, **kwargs):
|
|
|
|
idx = coin_movement['movement_idx']
|
|
|
|
plugin.log("{} coins movement version: {}".format(idx, coin_movement['version']))
|
|
|
|
plugin.log("{} coins node: {}".format(idx, coin_movement['node_id']))
|
|
|
|
plugin.log("{} coins mvt_type: {}".format(idx, coin_movement['type']))
|
|
|
|
plugin.log("{} coins account: {}".format(idx, coin_movement['account_id']))
|
|
|
|
plugin.log("{} coins credit: {}".format(idx, coin_movement['credit']))
|
|
|
|
plugin.log("{} coins debit: {}".format(idx, coin_movement['debit']))
|
|
|
|
plugin.log("{} coins tag: {}".format(idx, coin_movement['tag']))
|
|
|
|
plugin.log("{} coins timestamp: {}".format(idx, coin_movement['timestamp']))
|
|
|
|
plugin.log("{} coins unit_of_account: {}".format(idx, coin_movement['unit_of_account']))
|
|
|
|
|
2020-04-03 23:52:35 +02:00
|
|
|
for f in ['payment_hash', 'utxo_txid', 'vout', 'txid', 'part_id', 'blockheight']:
|
2020-03-19 00:46:17 +01:00
|
|
|
if f in coin_movement:
|
|
|
|
plugin.log("{} coins {}: {}".format(idx, f, coin_movement[f]))
|
|
|
|
|
|
|
|
plugin.coin_moves.append(coin_movement)
|
|
|
|
|
2020-04-02 05:02:08 +02:00
|
|
|
# we save to disk so that we don't get borked if the node restarts
|
|
|
|
# assumes notification calls are synchronous (not thread safe)
|
|
|
|
with open('moves.json', 'w') as f:
|
|
|
|
f.write(json.dumps(plugin.coin_moves))
|
|
|
|
|
2020-03-19 00:46:17 +01:00
|
|
|
|
|
|
|
@plugin.method('listcoinmoves_plugin')
|
|
|
|
def return_moves(plugin):
|
2020-04-02 05:02:08 +02:00
|
|
|
result = []
|
|
|
|
if os.path.exists('moves.json'):
|
|
|
|
jd = {}
|
|
|
|
with open('moves.json', 'r') as f:
|
|
|
|
jd = f.read()
|
|
|
|
result = json.loads(jd)
|
|
|
|
return {'coin_moves': result}
|
2020-03-19 00:46:17 +01:00
|
|
|
|
|
|
|
|
|
|
|
plugin.run()
|