From 09b468660b068f66bab57d28dd5e83a8d28e4840 Mon Sep 17 00:00:00 2001 From: ekzyis Date: Wed, 20 Dec 2023 15:52:01 +0100 Subject: [PATCH] Fix missing multi_auth cookie in existing sessions This makes this feature backwards compatible. Existing sessions were missing the multi_auth cookie since they didn't go through the new login flow were the cookie gets set. --- components/switch-account.js | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/components/switch-account.js b/components/switch-account.js index 57985128..10ad37a9 100644 --- a/components/switch-account.js +++ b/components/switch-account.js @@ -10,6 +10,7 @@ import { UserListRow } from './user-list' const AccountContext = createContext() const b64Decode = str => Buffer.from(str, 'base64').toString('utf-8') +const b64Encode = obj => Buffer.from(JSON.stringify(obj)).toString('base64') export const AccountProvider = ({ children }) => { const { me } = useMe() @@ -21,8 +22,13 @@ export const AccountProvider = ({ children }) => { const { multi_auth: multiAuthCookie } = cookie.parse(document.cookie) const accounts = multiAuthCookie ? JSON.parse(b64Decode(multiAuthCookie)) - : me ? [{ id: me.id, name: me.name, photoId: me.photoId }] : [] + : me ? [{ id: Number(me.id), name: me.name, photoId: me.photoId }] : [] setAccounts(accounts) + // required for backwards compatibility: sync cookie with accounts if no multi auth cookie exists + // this is the case for sessions that existed before we deployed account switching + if (!multiAuthCookie && !!me) { + document.cookie = `multi_auth=${b64Encode(accounts)}; Path=/; Secure` + } } catch (err) { console.error('error parsing cookies:', err) }