From fd04af82ce7ed71b5d3081823ffe9d952f6e7f29 Mon Sep 17 00:00:00 2001 From: Roma Sosnovsky Date: Sun, 19 May 2024 04:27:40 +0300 Subject: [PATCH] #5715 Fix id token fetch for exception reports (#5717) * #5715 Fix id token fetch for exception reports * pr review --- extension/chrome/settings/setup.ts | 2 +- extension/js/common/platform/catch.ts | 15 ++++++++------- test/source/tests/compose.ts | 2 +- test/source/tests/flaky.ts | 2 +- test/source/tests/setup.ts | 2 +- 5 files changed, 12 insertions(+), 11 deletions(-) diff --git a/extension/chrome/settings/setup.ts b/extension/chrome/settings/setup.ts index 4d5266f0bd3..cc3ee8862a0 100644 --- a/extension/chrome/settings/setup.ts +++ b/extension/chrome/settings/setup.ts @@ -397,7 +397,7 @@ export class SetupView extends View { return; } if (!armoredPubkey) { - await Ui.modal.warning('Public key not usable - not sumbitting to Attester'); + await Ui.modal.warning('Public key not usable - not submitting to Attester'); return; } const pub = await KeyUtil.parse(armoredPubkey); diff --git a/extension/js/common/platform/catch.ts b/extension/js/common/platform/catch.ts index 2e7dcce6c95..47bac3e8d4a 100644 --- a/extension/js/common/platform/catch.ts +++ b/extension/js/common/platform/catch.ts @@ -4,6 +4,7 @@ import { Url } from '../core/common.js'; import { FLAVOR, InMemoryStoreKeys, SHARED_TENANT_API_HOST, VERSION } from '../core/const.js'; +import { GlobalStore } from './store/global-store.js'; import { InMemoryStore } from './store/in-memory-store.js'; export class UnreportableError extends Error {} @@ -283,8 +284,8 @@ export class Catch { private static formatExceptionForReport(thrown: unknown, line?: number, col?: number): ErrorReport { if (!line || !col) { const { line: parsedLine, col: parsedCol } = Catch.getErrorLineAndCol(thrown); - line = parsedLine; - col = parsedCol; + line = parsedLine > 0 ? parsedLine : 1; + col = parsedCol > 0 ? parsedCol : 1; } if (thrown instanceof Error) { // reporting stack may differ from the stack of the actual error, both may be interesting @@ -299,8 +300,8 @@ export class Catch { name: exception.name.substring(0, 50), message: exception.message.substring(0, 200), url: location.href.split('?')[0], - line: line || 0, - col: col || 0, + line: line || 1, + col: col || 1, trace: exception.stack || '', version: VERSION, environment: Catch.RUNTIME_ENVIRONMENT, @@ -311,8 +312,8 @@ export class Catch { private static async doSendErrorToSharedTenantFes(errorReport: ErrorReport) { try { - const uncheckedUrlParams = Url.parse(['acctEmail']); - const acctEmail = String(uncheckedUrlParams.acctEmail); + const { acctEmail: parsedEmail } = Url.parse(['acctEmail']); + const acctEmail = parsedEmail ? String(parsedEmail) : (await GlobalStore.acctEmailsGet())?.[0]; if (!acctEmail) { console.error('Not reporting error because user is not logged in'); return; @@ -376,7 +377,7 @@ export class Catch { // eslint-disable-next-line @typescript-eslint/no-non-null-assertion return { line: Number(matched![1]), col: Number(matched![2]) }; } catch (lineErr) { - return { line: 0, col: 0 }; + return { line: 1, col: 1 }; } } diff --git a/test/source/tests/compose.ts b/test/source/tests/compose.ts index e6161d9fdfd..e9c8074841d 100644 --- a/test/source/tests/compose.ts +++ b/test/source/tests/compose.ts @@ -3271,7 +3271,7 @@ export const defineComposeTests = (testVariant: TestVariant, testWithBrowser: Te const acct = 'revoked@key-manager-autoimport-no-prv-create.flowcrypt.test'; const settingsPage = await BrowserRecipe.openSettingsLoginApprove(t, browser, acct); await SetupPageRecipe.autoSetupWithEKM(settingsPage, { - expectWarnModal: 'Public key not usable - not sumbitting to Attester', + expectWarnModal: 'Public key not usable - not submitting to Attester', }); }) ); diff --git a/test/source/tests/flaky.ts b/test/source/tests/flaky.ts index d6729c18069..ee277b79d75 100644 --- a/test/source/tests/flaky.ts +++ b/test/source/tests/flaky.ts @@ -61,7 +61,7 @@ export const defineFlakyTests = (testVariant: TestVariant, testWithBrowser: Test clickOn: 'confirm', }); await SettingsPageRecipe.waitForModalAndRespond(settingsPage, 'warning', { - contentToCheck: 'Public key not usable - not sumbitting to Attester', + contentToCheck: 'Public key not usable - not submitting to Attester', clickOn: 'confirm', }); await settingsPage.waitAndClick('@action-step4done-account-settings'); diff --git a/test/source/tests/setup.ts b/test/source/tests/setup.ts index ae556aa5eaa..20567e984b5 100644 --- a/test/source/tests/setup.ts +++ b/test/source/tests/setup.ts @@ -888,7 +888,7 @@ AN8G3r5Htj8olot+jm9mIa5XLXWzMNUZgg== }, }); const settingsPage = await BrowserRecipe.openSettingsLoginApprove(t, browser, acctEmail); - await SetupPageRecipe.autoSetupWithEKM(settingsPage, { expectWarnModal: 'Public key not usable - not sumbitting to Attester' }); + await SetupPageRecipe.autoSetupWithEKM(settingsPage, { expectWarnModal: 'Public key not usable - not submitting to Attester' }); const gmailPage = await openMockGmailPage(t, browser, acctEmail); // Check if notification presents let warningMsg =