From fdbe14d19592beba012a8e13594e5c20d1e273c2 Mon Sep 17 00:00:00 2001 From: ekzyis Date: Thu, 19 Dec 2024 18:31:11 +0100 Subject: [PATCH] Fix send-only wallet save after device sync enabled (#1732) * Rename walletData to recvConfig * Use nested upsert during wallet update --- api/resolvers/wallet.js | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/api/resolvers/wallet.js b/api/resolvers/wallet.js index 5621d946..ff1f1782 100644 --- a/api/resolvers/wallet.js +++ b/api/resolvers/wallet.js @@ -786,7 +786,7 @@ async function upsertWallet ( } } - const { id, enabled, priority, ...walletData } = data + const { id, enabled, priority, ...recvConfig } = data const txs = [] @@ -806,13 +806,13 @@ async function upsertWallet ( data: { enabled, priority, - // client only wallets has no walletData - ...(Object.keys(walletData).length > 0 + // client only wallets have no receive config and thus don't have their own table + ...(Object.keys(recvConfig).length > 0 ? { [wallet.field]: { - update: { - where: { walletId: Number(id) }, - data: walletData + upsert: { + create: recvConfig, + update: recvConfig } } } @@ -851,8 +851,8 @@ async function upsertWallet ( priority, userId: me.id, type: wallet.type, - // client only wallets has no walletData - ...(Object.keys(walletData).length > 0 ? { [wallet.field]: { create: walletData } } : {}), + // client only wallets have no receive config and thus don't have their own table + ...(Object.keys(recvConfig).length > 0 ? { [wallet.field]: { create: recvConfig } } : {}), ...(vaultEntries ? { vaultEntries: { @@ -876,7 +876,7 @@ async function upsertWallet ( ) } - if (canReceive({ def: walletDef, config: walletData })) { + if (canReceive({ def: walletDef, config: recvConfig })) { txs.push( models.walletLog.createMany({ data: {