2019-03-18 03:40:32 +01:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
"""This plugin is used to check that db_write calls are working correctly.
|
|
|
|
"""
|
|
|
|
from lightning import Plugin, RpcError
|
|
|
|
import sqlite3
|
|
|
|
|
|
|
|
plugin = Plugin()
|
|
|
|
plugin.sqlite_pre_init_cmds = []
|
|
|
|
plugin.initted = False
|
|
|
|
|
|
|
|
|
|
|
|
@plugin.init()
|
|
|
|
def init(configuration, options, plugin):
|
|
|
|
if not plugin.get_option('dblog-file'):
|
|
|
|
raise RpcError("No dblog-file specified")
|
|
|
|
plugin.conn = sqlite3.connect(plugin.get_option('dblog-file'),
|
|
|
|
isolation_level=None)
|
|
|
|
plugin.log("replaying pre-init data:")
|
2019-08-08 21:21:12 +02:00
|
|
|
plugin.conn.execute("PRAGMA foreign_keys = ON;")
|
|
|
|
|
|
|
|
print(plugin.sqlite_pre_init_cmds)
|
|
|
|
|
|
|
|
plugin.conn.execute("BEGIN TRANSACTION;")
|
|
|
|
|
2019-03-18 03:40:32 +01:00
|
|
|
for c in plugin.sqlite_pre_init_cmds:
|
|
|
|
plugin.conn.execute(c)
|
|
|
|
plugin.log("{}".format(c))
|
2019-08-08 21:21:12 +02:00
|
|
|
|
|
|
|
plugin.conn.execute("COMMIT;")
|
|
|
|
|
2019-03-18 03:40:32 +01:00
|
|
|
plugin.initted = True
|
2019-08-24 10:51:58 +02:00
|
|
|
plugin.log("initialized {}".format(configuration))
|
2019-03-18 03:40:32 +01:00
|
|
|
|
|
|
|
|
|
|
|
@plugin.hook('db_write')
|
2019-08-05 02:19:48 +02:00
|
|
|
def db_write(plugin, writes, **kwargs):
|
2019-03-18 03:40:32 +01:00
|
|
|
if not plugin.initted:
|
|
|
|
plugin.log("deferring {} commands".format(len(writes)))
|
|
|
|
plugin.sqlite_pre_init_cmds += writes
|
|
|
|
else:
|
2019-08-08 21:21:12 +02:00
|
|
|
print(writes)
|
|
|
|
plugin.conn.execute("BEGIN TRANSACTION;")
|
|
|
|
|
2019-03-18 03:40:32 +01:00
|
|
|
for c in writes:
|
|
|
|
plugin.conn.execute(c)
|
|
|
|
plugin.log("{}".format(c))
|
2019-08-08 21:21:12 +02:00
|
|
|
|
|
|
|
plugin.conn.execute("COMMIT;")
|
|
|
|
|
2020-01-31 12:50:37 +01:00
|
|
|
return {"result": "continue"}
|
2019-03-18 03:40:32 +01:00
|
|
|
|
|
|
|
|
|
|
|
plugin.add_option('dblog-file', None, 'The db file to create.')
|
|
|
|
plugin.run()
|