Use base64 encoding for multi_auth cookie

This commit is contained in:
ekzyis 2023-11-19 03:04:29 +01:00
parent 470e0dfc7a
commit 24168f556e
2 changed files with 13 additions and 7 deletions

View File

@ -8,16 +8,22 @@ import Link from 'next/link'
const AccountContext = createContext() const AccountContext = createContext()
const b64Decode = str => Buffer.from(str, 'base64').toString('utf-8')
export const AccountProvider = ({ children }) => { export const AccountProvider = ({ children }) => {
const me = useMe() const me = useMe()
const [accounts, setAccounts] = useState() const [accounts, setAccounts] = useState()
useEffect(() => { useEffect(() => {
const { multi_auth: multiAuthCookie } = cookie.parse(document.cookie) try {
const accounts = multiAuthCookie const { multi_auth: multiAuthCookie } = cookie.parse(document.cookie)
? JSON.parse(multiAuthCookie) const accounts = multiAuthCookie
: me ? [{ id: me.id, name: me.name, photoId: me.photoId }] : [] ? JSON.parse(b64Decode(multiAuthCookie))
setAccounts(accounts) : me ? [{ id: me.id, name: me.name, photoId: me.photoId }] : []
setAccounts(accounts)
} catch (err) {
console.error('error parsing cookies:', err)
}
}, []) }, [])
const addAccount = useCallback(user => { const addAccount = useCallback(user => {

View File

@ -123,10 +123,10 @@ async function pubkeyAuth (credentials, req, res, pubkeyColumnName) {
res.appendHeader('Set-Cookie', cookie.serialize(`multi_auth.${me.id}`, tokenJWT, cookieOptions)) res.appendHeader('Set-Cookie', cookie.serialize(`multi_auth.${me.id}`, tokenJWT, cookieOptions))
res.appendHeader('Set-Cookie', res.appendHeader('Set-Cookie',
cookie.serialize('multi_auth', cookie.serialize('multi_auth',
JSON.stringify([ Buffer.from(JSON.stringify([
{ id: user.id, name: user.name, photoId: user.photoId }, { id: user.id, name: user.name, photoId: user.photoId },
{ id: me.id, name: me.name, photoId: me.photoId } { id: me.id, name: me.name, photoId: me.photoId }
]), ])).toString('base64'),
{ ...cookieOptions, httpOnly: false })) { ...cookieOptions, httpOnly: false }))
// don't switch accounts, we only want to add. switching is done in client via "pointer cookie" // don't switch accounts, we only want to add. switching is done in client via "pointer cookie"
return token return token