mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-03 20:44:54 +01:00
41d3471c7f
If we don't save to disk, if the node restarts we'll lose them all and the resulting balance check at the end will be incorrect.
61 lines
2.0 KiB
Python
Executable File
61 lines
2.0 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
|
|
from pyln.client import Plugin
|
|
|
|
import json
|
|
import os.path
|
|
|
|
|
|
plugin = Plugin()
|
|
|
|
|
|
@plugin.init()
|
|
def init(configuration, options, plugin):
|
|
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 = []
|
|
|
|
|
|
@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 blockheight: {}".format(idx, coin_movement['blockheight']))
|
|
plugin.log("{} coins timestamp: {}".format(idx, coin_movement['timestamp']))
|
|
plugin.log("{} coins unit_of_account: {}".format(idx, coin_movement['unit_of_account']))
|
|
|
|
for f in ['payment_hash', 'utxo_txid', 'vout', 'txid', 'part_id']:
|
|
if f in coin_movement:
|
|
plugin.log("{} coins {}: {}".format(idx, f, coin_movement[f]))
|
|
|
|
plugin.coin_moves.append(coin_movement)
|
|
|
|
# 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))
|
|
|
|
|
|
@plugin.method('listcoinmoves_plugin')
|
|
def return_moves(plugin):
|
|
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}
|
|
|
|
|
|
plugin.run()
|