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 pydantic import BaseModel
|
||||
|
||||
from lnbits.db import Connection
|
||||
from lnbits.helpers import url_for
|
||||
from lnbits.settings import WALLET
|
||||
from lnbits.wallets.base import PaymentStatus
|
||||
|
|
@ -131,7 +132,11 @@ class Payment(BaseModel):
|
|||
def is_uncheckable(self) -> bool:
|
||||
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
|
||||
|
||||
await update_payment_details(
|
||||
|
|
@ -139,6 +144,7 @@ class Payment(BaseModel):
|
|||
pending=status.pending,
|
||||
fee=status.fee_msat,
|
||||
preimage=status.preimage,
|
||||
conn=conn,
|
||||
)
|
||||
|
||||
async def set_pending(self, pending: bool) -> None:
|
||||
|
|
@ -146,7 +152,10 @@ class Payment(BaseModel):
|
|||
|
||||
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:
|
||||
return PaymentStatus(None)
|
||||
|
||||
|
|
@ -170,7 +179,7 @@ class Payment(BaseModel):
|
|||
logger.info(
|
||||
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
|
||||
|
||||
async def delete(self) -> None:
|
||||
|
|
|
|||
|
|
@ -103,7 +103,7 @@ async def check_pending_payments():
|
|||
conn=conn,
|
||||
)
|
||||
for payment in pending_payments:
|
||||
await payment.check_status()
|
||||
await payment.check_status(conn=conn)
|
||||
|
||||
logger.debug(
|
||||
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