a103a2ee2c
* Set a cookie with an up-to-date Firebase ID token * Implement server-side authentication cookie reading logic * Change index page to redirect for authed users * No branch necessary for logged in users on index page * Add helpers for creating server-side redirects * Add some common sense redirects
27 lines
864 B
TypeScript
27 lines
864 B
TypeScript
type CookieOptions = string[][]
|
|
|
|
const encodeCookie = (name: string, val: string) => {
|
|
return `${name}=${encodeURIComponent(val)}`
|
|
}
|
|
|
|
const decodeCookie = (cookie: string) => {
|
|
const parts = cookie.trim().split('=')
|
|
if (parts.length != 2) {
|
|
throw new Error(`Invalid cookie contents: ${cookie}`)
|
|
}
|
|
return [parts[0], decodeURIComponent(parts[1])] as const
|
|
}
|
|
|
|
export const setCookie = (name: string, val: string, opts?: CookieOptions) => {
|
|
const parts = [encodeCookie(name, val)]
|
|
if (opts != null) {
|
|
parts.push(...opts.map((opt) => opt.join('=')))
|
|
}
|
|
return parts.join('; ')
|
|
}
|
|
|
|
// Note that this intentionally ignores the case where multiple cookies have
|
|
// the same name but different paths. Hopefully we never need to think about it.
|
|
export const getCookies = (cookies: string) =>
|
|
Object.fromEntries(cookies.split(';').map(decodeCookie))
|