mirror of
https://github.com/lnbits/lnbits-legend.git
synced 2025-02-25 23:21:21 +01:00
* feat: add shortcuts for insert_query and update_query into `Database` example: await db.insert("table_name", base_model) * remove where from argument * chore: code clean-up * extension manager * lnbits-qrcode components * parse date from dict * refactor: make `settings` a fixture * chore: remove verbose key names * fix: time column * fix: cast balance to `int` * extension toggle vue3 * vue3 @input migration * fix: payment extra and payment hash * fix dynamic fields and ext db migration * remove shadow on cards in dark theme * screwed up and made more css pushes to this branch * attempt to make chip component in settings dynamic fields * dynamic chips * qrscanner * clean init admin settings * make get_user better * add dbversion model * remove update_payment_status/extra/details * traces for value and assertion errors * refactor services * add PaymentFiatAmount * return Payment on api endpoints * rename to get_user_from_account * refactor: just refactor (#2740) * rc5 * Fix db cache (#2741) * [refactor] split services.py (#2742) * refactor: spit `core.py` (#2743) * refactor: make QR more customizable * fix: print.html * fix: qrcode options * fix: white shadow on dark theme * fix: datetime wasnt parsed in dict_to_model * add timezone for conversion * only parse timestamp for sqlite, postgres does it * log internal payment success * fix: export wallet to phone QR * Adding a customisable border theme, like gradient (#2746) * fixed mobile scan btn * fix test websocket * fix get_payments tests * dict_to_model skip none values * preimage none instead of defaulting to 0000... * fixup test real invoice tests * fixed pheonixd for wss * fix nodemanager test settings * fix lnbits funding * only insert extension when they dont exist --------- Co-authored-by: Vlad Stan <stan.v.vlad@gmail.com> Co-authored-by: Tiago Vasconcelos <talvasconcelos@gmail.com> Co-authored-by: Arc <ben@arc.wales> Co-authored-by: Arc <33088785+arcbtc@users.noreply.github.com>
39 lines
1 KiB
Python
39 lines
1 KiB
Python
from typing import Optional
|
|
|
|
from lnbits.core.db import db
|
|
from lnbits.db import Connection
|
|
|
|
from ..models import DbVersion
|
|
|
|
|
|
async def get_db_version(
|
|
ext_id: str, conn: Optional[Connection] = None
|
|
) -> Optional[DbVersion]:
|
|
return await (conn or db).fetchone(
|
|
"SELECT * FROM dbversions WHERE db = :ext_id",
|
|
{"ext_id": ext_id},
|
|
model=DbVersion,
|
|
)
|
|
|
|
|
|
async def get_db_versions(conn: Optional[Connection] = None) -> list[DbVersion]:
|
|
return await (conn or db).fetchall("SELECT * FROM dbversions", model=DbVersion)
|
|
|
|
|
|
async def update_migration_version(conn, db_name, version):
|
|
await (conn or db).execute(
|
|
"""
|
|
INSERT INTO dbversions (db, version) VALUES (:db, :version)
|
|
ON CONFLICT (db) DO UPDATE SET version = :version
|
|
""",
|
|
{"db": db_name, "version": version},
|
|
)
|
|
|
|
|
|
async def delete_dbversion(*, ext_id: str, conn: Optional[Connection] = None) -> None:
|
|
await (conn or db).execute(
|
|
"""
|
|
DELETE FROM dbversions WHERE db = :ext
|
|
""",
|
|
{"ext": ext_id},
|
|
)
|