Fix/db reuse connection mark pending (#964)
* check if wallet exists * check wallet existence in key check * reuse connection for stataus update * make format
This commit is contained in:
parent
1660b9dcf1
commit
d0ca0b18da
2 changed files with 13 additions and 4 deletions
|
|
@ -9,6 +9,7 @@ from lnurl import encode as lnurl_encode # type: ignore
|
||||||
from loguru import logger
|
from loguru import logger
|
||||||
from pydantic import BaseModel
|
from pydantic import BaseModel
|
||||||
|
|
||||||
|
from lnbits.db import Connection
|
||||||
from lnbits.helpers import url_for
|
from lnbits.helpers import url_for
|
||||||
from lnbits.settings import WALLET
|
from lnbits.settings import WALLET
|
||||||
from lnbits.wallets.base import PaymentStatus
|
from lnbits.wallets.base import PaymentStatus
|
||||||
|
|
@ -131,7 +132,11 @@ class Payment(BaseModel):
|
||||||
def is_uncheckable(self) -> bool:
|
def is_uncheckable(self) -> bool:
|
||||||
return self.checking_id.startswith("internal_")
|
return self.checking_id.startswith("internal_")
|
||||||
|
|
||||||
async def update_status(self, status: PaymentStatus) -> None:
|
async def update_status(
|
||||||
|
self,
|
||||||
|
status: PaymentStatus,
|
||||||
|
conn: Optional[Connection] = None,
|
||||||
|
) -> None:
|
||||||
from .crud import update_payment_details
|
from .crud import update_payment_details
|
||||||
|
|
||||||
await update_payment_details(
|
await update_payment_details(
|
||||||
|
|
@ -139,6 +144,7 @@ class Payment(BaseModel):
|
||||||
pending=status.pending,
|
pending=status.pending,
|
||||||
fee=status.fee_msat,
|
fee=status.fee_msat,
|
||||||
preimage=status.preimage,
|
preimage=status.preimage,
|
||||||
|
conn=conn,
|
||||||
)
|
)
|
||||||
|
|
||||||
async def set_pending(self, pending: bool) -> None:
|
async def set_pending(self, pending: bool) -> None:
|
||||||
|
|
@ -146,7 +152,10 @@ class Payment(BaseModel):
|
||||||
|
|
||||||
await update_payment_status(self.checking_id, pending)
|
await update_payment_status(self.checking_id, pending)
|
||||||
|
|
||||||
async def check_status(self) -> PaymentStatus:
|
async def check_status(
|
||||||
|
self,
|
||||||
|
conn: Optional[Connection] = None,
|
||||||
|
) -> PaymentStatus:
|
||||||
if self.is_uncheckable:
|
if self.is_uncheckable:
|
||||||
return PaymentStatus(None)
|
return PaymentStatus(None)
|
||||||
|
|
||||||
|
|
@ -170,7 +179,7 @@ class Payment(BaseModel):
|
||||||
logger.info(
|
logger.info(
|
||||||
f"Marking '{'in' if self.is_in else 'out'}' {self.checking_id} as not pending anymore: {status}"
|
f"Marking '{'in' if self.is_in else 'out'}' {self.checking_id} as not pending anymore: {status}"
|
||||||
)
|
)
|
||||||
await self.update_status(status)
|
await self.update_status(status, conn=conn)
|
||||||
return status
|
return status
|
||||||
|
|
||||||
async def delete(self) -> None:
|
async def delete(self) -> None:
|
||||||
|
|
|
||||||
|
|
@ -103,7 +103,7 @@ async def check_pending_payments():
|
||||||
conn=conn,
|
conn=conn,
|
||||||
)
|
)
|
||||||
for payment in pending_payments:
|
for payment in pending_payments:
|
||||||
await payment.check_status()
|
await payment.check_status(conn=conn)
|
||||||
|
|
||||||
logger.debug(
|
logger.debug(
|
||||||
f"Task: pending check finished for {len(pending_payments)} payments (took {time.time() - start_time:0.3f} s)"
|
f"Task: pending check finished for {len(pending_payments)} payments (took {time.time() - start_time:0.3f} s)"
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue