lnbits-legend/lnbits/extensions/paywall/migrations.py

74 lines
1.9 KiB
Python
Raw Normal View History

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
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)
m002_redux(db)