|
| 1 | +import type { ReactNode } from 'react' |
1 | 2 | import React from 'react'
|
2 | 3 |
|
3 | 4 | import type { AuthProviderState } from './AuthProviderState'
|
4 | 5 | import { defaultAuthProviderState } from './AuthProviderState'
|
5 | 6 |
|
6 |
| -export const ServerAuthContext = React.createContext< |
7 |
| - AuthProviderState<never> & { |
8 |
| - encryptedSession: string | null |
9 |
| - cookieHeader?: string |
| 7 | +export type ServerAuthState = AuthProviderState<never> & { |
| 8 | + // Used by AuthProvider in getToken. We can probably remove this |
| 9 | + encryptedSession?: string | null |
| 10 | + cookieHeader?: string |
| 11 | +} |
| 12 | + |
| 13 | +/** |
| 14 | + * On the server, it resolve to the defaultAuthProviderState first |
| 15 | + */ |
| 16 | +export const ServerAuthContext = React.createContext<ServerAuthState>( |
| 17 | + globalThis?.__REDWOOD__SERVER__AUTH_STATE__ || { |
| 18 | + ...defaultAuthProviderState, |
| 19 | + encryptedSession: null, |
10 | 20 | }
|
11 |
| ->({ ...defaultAuthProviderState, encryptedSession: null }) |
| 21 | +) |
| 22 | + |
| 23 | +/*** |
| 24 | + * Note: This only gets rendered on the server and serves two purposes: |
| 25 | + * 1) On the server, it sets the auth state |
| 26 | + * 2) On the client, it restores the auth state from the initial server render |
| 27 | + */ |
| 28 | +export const ServerAuthProvider = ({ |
| 29 | + value, |
| 30 | + children, |
| 31 | +}: { |
| 32 | + value: ServerAuthState |
| 33 | + children?: ReactNode[] |
| 34 | +}) => { |
| 35 | + // @NOTE: we "Sanitize" to remove encryptedSession and cookieHeader |
| 36 | + // not totally necessary, but it's nice to not have them in the DOM |
| 37 | + // @MARK: needs discussion! |
| 38 | + const stringifiedAuthState = `__REDWOOD__SERVER__AUTH_STATE__ = ${JSON.stringify( |
| 39 | + sanitizeServerAuthState(value) |
| 40 | + )};` |
| 41 | + |
| 42 | + return ( |
| 43 | + <> |
| 44 | + <script |
| 45 | + id="__REDWOOD__SERVER_AUTH_STATE__" |
| 46 | + dangerouslySetInnerHTML={{ |
| 47 | + __html: stringifiedAuthState, |
| 48 | + }} |
| 49 | + /> |
12 | 50 |
|
13 |
| -export const ServerAuthProvider = ServerAuthContext.Provider |
| 51 | + <ServerAuthContext.Provider value={value}> |
| 52 | + {children} |
| 53 | + </ServerAuthContext.Provider> |
| 54 | + </> |
| 55 | + ) |
| 56 | +} |
| 57 | +function sanitizeServerAuthState(value: ServerAuthState) { |
| 58 | + const sanitizedState = { ...value } |
| 59 | + delete sanitizedState.encryptedSession && delete sanitizedState.cookieHeader |
| 60 | + return sanitizedState |
| 61 | +} |
0 commit comments