From 3f51fadec926902721570ff5870521b674cb54cd Mon Sep 17 00:00:00 2001 From: Wan Qi Chen <495709+wa0x6e@users.noreply.github.com> Date: Tue, 16 Jan 2024 15:00:22 +0700 Subject: [PATCH 1/3] fix: show error message when params is an Error object --- src/api.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/api.ts b/src/api.ts index 3d634a7d..00e4a944 100644 --- a/src/api.ts +++ b/src/api.ts @@ -42,10 +42,10 @@ router.get('/scores/:proposalId', async (req, res) => { try { const result = await serve(proposalId, updateProposalAndVotes, [proposalId]); return res.json({ result }); - } catch (e) { + } catch (e: any) { capture(e); log.warn(`[api] updateProposalAndVotes() failed ${proposalId}, ${JSON.stringify(e)}`); - return res.json({ error: 'failed', message: e }); + return res.json({ error: 'failed', message: e.message || e }); } }); From d04b67acbb96880d9b542f1181735bc7ae3338c9 Mon Sep 17 00:00:00 2001 From: Wan Qi Chen <495709+wa0x6e@users.noreply.github.com> Date: Tue, 16 Jan 2024 15:02:01 +0700 Subject: [PATCH 2/3] fix: mark proposal scores as invalid when score is out of range --- src/scores.ts | 25 ++++++++++++++++++++----- 1 file changed, 20 insertions(+), 5 deletions(-) diff --git a/src/scores.ts b/src/scores.ts index d2780bbf..1bad33a5 100644 --- a/src/scores.ts +++ b/src/scores.ts @@ -96,6 +96,11 @@ async function updateProposalScores(proposalId: string, scores: any, votes: numb ]); } +async function invalidateProposalScore(proposalId: string) { + const query = `UPDATE proposals SET scores_state = ? WHERE id = ? LIMIT 1;`; + await db.queryAsync(query, ['invalid', proposalId]); +} + const pendingRequests = {}; export async function updateProposalAndVotes(proposalId: string, force = false) { @@ -114,7 +119,7 @@ export async function updateProposalAndVotes(proposalId: string, force = false) (proposal.votes > 30000 && proposal.scores_updated > ts - 300) || pendingRequests[proposalId] ) { - console.log( + log.info( 'ignore score calculation', proposal.space, proposalId, @@ -171,10 +176,20 @@ export async function updateProposalAndVotes(proposalId: string, force = false) if (!isFinal) await updateVotesVp(votes, vpState, proposalId); // Store scores - await updateProposalScores(proposalId, results, votes.length); - log.info( - `[scores] Proposal updated ${proposal.id}, ${proposal.space}, ${results.scores_state}, ${votes.length}` - ); + try { + await updateProposalScores(proposalId, results, votes.length); + log.info( + `[scores] Proposal updated ${proposal.id}, ${proposal.space}, ${results.scores_state}, ${votes.length}` + ); + } catch (e: any) { + if (proposal.state === 'closed' && e.code === 'ER_WARN_DATA_OUT_OF_RANGE') { + log.info(`[scores] Invalid final scores_total: ${results.scores_total}`, e); + await invalidateProposalScore(proposalId); + throw new Error('Invalid out of range score'); + } else { + throw e; + } + } delete pendingRequests[proposalId]; return true; From f5f90ae1d60afeaed82455261225dc693cc3fd63 Mon Sep 17 00:00:00 2001 From: Wan Qi Chen <495709+wa0x6e@users.noreply.github.com> Date: Tue, 16 Jan 2024 15:38:11 +0700 Subject: [PATCH 3/3] fix: always return out-of-range error, regardless of proposal state --- src/scores.ts | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/scores.ts b/src/scores.ts index 1bad33a5..4ce5ef06 100644 --- a/src/scores.ts +++ b/src/scores.ts @@ -182,9 +182,11 @@ export async function updateProposalAndVotes(proposalId: string, force = false) `[scores] Proposal updated ${proposal.id}, ${proposal.space}, ${results.scores_state}, ${votes.length}` ); } catch (e: any) { - if (proposal.state === 'closed' && e.code === 'ER_WARN_DATA_OUT_OF_RANGE') { + if (e.code === 'ER_WARN_DATA_OUT_OF_RANGE') { log.info(`[scores] Invalid final scores_total: ${results.scores_total}`, e); - await invalidateProposalScore(proposalId); + if (proposal.state === 'closed') { + await invalidateProposalScore(proposalId); + } throw new Error('Invalid out of range score'); } else { throw e;