From 6eab66050608a1bc5cb9aca6a234b1fea16106e5 Mon Sep 17 00:00:00 2001 From: Nikos Douvlis Date: Tue, 27 Feb 2024 18:27:05 +0200 Subject: [PATCH] fix(shared): Remove legacy __dev_session from URL search params (#2867) --- .changeset/witty-jokes-repair.md | 6 ++++++ packages/shared/src/devBrowser.ts | 9 ++++++--- 2 files changed, 12 insertions(+), 3 deletions(-) create mode 100644 .changeset/witty-jokes-repair.md diff --git a/.changeset/witty-jokes-repair.md b/.changeset/witty-jokes-repair.md new file mode 100644 index 0000000000..64ba783b1d --- /dev/null +++ b/.changeset/witty-jokes-repair.md @@ -0,0 +1,6 @@ +--- +'@clerk/shared': patch +'@clerk/clerk-js': patch +--- + +Remove legacy \_\_dev_session from URL search params diff --git a/packages/shared/src/devBrowser.ts b/packages/shared/src/devBrowser.ts index 7e11c08fb0..077494edf6 100644 --- a/packages/shared/src/devBrowser.ts +++ b/packages/shared/src/devBrowser.ts @@ -37,7 +37,7 @@ const readDevBrowserJwtFromSearchParams = (url: URL) => { }; const removeDevBrowserJwt = (url: URL) => { - return removeDevBrowserJwtFromURLSearchParams(removeLegacyDevBrowserJwtFromURLHash(new URL(url))); + return removeDevBrowserJwtFromURLSearchParams(removeLegacyDevBrowserJwt(url)); }; const removeDevBrowserJwtFromURLSearchParams = (_url: URL) => { @@ -47,7 +47,8 @@ const removeDevBrowserJwtFromURLSearchParams = (_url: URL) => { }; /** - * Removes the __clerk_db_jwt JWT from the URL hash. + * Removes the __clerk_db_jwt JWT from the URL hash, as well as + * the legacy __dev_session JWT from the URL searchParams * We no longer need to use this value, however, we should remove it from the URL * Existing v4 apps will write the JWT to the hash and the search params in order to ensure * backwards compatibility with older v4 apps. @@ -56,9 +57,11 @@ const removeDevBrowserJwtFromURLSearchParams = (_url: URL) => { * In this scenario, the AP@4 -> localhost@5 redirect will still have the JWT in the hash, * in which case we need to remove it. */ -const removeLegacyDevBrowserJwtFromURLHash = (_url: URL) => { +const removeLegacyDevBrowserJwt = (_url: URL) => { const DEV_BROWSER_JWT_MARKER_REGEXP = /__clerk_db_jwt\[(.*)\]/; + const DEV_BROWSER_JWT_LEGACY_KEY = '__dev_session'; const url = new URL(_url); + url.searchParams.delete(DEV_BROWSER_JWT_LEGACY_KEY); url.hash = url.hash.replace(DEV_BROWSER_JWT_MARKER_REGEXP, ''); if (url.href.endsWith('#')) { url.hash = '';