From 69e62229d835dc13c22466424cf70626ce238de0 Mon Sep 17 00:00:00 2001 From: ekzyis Date: Sat, 20 Jan 2024 23:48:38 +0100 Subject: [PATCH] Fix stale cursor used on reconnect --- worker/wallet.js | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/worker/wallet.js b/worker/wallet.js index 99bd10bd7..a91c8edf9 100644 --- a/worker/wallet.js +++ b/worker/wallet.js @@ -22,11 +22,16 @@ function subscribeForever (subscribe) { let sub try { return await new Promise((resolve, reject) => { - sub = subscribe(resolve, bail) + const sub = subscribe(resolve, bail) if (!sub) { - return bail(new Error('function passed to subscribeForever must return a subscription object')) + return bail(new Error('function passed to subscribeForever must return a subscription object or promise')) + } + if (sub.then) { + // sub is promise + sub.then(sub => sub.on('error', reject)) + } else { + sub.on('error', reject) } - sub.on('error', reject) }) } catch (error) { console.error(error) @@ -45,13 +50,12 @@ const logEventError = (name, error) => console.error(`error running ${name}`, er async function subscribeToDeposits (args) { const { models, lnd } = args - const [lastConfirmed] = await models.$queryRaw` + subscribeForever(async () => { + const [lastConfirmed] = await models.$queryRaw` SELECT "confirmedIndex" FROM "Invoice" ORDER BY "confirmedIndex" DESC NULLS LAST LIMIT 1` - - subscribeForever(() => { const sub = subscribeToInvoices({ lnd, confirmed_after: lastConfirmed?.confirmedIndex }) sub.on('invoice_updated', async (inv) => {