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.
This commit is contained in:
ekzyis 2023-12-20 15:52:01 +01:00
parent 703d7e3cb5
commit 09b468660b
1 changed files with 7 additions and 1 deletions

View File

@ -10,6 +10,7 @@ import { UserListRow } from './user-list'
const AccountContext = createContext() const AccountContext = createContext()
const b64Decode = str => Buffer.from(str, 'base64').toString('utf-8') const b64Decode = str => Buffer.from(str, 'base64').toString('utf-8')
const b64Encode = obj => Buffer.from(JSON.stringify(obj)).toString('base64')
export const AccountProvider = ({ children }) => { export const AccountProvider = ({ children }) => {
const { me } = useMe() const { me } = useMe()
@ -21,8 +22,13 @@ export const AccountProvider = ({ children }) => {
const { multi_auth: multiAuthCookie } = cookie.parse(document.cookie) const { multi_auth: multiAuthCookie } = cookie.parse(document.cookie)
const accounts = multiAuthCookie const accounts = multiAuthCookie
? JSON.parse(b64Decode(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) 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) { } catch (err) {
console.error('error parsing cookies:', err) console.error('error parsing cookies:', err)
} }