2020-05-08 21:05:32 +02:00
|
|
|
from sqlite3 import OperationalError
|
|
|
|
|
2020-04-16 15:23:38 +02:00
|
|
|
from lnbits.db import open_ext_db
|
|
|
|
|
|
|
|
|
|
|
|
def m001_initial(db):
|
|
|
|
"""
|
|
|
|
Initial paywalls table.
|
|
|
|
"""
|
2020-04-21 23:47:04 +02:00
|
|
|
db.execute(
|
|
|
|
"""
|
2020-04-16 15:23:38 +02:00
|
|
|
CREATE TABLE IF NOT EXISTS paywalls (
|
|
|
|
id TEXT PRIMARY KEY,
|
|
|
|
wallet TEXT NOT NULL,
|
2020-04-21 23:42:41 +02:00
|
|
|
secret TEXT NOT NULL,
|
2020-04-16 15:23:38 +02:00
|
|
|
url TEXT NOT NULL,
|
|
|
|
memo TEXT NOT NULL,
|
|
|
|
amount INTEGER NOT NULL,
|
|
|
|
time TIMESTAMP NOT NULL DEFAULT (strftime('%s', 'now'))
|
|
|
|
);
|
2020-04-21 23:47:04 +02:00
|
|
|
"""
|
|
|
|
)
|
2020-04-16 15:23:38 +02:00
|
|
|
|
|
|
|
|
2020-05-08 21:05:32 +02:00
|
|
|
def m002_redux(db):
|
|
|
|
"""
|
|
|
|
Creates an improved paywalls table and migrates the existing data.
|
|
|
|
"""
|
|
|
|
try:
|
|
|
|
db.execute("SELECT remembers FROM paywalls")
|
|
|
|
|
|
|
|
except OperationalError:
|
|
|
|
db.execute("ALTER TABLE paywalls RENAME TO paywalls_old")
|
|
|
|
db.execute(
|
|
|
|
"""
|
|
|
|
CREATE TABLE IF NOT EXISTS paywalls (
|
|
|
|
id TEXT PRIMARY KEY,
|
|
|
|
wallet TEXT NOT NULL,
|
|
|
|
url TEXT NOT NULL,
|
|
|
|
memo TEXT NOT NULL,
|
|
|
|
description TEXT NULL,
|
|
|
|
amount INTEGER DEFAULT 0,
|
|
|
|
time TIMESTAMP NOT NULL DEFAULT (strftime('%s', 'now')),
|
|
|
|
remembers INTEGER DEFAULT 0,
|
|
|
|
extras TEXT NULL
|
|
|
|
);
|
|
|
|
"""
|
|
|
|
)
|
|
|
|
db.execute("CREATE INDEX IF NOT EXISTS wallet_idx ON paywalls (wallet)")
|
|
|
|
|
|
|
|
for row in [list(row) for row in db.fetchall("SELECT * FROM paywalls_old")]:
|
|
|
|
db.execute(
|
|
|
|
"""
|
|
|
|
INSERT INTO paywalls (
|
|
|
|
id,
|
|
|
|
wallet,
|
|
|
|
url,
|
|
|
|
memo,
|
|
|
|
amount,
|
|
|
|
time
|
|
|
|
)
|
|
|
|
VALUES (?, ?, ?, ?, ?, ?)
|
|
|
|
""",
|
|
|
|
(row[0], row[1], row[3], row[4], row[5], row[6]),
|
|
|
|
)
|
|
|
|
|
|
|
|
db.execute("DROP TABLE paywalls_old")
|
|
|
|
|
|
|
|
|
2020-04-16 15:23:38 +02:00
|
|
|
def migrate():
|
2020-04-21 23:42:41 +02:00
|
|
|
with open_ext_db("paywall") as db:
|
2020-04-16 15:23:38 +02:00
|
|
|
m001_initial(db)
|
2020-05-08 21:05:32 +02:00
|
|
|
m002_redux(db)
|