modelence 0.18.0-dev.rn.1 → 0.19.0-email.dev.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/client/localStorage.ts","../src/client/clientConfig.ts","../src/auth/client/index.ts","../src/client/errorHandler.ts","../src/client/method.ts","../src/config/client.ts","../src/client/session.ts","../src/client/AppProvider.tsx","../src/client/module.ts","../src/system/client.ts","../src/client/renderApp.tsx","../src/websocket/socketio/client.ts","../src/websocket/client.ts","../src/websocket/clientChannel.ts","../src/files/client.ts","../src/client.ts"],"names":["getLocalStorageSession","sessionJson","e","setLocalStorageSession","session","config","configureClient","userConfig","getClientConfig","signupWithPassword","options","email","password","handle","firstName","lastName","avatarUrl","callMethod","loginWithPassword","user","setCurrentUser","updateProfile","verifyEmail","token","resendEmailVerification","logout","sendResetPasswordToken","resetPassword","linkOAuthProvider","provider","baseUrl","getAuthToken","url","unlinkOAuthProvider","getClientInfo","errorHandler","error","methodName","setErrorHandler","handler","handleError","MethodError","message","status","args","call","endpoint","response","text","result","reviveResponseTypes","getConfig","key","_setConfig","configs","useSessionStore","create","set","isInitialized","SESSION_HEARTBEAT_INTERVAL","time","userSchema","z","parseUser","parsedData","role","initSession","loopSessionHeartbeat","enrichedUser","useSession","state","AppProvider","children","loadingElement","isLoading","setIsLoading","useState","useEffect","initConfig","jsx","createClientModule","moduleName","name","rest","getArgs","pageParam","systemConfig","renderApp","routesElement","favicon","ReactDOM","React","link","newLink","socketClient","activeLiveSubscriptions","getSocket","resubscribeAll","authToken","clientInfo","sub","init","props","io","channel","on","category","listener","once","off","emit","eventName","id","joinChannel","leaveChannel","liveQueryCounter","subscribeLiveQuery","method","onData","onError","subscriptionId","handleData","sid","data","typeMap","socket","websocketProvider","client_default","websocketClientProvider","setWebsocketClientProvider","getWebsocketClientProvider","startWebsockets","ClientChannel","onMessage","uploadFile","file","filePath","contentType","visibility","fields","resolvedFilePath","formData","value","uploadResponse","deleteFile","downloadFile","getFileUrl"],"mappings":"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","file":"client.js","sourcesContent":["export function getLocalStorageSession() {\n const sessionJson = localStorage.getItem('modelence.session');\n try {\n return sessionJson ? JSON.parse(sessionJson) : null;\n } catch (e) {\n console.error('Error parsing session from localStorage', e);\n return null;\n }\n}\n\nexport function setLocalStorageSession(session: object) {\n localStorage.setItem('modelence.session', JSON.stringify(session));\n}\n","import type { ClientInfo } from '@/methods/types';\n\nexport interface ClientConfig {\n baseUrl: string;\n getAuthToken: () => string | undefined;\n setAuthToken: (token: string | null) => void;\n getClientInfo: () => ClientInfo;\n /**\n * Opens an external URL (used for OAuth redirects). Defaults to\n * `window.location.href` assignment when not provided. React Native apps\n * should pass `(url) => Linking.openURL(url)`.\n */\n openUrl?: (url: string) => void;\n}\n\nlet config: ClientConfig | null = null;\n\n/**\n * Configure the Modelence client for non-browser environments like React Native.\n *\n * When configured, the client uses the provided functions for auth-token\n * storage, client-info collection, and URL resolution instead of the\n * default browser APIs (localStorage, window.screen, relative URLs).\n *\n * @example\n * ```ts\n * import { configureClient } from 'modelence/client';\n *\n * let authToken: string | undefined;\n *\n * configureClient({\n * baseUrl: 'https://myapp.com',\n * getAuthToken: () => authToken,\n * setAuthToken: (token) => { authToken = token ?? undefined; },\n * getClientInfo: () => ({\n * screenWidth: Dimensions.get('screen').width,\n * screenHeight: Dimensions.get('screen').height,\n * windowWidth: Dimensions.get('window').width,\n * windowHeight: Dimensions.get('window').height,\n * pixelRatio: PixelRatio.get(),\n * orientation: null,\n * }),\n * });\n * ```\n */\nexport function configureClient(userConfig: ClientConfig) {\n config = userConfig;\n}\n\nexport function getClientConfig(): ClientConfig | null {\n return config;\n}\n","import { setCurrentUser } from '@/client/session';\nimport { callMethod } from '@/client/method';\nimport { getLocalStorageSession } from '@/client/localStorage';\nimport { getClientConfig } from '@/client/clientConfig';\nimport type { ClientInfo } from '@/methods/types';\nimport { OAuthProvider } from '../types';\n\nexport type UserInfo = {\n id: string;\n handle: string;\n roles: string[];\n hasRole: (role: string) => boolean;\n requireRole: (role: string) => void;\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n};\n\ntype RawUserData = {\n id: string;\n handle: string;\n roles: string[];\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n};\n\n/**\n * Sign up a new user with an email and password.\n *\n * @example\n * ```ts\n * await signupWithPassword({ email: 'test@example.com', password: '12345678' });\n * await signupWithPassword({ email: 'test@example.com', password: '12345678', handle: 'myhandle', firstName: 'John' });\n * ```\n * @param options.email - The email of the user.\n * @param options.password - The password of the user.\n * @param options.handle - Optional custom handle. If omitted, one is derived from the email.\n * @param options.firstName - Optional first name.\n * @param options.lastName - Optional last name.\n * @param options.avatarUrl - Optional avatar URL.\n */\nexport async function signupWithPassword(options: {\n email: string;\n password: string;\n handle?: string;\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n}) {\n const { email, password, handle, firstName, lastName, avatarUrl } = options;\n await callMethod('_system.user.signupWithPassword', {\n email,\n password,\n ...(handle !== undefined ? { handle } : {}),\n ...(firstName !== undefined ? { firstName } : {}),\n ...(lastName !== undefined ? { lastName } : {}),\n ...(avatarUrl !== undefined ? { avatarUrl } : {}),\n });\n}\n\n/**\n * Login a user with an email and password.\n *\n * @example\n * ```ts\n * await loginWithPassword({ email: 'test@example.com', password: '12345678' });\n * ```\n * @param options.email - The email of the user.\n * @param options.password - The password of the user.\n */\nexport async function loginWithPassword(options: { email: string; password: string }) {\n const { email, password } = options;\n const { user, session } = await callMethod<{ user: RawUserData; session: { authToken: string } }>(\n '_system.user.loginWithPassword',\n {\n email,\n password,\n }\n );\n const config = getClientConfig();\n if (config) {\n config.setAuthToken(session.authToken);\n }\n const enrichedUser = setCurrentUser(user);\n return enrichedUser;\n}\n\n/**\n * Update the current user's profile.\n *\n * @example\n * ```ts\n * await updateProfile({ firstName: 'Atul', lastName: 'Yadav', avatarUrl: 'https://example.com/avatar.jpg', handle: 'atulyadav' });\n * ```\n * @param options.firstName - The first name of the user.\n * @param options.lastName - The last name of the user.\n * @param options.avatarUrl - The avatar URL of the user.\n * @param options.handle - The handle of the user.\n */\nexport async function updateProfile(options: {\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n handle?: string;\n}) {\n const { firstName, lastName, avatarUrl, handle } = options;\n const { user } = await callMethod<{ user: RawUserData }>('_system.user.updateProfile', {\n ...(firstName !== undefined ? { firstName } : {}),\n ...(lastName !== undefined ? { lastName } : {}),\n ...(avatarUrl !== undefined ? { avatarUrl } : {}),\n ...(handle !== undefined ? { handle } : {}),\n });\n const enrichedUser = setCurrentUser(user);\n return enrichedUser;\n}\n\n/**\n * Verify user's email with a verification token.\n *\n * @example\n * ```ts\n * await verifyEmail({ token: 'verification-token' });\n * ```\n * @param options.token - The email verification token.\n */\nexport async function verifyEmail(options: { token: string }) {\n const { token } = options;\n await callMethod<{ user: RawUserData }>('_system.user.verifyEmail', { token });\n}\n\n/**\n * Resend the verification email for a given email address.\n * The email is only sent if the address is registered and not yet verified.\n * A generic response is always returned to avoid leaking account information.\n *\n * @example\n * ```ts\n * await resendEmailVerification({ email: 'user@example.com' });\n * ```\n * @param options.email - The email address to resend verification to.\n */\nexport async function resendEmailVerification(options: { email: string }) {\n const { email } = options;\n await callMethod('_system.user.resendEmailVerification', { email });\n}\n\n/**\n * Logout the current user.\n *\n */\nexport async function logout() {\n await callMethod('_system.user.logout');\n const config = getClientConfig();\n if (config) {\n config.setAuthToken(null);\n }\n setCurrentUser(null);\n}\n\n/**\n * Send reset password token.\n * @param options.email - The email of the user.\n */\nexport async function sendResetPasswordToken(options: { email: string }) {\n const { email } = options;\n await callMethod('_system.user.sendResetPasswordToken', {\n email,\n });\n}\n\n/**\n * Reset password.\n * @param options.token - The password reset token.\n * @param options.password - The new password.\n */\nexport async function resetPassword(options: { token: string; password: string }) {\n const { token, password } = options;\n await callMethod('_system.user.resetPassword', {\n token,\n password,\n });\n}\n\n/**\n * Link an OAuth provider to the currently signed-in user's account.\n * Redirects the browser to the OAuth provider's authorization page.\n * The provider will redirect back and the account will be linked.\n *\n * @example\n * ```ts\n * linkOAuthProvider({ provider: 'google' });\n * ```\n * @param options.provider - The OAuth provider to link ('google' or 'github').\n */\nexport async function linkOAuthProvider(options: { provider: OAuthProvider }): Promise<void> {\n const { provider } = options;\n const config = getClientConfig();\n const baseUrl = config?.baseUrl ?? '';\n\n if (config?.openUrl) {\n // React Native: the system browser has no shared cookie jar with the in-app\n // fetch layer, so we pass the auth token as a URL param instead. The server\n // validates it during OAuth initiation (which runs in the browser) and\n // embeds the resolved userId in its state cookie.\n const token = getAuthToken();\n if (!token) {\n throw new Error('Failed to initialize OAuth linking. Please ensure you are logged in.');\n }\n const url = `${baseUrl}/api/_internal/auth/${provider}?mode=link&authToken=${encodeURIComponent(token)}`;\n config.openUrl(url);\n } else {\n // Browser: set an httpOnly cookie via a same-origin fetch so the token is\n // never exposed to the OAuth provider as a redirect parameter.\n const token = getAuthToken();\n if (token) {\n const response = await fetch(`${baseUrl}/api/_internal/auth/set-link-cookie`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ authToken: token }),\n credentials: 'include',\n });\n if (!response.ok) {\n throw new Error('Failed to initialize OAuth linking. Please ensure you are logged in.');\n }\n }\n window.location.href = `${baseUrl}/api/_internal/auth/${provider}?mode=link`;\n }\n}\n/**\n * Unlink an OAuth provider from the currently signed-in user's account.\n *\n * @example\n * ```ts\n * await unlinkOAuthProvider({ provider: 'github' });\n * ```\n * @param options.provider - The OAuth provider to unlink ('google' or 'github').\n */\nexport async function unlinkOAuthProvider(options: { provider: OAuthProvider }): Promise<void> {\n const { provider } = options;\n await callMethod('_system.user.unlinkOAuthProvider', { provider });\n}\n\n/**\n * Get the current auth token associated with the current session.\n * @returns The auth token or undefined if not authenticated.\n */\nexport function getAuthToken(): string | undefined {\n const config = getClientConfig();\n if (config) {\n return config.getAuthToken();\n }\n return getLocalStorageSession()?.authToken;\n}\n\nexport function getClientInfo(): ClientInfo {\n const config = getClientConfig();\n if (config) {\n return config.getClientInfo();\n }\n return {\n screenWidth: window.screen.width,\n screenHeight: window.screen.height,\n windowWidth: window.innerWidth,\n windowHeight: window.innerHeight,\n pixelRatio: window.devicePixelRatio,\n orientation: window.screen.orientation?.type ?? null,\n };\n}\n","export type ErrorHandler = (error: Error, methodName: string) => void;\n\nlet errorHandler: ErrorHandler = (error, methodName) => {\n console.error(`Error calling method '${methodName}':`, error);\n};\n\nexport function setErrorHandler(handler: ErrorHandler) {\n errorHandler = handler;\n}\n\nexport function handleError(error: Error, methodName: string) {\n return errorHandler(error, methodName);\n}\n","/*\n The \"use client\" directive is specifically for the Next.js layout component, which is rendered on the server by default.\n Because of this, we are explicitly marking it as a client component, so we can render this component on the client\n and properly initialize config on the client side.\n \n While this is specific to Next.js, it is simply ignored outside of Next.js and should not cause errors.\n*/\n'use client';\n\nimport { getAuthToken, getClientInfo } from '@/auth/client';\nimport { handleError } from '@/client/errorHandler';\nimport { getClientConfig } from '@/client/clientConfig';\nimport { reviveResponseTypes } from '@/methods/serialize';\n\nexport class MethodError extends Error {\n status: number;\n\n constructor(message: string, status: number) {\n super(message);\n this.name = 'MethodError';\n this.status = status;\n }\n}\n\nexport type MethodArgs = Record<string, unknown>;\n\nexport type CallMethodOptions = {\n errorHandler?: (error: Error, methodName: string) => void;\n};\n\n/**\n * Calls a server-side method (query or mutation) defined on a Modelence module.\n *\n * Both `args` and `options` are optional. Use the type parameter `T` to type the return value.\n *\n * @example\n * ```typescript\n * import { callMethod } from 'modelence/client';\n *\n * // No arguments\n * const todos = await callMethod<Todo[]>('todo.getAll');\n *\n * // With arguments\n * const todo = await callMethod<Todo>('todo.getOne', { id: '123' });\n *\n * // With a custom error handler\n * const created = await callMethod<Todo>(\n * 'todo.create',\n * { title: 'Buy groceries' },\n * { errorHandler: (error, methodName) => console.error(methodName, error) }\n * );\n * ```\n *\n * @param methodName - Fully qualified method name, e.g. `'todo.getAll'`.\n * @param args - Arguments passed to the server-side method. Defaults to `{}`.\n * @param options - Call-site options such as a custom {@link CallMethodOptions.errorHandler}. Defaults to `{}`.\n * @returns A promise that resolves to the method's return value.\n */\nexport async function callMethod<T = unknown>(\n methodName: string,\n args?: MethodArgs,\n options?: CallMethodOptions\n): Promise<T> {\n args = args ?? {};\n options = options ?? {};\n try {\n const baseUrl = getClientConfig()?.baseUrl ?? '';\n return await call<T>(`${baseUrl}/api/_internal/method/${methodName}`, args);\n } catch (error) {\n const handler = options.errorHandler ?? handleError;\n handler(error as Error, methodName);\n throw error;\n }\n}\n\nasync function call<T = unknown>(endpoint: string, args: MethodArgs): Promise<T> {\n const response = await fetch(endpoint, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n args,\n authToken: getAuthToken(),\n clientInfo: getClientInfo(),\n }),\n });\n\n if (!response.ok) {\n const error = await response.text();\n throw new MethodError(error, response.status);\n }\n\n const text = await response.text();\n const result = text ? JSON.parse(text) : undefined;\n if (!result) {\n throw new Error('Invalid response from server');\n }\n\n return reviveResponseTypes(result.data, result.typeMap);\n}\n","import { AppConfig, ConfigKey, Configs } from './types';\n\nlet config: Record<ConfigKey, AppConfig> = {};\n\n/**\n * @sidebarTitle getConfig (client)\n *\n * @param key\n * @returns\n */\nexport function getConfig(key: ConfigKey): string | number | boolean | undefined {\n return config[key]?.value;\n}\n\nexport function _setConfig(configs: Configs) {\n config = configs;\n}\n","import { create } from 'zustand';\nimport { z } from 'zod';\nimport { callMethod } from './method';\nimport { _setConfig } from '../config/client';\nimport { setLocalStorageSession } from './localStorage';\nimport { getClientConfig } from './clientConfig';\nimport { time } from '../time';\nimport { Configs } from '../config/types';\n\ntype User = {\n id: string;\n handle: string;\n roles: string[];\n hasRole: (role: string) => boolean;\n requireRole: (role: string) => void;\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n};\n\ntype SessionStore = {\n user: User | null;\n setUser: (user: User | null) => void;\n};\n\nexport const useSessionStore = create<SessionStore>((set) => ({\n user: null,\n setUser: (user) => set({ user }),\n}));\n\nlet isInitialized = false;\nconst SESSION_HEARTBEAT_INTERVAL = time.seconds(30);\nlet heartbeatTimer: ReturnType<typeof setTimeout> | null = null;\n\nconst userSchema = z.object({\n id: z.string(),\n handle: z.string(),\n roles: z.array(z.string()),\n firstName: z.string().optional(),\n lastName: z.string().optional(),\n avatarUrl: z.string().optional(),\n});\n\nfunction parseUser(user: unknown): User | null {\n if (!user) {\n return null;\n }\n\n const result = userSchema.safeParse(user);\n\n if (!result.success) {\n console.error('Session Error: Invalid user payload', result.error);\n return null;\n }\n\n const parsedData = result.data;\n\n return Object.freeze({\n ...parsedData,\n firstName: parsedData.firstName ?? undefined,\n lastName: parsedData.lastName ?? undefined,\n avatarUrl: parsedData.avatarUrl ?? undefined,\n hasRole: (role: string) => parsedData.roles.includes(role),\n requireRole: (role: string) => {\n if (!parsedData.roles.includes(role)) {\n throw new Error(`Access denied - role '${role}' required`);\n }\n },\n });\n}\n\nexport async function initSession() {\n if (isInitialized) {\n return;\n }\n\n isInitialized = true;\n\n const { configs, session, user } = await callMethod<{\n configs: Configs;\n session: object & { authToken: string };\n user: object;\n }>('_system.session.init');\n _setConfig(configs);\n\n const config = getClientConfig();\n if (config) {\n config.setAuthToken(session.authToken);\n } else {\n setLocalStorageSession(session);\n }\n\n useSessionStore.getState().setUser(parseUser(user));\n\n await loopSessionHeartbeat();\n}\n\nasync function loopSessionHeartbeat() {\n try {\n await callMethod('_system.session.heartbeat', {}, { errorHandler: () => {} });\n } catch {\n // Silently ignore heartbeat errors - they're expected during HMR/reconnects\n }\n heartbeatTimer = setTimeout(loopSessionHeartbeat, SESSION_HEARTBEAT_INTERVAL);\n}\n\nexport function setCurrentUser(user: unknown) {\n const enrichedUser = parseUser(user);\n useSessionStore.getState().setUser(enrichedUser);\n return enrichedUser;\n}\n\nexport function getHeartbeatTimer() {\n return heartbeatTimer;\n}\n\nexport function stopHeartbeatTimer() {\n if (heartbeatTimer) {\n clearTimeout(heartbeatTimer);\n heartbeatTimer = null;\n }\n}\n\n/**\n * `useSession` is a hook that returns the current user, and in the future will also return other details about the current session.\n *\n * @example\n * ```ts\n * import { useSession } from 'modelence/client';\n *\n * function MyComponent() {\n * const { user } = useSession();\n * return <div>{user?.handle}</div>;\n * }\n * ```\n */\nexport function useSession() {\n const user = useSessionStore((state) => state.user);\n return { user };\n}\n","/*\n The \"use client\" directive is specifically for the Next.js layout component, which is rendered on the server by default.\n Because of this, we are explicitly marking it as a client component, so we can render this component on the client\n and properly initialize config on the client side.\n \n While this is specific to Next.js, it is simply ignored outside of Next.js and should not cause errors.\n*/\n'use client';\n\nimport React, { useState, useEffect, ReactNode } from 'react';\nimport { initSession } from './session';\n\ninterface AppProviderProps {\n children: ReactNode;\n loadingElement?: ReactNode;\n}\n\nlet isInitialized = false;\n\nexport function AppProvider({ children, loadingElement }: AppProviderProps) {\n const [isLoading, setIsLoading] = useState(true);\n\n useEffect(() => {\n async function initConfig() {\n if (isInitialized) {\n return;\n }\n\n isInitialized = true;\n\n await initSession();\n setIsLoading(false);\n }\n\n initConfig();\n }, []);\n\n if (isLoading) {\n return loadingElement ?? <div>Loading...</div>;\n }\n\n return children;\n}\n","'use client';\n\nimport type { ObjectId } from 'mongodb';\nimport type { ConfigParams, ConfigType, ValueType } from '../config/types';\nimport { callMethod, type MethodArgs } from './method';\nimport type { AnyMethodShape } from '../methods/types';\n\n// Pulls the config store value without importing server-side code\nimport { getConfig as _getClientConfig } from '../config/client';\n\n// ── type helpers ─────────────────────────────────────────────────────────────\n\n/**\n * Recursively maps ObjectId → string to match the sanitized runtime values\n * sent over the wire. Dates are preserved (revived via typeMap on the client).\n */\ntype Sanitized<T> = T extends ObjectId\n ? string\n : T extends Date\n ? Date\n : T extends (infer U)[]\n ? Sanitized<U>[]\n : T extends object\n ? { [K in keyof T]: Sanitized<T[K]> }\n : T;\n\ntype ExtractArgs<M> = M extends (args: infer A, ...rest: any[]) => any // eslint-disable-line @typescript-eslint/no-explicit-any\n ? A\n : M extends { handler: (args: infer A, ...rest: any[]) => any } // eslint-disable-line @typescript-eslint/no-explicit-any\n ? A\n : MethodArgs;\n\ntype ExtractResult<M> = M extends (...args: any[]) => Promise<infer R> // eslint-disable-line @typescript-eslint/no-explicit-any\n ? Sanitized<R>\n : M extends { handler: (...args: any[]) => Promise<infer R> } // eslint-disable-line @typescript-eslint/no-explicit-any\n ? Sanitized<R>\n : unknown;\n\ntype PublicKeyOf<TSchema extends Record<string, ConfigParams>> = {\n [K in keyof TSchema as TSchema[K] extends ConfigParams<ConfigType, true>\n ? string & K\n : never]: ValueType<TSchema[K]['type']>;\n};\n\ntype AnyModule = {\n name: string;\n configSchema: Record<string, ConfigParams>;\n queries: Record<string, AnyMethodShape>;\n mutations: Record<string, AnyMethodShape>;\n};\n\n// ── createClientModule ────────────────────────────────────────────────────────\n\n/**\n * Creates a typed client accessor for a module's public configs, queries, and mutations.\n *\n * Use `import type` to reference the module so no server code is bundled on the client.\n * Arg and return types for queries and mutations are inferred automatically from the\n * server-side handler signatures.\n *\n * @param moduleName - The module's name as passed to `new Module(name, ...)`.\n *\n * @example\n * ```ts\n * // src/client/payments.ts\n * import type paymentsModule from '../server/payments';\n * import { createClientModule } from 'modelence/client';\n *\n * export const payments = createClientModule<typeof paymentsModule>('payments');\n * ```\n *\n * ```ts\n * // src/components/Checkout.tsx\n * import { useQuery, useMutation } from '@tanstack/react-query';\n * import { payments } from '../client/payments';\n *\n * // Typed config — public keys only, private and secret keys excluded:\n * const currency = payments.getConfig('currency'); // string | undefined\n *\n * // Typed query — pass directly to useQuery:\n * const { data: products } = useQuery(payments.query('getProducts', { page: 1 }));\n *\n * // Typed mutation — pass directly to useMutation:\n * const { mutate: charge } = useMutation(payments.mutation('charge'));\n * charge({ amount: 100 }); // args typed from handler signature\n * ```\n */\nexport function createClientModule<TModule extends AnyModule>(moduleName: string) {\n return {\n getConfig<K extends keyof PublicKeyOf<TModule['configSchema']> & string>(\n key: K\n ): PublicKeyOf<TModule['configSchema']>[K] | undefined {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return _getClientConfig(`${moduleName}.${key}`) as any;\n },\n\n query<K extends keyof TModule['queries'] & string>(\n name: K,\n ...rest: {} extends ExtractArgs<TModule['queries'][K]>\n ? [args?: ExtractArgs<TModule['queries'][K]>]\n : [args: ExtractArgs<TModule['queries'][K]>]\n ) {\n const args = (rest[0] ?? {}) as ExtractArgs<TModule['queries'][K]>;\n return {\n queryKey: [moduleName, name, args] as const,\n queryFn: (): Promise<ExtractResult<TModule['queries'][K]>> =>\n callMethod<ExtractResult<TModule['queries'][K]>>(\n `${moduleName}.${name}`,\n args as MethodArgs\n ),\n };\n },\n\n mutation<K extends keyof TModule['mutations'] & string>(name: K) {\n return {\n mutationFn: (\n args: ExtractArgs<TModule['mutations'][K]>\n ): Promise<ExtractResult<TModule['mutations'][K]>> =>\n callMethod<ExtractResult<TModule['mutations'][K]>>(\n `${moduleName}.${name}`,\n args as MethodArgs\n ),\n };\n },\n\n /**\n * Returns options for `useInfiniteQuery`. The `getArgs` callback receives the\n * current `pageParam` and returns the args to pass to the query handler.\n * Spread the result into `useInfiniteQuery` alongside `getNextPageParam`.\n *\n * Annotate the `pageParam` type in the callback so TypeScript can infer the\n * page param type — no manual generic needed on `useInfiniteQuery`.\n */\n infiniteQuery<K extends keyof TModule['queries'] & string, TPageParam = unknown>(\n name: K,\n getArgs: (pageParam: TPageParam | undefined) => ExtractArgs<TModule['queries'][K]>\n ) {\n return {\n queryKey: [moduleName, name, 'infinite', getArgs(undefined)] as const,\n // Included so TanStack infers TPageParam from the callback type, not from a bare `undefined`.\n initialPageParam: undefined as TPageParam | undefined,\n queryFn: ({\n pageParam,\n }: {\n pageParam: TPageParam | undefined;\n }): Promise<ExtractResult<TModule['queries'][K]>> =>\n callMethod<ExtractResult<TModule['queries'][K]>>(\n `${moduleName}.${name}`,\n getArgs(pageParam) as MethodArgs\n ),\n };\n },\n };\n}\n","import type systemModule from './index';\nimport { createClientModule } from '../client/module';\n\nexport const systemConfig = createClientModule<typeof systemModule>('_system');\n","import React from 'react';\nimport ReactDOM from 'react-dom/client';\nimport { AppProvider } from '../client';\nimport { setErrorHandler, ErrorHandler } from './errorHandler';\n\nexport function renderApp({\n loadingElement,\n routesElement,\n favicon,\n errorHandler,\n}: {\n loadingElement: React.ReactNode;\n routesElement: React.ReactNode;\n favicon?: string;\n errorHandler?: ErrorHandler;\n}) {\n if (errorHandler) {\n setErrorHandler(errorHandler);\n }\n\n window.addEventListener('unload', () => {\n // The presence of any 'unload' event handler, even empty,\n // prevents bfcache in most browsers\n });\n\n ReactDOM.createRoot(document.getElementById('root')!).render(\n <React.StrictMode>\n <AppProvider loadingElement={loadingElement}>{routesElement}</AppProvider>\n </React.StrictMode>\n );\n\n if (favicon) {\n const link = document.querySelector(\"link[rel~='icon']\") as HTMLLinkElement;\n if (!link) {\n const newLink = document.createElement('link');\n newLink.rel = 'icon';\n newLink.href = favicon;\n document.head.appendChild(newLink);\n } else {\n link.href = favicon;\n }\n }\n}\n","import io, { Socket } from 'socket.io-client';\nimport { WebsocketClientProvider } from '../types';\nimport { ClientChannel } from '../clientChannel';\nimport { getAuthToken, getClientInfo } from '@/auth/client';\nimport { getClientConfig } from '@/client/clientConfig';\nimport { reviveResponseTypes } from '@/methods/serialize';\n\nlet socketClient: Socket | null = null;\n\ninterface ActiveLiveSubscription {\n subscriptionId: string;\n method: string;\n args: Record<string, unknown>;\n}\nconst activeLiveSubscriptions = new Map<string, ActiveLiveSubscription>();\n\nfunction getSocket(): Socket {\n if (!socketClient) {\n throw new Error('WebSocket not initialized. Call startWebsockets() first.');\n }\n return socketClient;\n}\n\nfunction resubscribeAll() {\n const authToken = getAuthToken();\n const clientInfo = getClientInfo();\n for (const sub of activeLiveSubscriptions.values()) {\n socketClient?.emit('subscribeLiveQuery', {\n subscriptionId: sub.subscriptionId,\n method: sub.method,\n args: sub.args,\n authToken,\n clientInfo,\n });\n }\n}\n\nfunction init(props: { channels?: ClientChannel<unknown>[] }) {\n const baseUrl = getClientConfig()?.baseUrl ?? '/';\n socketClient = io(baseUrl, {\n transports: ['websocket'],\n auth: {\n token: getAuthToken(),\n },\n });\n\n // Subscribe to all live queries on connect/reconnect\n socketClient.on('connect', () => {\n if (activeLiveSubscriptions.size > 0) {\n console.log(\n `[Modelence] WebSocket reconnected, re-subscribing to ${activeLiveSubscriptions.size} live queries`\n );\n resubscribeAll();\n }\n });\n\n props.channels?.forEach((channel) => channel.init());\n}\n\nfunction on<T = unknown>({\n category,\n listener,\n}: {\n category: string;\n listener: (data: T) => void;\n}) {\n getSocket().on(category, listener);\n}\n\nfunction once<T = unknown>({\n category,\n listener,\n}: {\n category: string;\n listener: (data: T) => void;\n}) {\n getSocket().once(category, listener);\n}\n\nfunction off<T = unknown>({\n category,\n listener,\n}: {\n category: string;\n listener: (data: T) => void;\n}) {\n getSocket().off(category, listener);\n}\n\nfunction emit({ eventName, category, id }: { eventName: string; category: string; id: string }) {\n getSocket().emit(eventName, `${category}:${id}`);\n}\n\nfunction joinChannel({ category, id }: { category: string; id: string }) {\n emit({\n eventName: 'joinChannel',\n category,\n id,\n });\n}\n\nfunction leaveChannel({ category, id }: { category: string; id: string }) {\n emit({\n eventName: 'leaveChannel',\n category,\n id,\n });\n}\n\nlet liveQueryCounter = 0;\n\nexport function subscribeLiveQuery<T = unknown>(\n method: string,\n args: Record<string, unknown>,\n onData: (data: T) => void,\n onError?: (error: string) => void\n): () => void {\n const subscriptionId = `sub-${++liveQueryCounter}-${Date.now()}`;\n\n const handleData = ({\n subscriptionId: sid,\n data,\n typeMap,\n }: {\n subscriptionId: string;\n data: T;\n typeMap?: Record<string, unknown>;\n }) => {\n if (sid === subscriptionId) {\n onData(reviveResponseTypes(data, typeMap));\n }\n };\n\n const handleError = ({\n subscriptionId: sid,\n error,\n }: {\n subscriptionId: string;\n error: string;\n }) => {\n if (sid === subscriptionId) {\n console.error(`[Modelence] Live query error for ${method}:`, error);\n onError?.(error);\n }\n };\n\n const socket = getSocket();\n socket.on('liveQueryData', handleData);\n socket.on('liveQueryError', handleError);\n\n activeLiveSubscriptions.set(subscriptionId, { subscriptionId, method, args });\n\n // Only emit if already connected; otherwise the connect handler will handle it\n if (socket.connected) {\n socket.emit('subscribeLiveQuery', {\n subscriptionId,\n method,\n args,\n authToken: getAuthToken(),\n clientInfo: getClientInfo(),\n });\n }\n\n // Return unsubscribe function\n return () => {\n activeLiveSubscriptions.delete(subscriptionId);\n socket.emit('unsubscribeLiveQuery', { subscriptionId });\n socket.off('liveQueryData', handleData);\n socket.off('liveQueryError', handleError);\n };\n}\n\nconst websocketProvider: WebsocketClientProvider = {\n init,\n on,\n once,\n off,\n emit,\n joinChannel,\n leaveChannel,\n};\n\nexport default websocketProvider;\n","import { ClientChannel } from './clientChannel';\nimport websocketProvider, { subscribeLiveQuery } from './socketio/client';\nimport { WebsocketClientProvider } from './types';\n\nexport { subscribeLiveQuery };\n\nlet websocketClientProvider: WebsocketClientProvider | null = null;\n\nexport function setWebsocketClientProvider(provider: WebsocketClientProvider | null) {\n websocketClientProvider = provider;\n}\n\nexport function getWebsocketClientProvider() {\n return websocketClientProvider;\n}\n\nexport function startWebsockets(props?: {\n provider?: WebsocketClientProvider;\n channels?: ClientChannel[];\n}) {\n if (websocketClientProvider) {\n console.warn('WebSocket already initialized. Skipping initialization.');\n return;\n }\n\n const provider = props?.provider || websocketProvider;\n setWebsocketClientProvider(provider);\n try {\n provider.init({\n channels: props?.channels,\n });\n } catch (error) {\n setWebsocketClientProvider(null);\n throw error;\n }\n}\n","import { getWebsocketClientProvider } from './client';\n\nexport class ClientChannel<T = unknown> {\n public readonly category: string;\n private readonly onMessage: (data: T) => void;\n\n constructor(category: string, onMessage: (data: T) => void) {\n this.category = category;\n this.onMessage = onMessage;\n }\n\n init() {\n getWebsocketClientProvider()?.on({\n category: this.category,\n listener: this.onMessage,\n });\n }\n\n joinChannel(id: string) {\n getWebsocketClientProvider()?.joinChannel({\n category: this.category,\n id,\n });\n }\n\n leaveChannel(id: string) {\n getWebsocketClientProvider()?.leaveChannel({\n category: this.category,\n id,\n });\n }\n}\n","import { callMethod } from '../client/method';\nimport type { FileVisibility, GetUploadUrlResult } from './types';\n\ntype UploadFileParams = {\n filePath: string;\n contentType: string;\n visibility: FileVisibility;\n};\n\ntype UploadFileResult = {\n filePath: string;\n};\n\nexport async function uploadFile(\n file: File | Blob,\n { filePath, contentType, visibility }: UploadFileParams\n): Promise<UploadFileResult> {\n const {\n url,\n fields,\n filePath: resolvedFilePath,\n } = await callMethod<GetUploadUrlResult>('_system.files.getUploadUrl', {\n filePath,\n contentType,\n visibility,\n });\n\n const formData = new FormData();\n for (const [key, value] of Object.entries(fields)) {\n formData.append(key, value);\n }\n formData.append('file', file);\n\n const uploadResponse = await fetch(url, {\n method: 'POST',\n body: formData,\n });\n\n if (!uploadResponse.ok) {\n throw new Error(`Failed to upload file: HTTP status: ${uploadResponse.status}`);\n }\n\n return { filePath: resolvedFilePath };\n}\n\nexport async function deleteFile(filePath: string): Promise<void> {\n await callMethod('_system.files.deleteFile', { filePath });\n}\n\nexport async function downloadFile(filePath: string): Promise<{ downloadUrl: string }> {\n return callMethod('_system.files.downloadFile', { filePath });\n}\n\nexport async function getFileUrl(filePath: string): Promise<{ url: string }> {\n return callMethod('_system.files.getFileUrl', { filePath });\n}\n","import React from 'react';\n\nimport { AppProvider as OriginalAppProvider } from './client/AppProvider';\n\nexport { configureClient, type ClientConfig } from './client/clientConfig';\nexport { getConfig } from './config/client';\nexport { createClientModule } from './client/module';\nexport type { ValueType } from './config/types';\nexport { systemConfig } from './system/client';\n\nexport const AppProvider =\n 'useClient' in React\n ? // @ts-ignore: React.useClient only exists in Next.js\n React.useClient(OriginalAppProvider)\n : OriginalAppProvider;\n\nexport { renderApp } from './client/renderApp';\nexport { callMethod, MethodError, type MethodArgs, type CallMethodOptions } from './client/method';\nexport { useSession } from './client/session';\nexport {\n signupWithPassword,\n loginWithPassword,\n verifyEmail,\n updateProfile,\n resendEmailVerification,\n logout,\n sendResetPasswordToken,\n resetPassword,\n linkOAuthProvider,\n unlinkOAuthProvider,\n type UserInfo,\n} from './auth/client';\nexport {\n getWebsocketClientProvider,\n setWebsocketClientProvider,\n startWebsockets,\n subscribeLiveQuery,\n} from './websocket/client';\nexport { ClientChannel } from './websocket/clientChannel';\nexport { getLocalStorageSession } from './client/localStorage';\nexport { uploadFile, deleteFile, downloadFile, getFileUrl } from './files/client';\n"]}
1
+ {"version":3,"sources":["../src/client/localStorage.ts","../src/client/clientConfig.ts","../src/auth/client/index.ts","../src/client/errorHandler.ts","../src/client/method.ts","../src/config/client.ts","../src/client/session.ts","../src/client/AppProvider.tsx","../src/client/module.ts","../src/system/client.ts","../src/client/renderApp.tsx","../src/websocket/socketio/client.ts","../src/websocket/client.ts","../src/websocket/clientChannel.ts","../src/files/client.ts","../src/client.ts"],"names":["getLocalStorageSession","sessionJson","e","setLocalStorageSession","session","config","configureClient","userConfig","getClientConfig","signupWithPassword","options","email","password","handle","firstName","lastName","avatarUrl","callMethod","loginWithPassword","user","setCurrentUser","updateProfile","verifyEmail","token","resendEmailVerification","logout","sendResetPasswordToken","resetPassword","linkOAuthProvider","provider","baseUrl","getAuthToken","nonceResponse","nonce","url","unlinkOAuthProvider","getClientInfo","errorHandler","error","methodName","setErrorHandler","handler","handleError","MethodError","message","status","code","args","call","endpoint","response","text","result","reviveResponseTypes","getConfig","key","_setConfig","configs","useSessionStore","create","set","isInitialized","SESSION_HEARTBEAT_INTERVAL","time","userSchema","z","parseUser","parsedData","role","initSession","loopSessionHeartbeat","enrichedUser","useSession","state","AppProvider","children","loadingElement","isLoading","setIsLoading","useState","useEffect","initConfig","jsx","createClientModule","moduleName","name","rest","getArgs","pageParam","systemConfig","renderApp","routesElement","favicon","ReactDOM","React","link","newLink","socketClient","activeLiveSubscriptions","getSocket","resubscribeAll","authToken","clientInfo","sub","init","props","io","channel","on","category","listener","once","off","emit","eventName","id","joinChannel","leaveChannel","liveQueryCounter","subscribeLiveQuery","method","onData","onError","subscriptionId","handleData","sid","data","typeMap","socket","websocketProvider","client_default","websocketClientProvider","setWebsocketClientProvider","getWebsocketClientProvider","startWebsockets","ClientChannel","onMessage","uploadFile","file","filePath","contentType","visibility","fields","resolvedFilePath","formData","value","uploadResponse","deleteFile","downloadFile","getFileUrl"],"mappings":"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","file":"client.js","sourcesContent":["export function getLocalStorageSession() {\n const sessionJson = localStorage.getItem('modelence.session');\n try {\n return sessionJson ? JSON.parse(sessionJson) : null;\n } catch (e) {\n console.error('Error parsing session from localStorage', e);\n return null;\n }\n}\n\nexport function setLocalStorageSession(session: object) {\n localStorage.setItem('modelence.session', JSON.stringify(session));\n}\n","import type { ClientInfo } from '@/methods/types';\n\nexport interface ClientConfig {\n baseUrl: string;\n getAuthToken: () => string | undefined;\n setAuthToken: (token: string | null) => void;\n getClientInfo: () => ClientInfo;\n /**\n * Opens a URL for OAuth redirects. React Native must use\n * `(url) => Linking.openURL(url)` — WebView is not supported.\n * Defaults to `window.location.href` when not provided.\n */\n openUrl?: (url: string) => void;\n}\n\nlet config: ClientConfig | null = null;\n\n/**\n * Configure the Modelence client for non-browser environments like React Native.\n *\n * When configured, the client uses the provided functions for auth-token\n * storage, client-info collection, and URL resolution instead of the\n * default browser APIs (localStorage, window.screen, relative URLs).\n *\n * @example\n * ```ts\n * import { configureClient } from 'modelence/client';\n * import { Linking } from 'react-native';\n *\n * let authToken: string | undefined;\n *\n * configureClient({\n * baseUrl: 'https://myapp.com',\n * getAuthToken: () => authToken,\n * setAuthToken: (token) => { authToken = token ?? undefined; },\n * getClientInfo: () => ({\n * screenWidth: Dimensions.get('screen').width,\n * screenHeight: Dimensions.get('screen').height,\n * windowWidth: Dimensions.get('window').width,\n * windowHeight: Dimensions.get('window').height,\n * pixelRatio: PixelRatio.get(),\n * orientation: null,\n * }),\n * openUrl: (url) => Linking.openURL(url),\n * });\n * ```\n */\nexport function configureClient(userConfig: ClientConfig) {\n config = userConfig;\n}\n\nexport function getClientConfig(): ClientConfig | null {\n return config;\n}\n","import { setCurrentUser } from '@/client/session';\nimport { callMethod } from '@/client/method';\nimport { getLocalStorageSession } from '@/client/localStorage';\nimport { getClientConfig } from '@/client/clientConfig';\nimport type { ClientInfo } from '@/methods/types';\nimport { OAuthProvider } from '../types';\n\nexport type UserInfo = {\n id: string;\n handle: string;\n roles: string[];\n hasRole: (role: string) => boolean;\n requireRole: (role: string) => void;\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n};\n\ntype RawUserData = {\n id: string;\n handle: string;\n roles: string[];\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n};\n\n/**\n * Sign up a new user with an email and password.\n *\n * @example\n * ```ts\n * await signupWithPassword({ email: 'test@example.com', password: '12345678' });\n * await signupWithPassword({ email: 'test@example.com', password: '12345678', handle: 'myhandle', firstName: 'John' });\n * ```\n * @param options.email - The email of the user.\n * @param options.password - The password of the user.\n * @param options.handle - Optional custom handle. If omitted, one is derived from the email.\n * @param options.firstName - Optional first name.\n * @param options.lastName - Optional last name.\n * @param options.avatarUrl - Optional avatar URL.\n */\nexport async function signupWithPassword(options: {\n email: string;\n password: string;\n handle?: string;\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n}) {\n const { email, password, handle, firstName, lastName, avatarUrl } = options;\n await callMethod('_system.user.signupWithPassword', {\n email,\n password,\n ...(handle !== undefined ? { handle } : {}),\n ...(firstName !== undefined ? { firstName } : {}),\n ...(lastName !== undefined ? { lastName } : {}),\n ...(avatarUrl !== undefined ? { avatarUrl } : {}),\n });\n}\n\n/**\n * Login a user with an email and password.\n *\n * @example\n * ```ts\n * await loginWithPassword({ email: 'test@example.com', password: '12345678' });\n * ```\n * @param options.email - The email of the user.\n * @param options.password - The password of the user.\n */\nexport async function loginWithPassword(options: { email: string; password: string }) {\n const { email, password } = options;\n const { user, session } = await callMethod<{ user: RawUserData; session: { authToken: string } }>(\n '_system.user.loginWithPassword',\n {\n email,\n password,\n }\n );\n const config = getClientConfig();\n if (config) {\n config.setAuthToken(session.authToken);\n }\n const enrichedUser = setCurrentUser(user);\n return enrichedUser;\n}\n\n/**\n * Update the current user's profile.\n *\n * @example\n * ```ts\n * await updateProfile({ firstName: 'Atul', lastName: 'Yadav', avatarUrl: 'https://example.com/avatar.jpg', handle: 'atulyadav' });\n * ```\n * @param options.firstName - The first name of the user.\n * @param options.lastName - The last name of the user.\n * @param options.avatarUrl - The avatar URL of the user.\n * @param options.handle - The handle of the user.\n */\nexport async function updateProfile(options: {\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n handle?: string;\n}) {\n const { firstName, lastName, avatarUrl, handle } = options;\n const { user } = await callMethod<{ user: RawUserData }>('_system.user.updateProfile', {\n ...(firstName !== undefined ? { firstName } : {}),\n ...(lastName !== undefined ? { lastName } : {}),\n ...(avatarUrl !== undefined ? { avatarUrl } : {}),\n ...(handle !== undefined ? { handle } : {}),\n });\n const enrichedUser = setCurrentUser(user);\n return enrichedUser;\n}\n\n/**\n * Verify user's email with a verification token.\n *\n * @example\n * ```ts\n * await verifyEmail({ token: 'verification-token' });\n * ```\n * @param options.token - The email verification token.\n */\nexport async function verifyEmail(options: { token: string }) {\n const { token } = options;\n await callMethod<{ user: RawUserData }>('_system.user.verifyEmail', { token });\n}\n\n/**\n * Resend the verification email for a given email address.\n * The email is only sent if the address is registered and not yet verified.\n * A generic response is always returned to avoid leaking account information.\n *\n * @example\n * ```ts\n * await resendEmailVerification({ email: 'user@example.com' });\n * ```\n * @param options.email - The email address to resend verification to.\n */\nexport async function resendEmailVerification(options: { email: string }) {\n const { email } = options;\n await callMethod('_system.user.resendEmailVerification', { email });\n}\n\n/**\n * Logout the current user.\n *\n */\nexport async function logout() {\n await callMethod('_system.user.logout');\n const config = getClientConfig();\n if (config) {\n config.setAuthToken(null);\n }\n setCurrentUser(null);\n}\n\n/**\n * Send reset password token.\n * @param options.email - The email of the user.\n */\nexport async function sendResetPasswordToken(options: { email: string }) {\n const { email } = options;\n await callMethod('_system.user.sendResetPasswordToken', {\n email,\n });\n}\n\n/**\n * Reset password.\n * @param options.token - The password reset token.\n * @param options.password - The new password.\n */\nexport async function resetPassword(options: { token: string; password: string }) {\n const { token, password } = options;\n await callMethod('_system.user.resetPassword', {\n token,\n password,\n });\n}\n\n/**\n * Link an OAuth provider to the currently signed-in user's account.\n * Redirects the browser to the OAuth provider's authorization page.\n * The provider will redirect back and the account will be linked.\n *\n * @example\n * ```ts\n * linkOAuthProvider({ provider: 'google' });\n * ```\n * @param options.provider - The OAuth provider to link ('google' or 'github').\n */\nexport async function linkOAuthProvider(options: { provider: OAuthProvider }): Promise<void> {\n const { provider } = options;\n const config = getClientConfig();\n const baseUrl = config?.baseUrl ?? '';\n\n if (config?.openUrl) {\n // React Native: exchange authToken for a single-use nonce via an authenticated\n // request, then put the nonce in the URL. A crafted external link can't work\n // because the nonce is bound to this session and consumed on first use.\n const token = getAuthToken();\n if (!token) {\n throw new Error('Failed to initialize OAuth linking. Please ensure you are logged in.');\n }\n const nonceResponse = await fetch(`${baseUrl}/api/_internal/auth/issue-link-nonce`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ authToken: token }),\n });\n if (!nonceResponse.ok) {\n throw new Error('Failed to initialize OAuth linking. Please ensure you are logged in.');\n }\n const { nonce } = await nonceResponse.json();\n const url = `${baseUrl}/api/_internal/auth/${provider}?mode=link&linkNonce=${encodeURIComponent(nonce)}`;\n config.openUrl(url);\n } else {\n // Browser: set httpOnly cookie via same-origin fetch (keeps token out of redirect params).\n const token = getAuthToken();\n if (token) {\n const response = await fetch(`${baseUrl}/api/_internal/auth/set-link-cookie`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ authToken: token }),\n credentials: 'include',\n });\n if (!response.ok) {\n throw new Error('Failed to initialize OAuth linking. Please ensure you are logged in.');\n }\n }\n window.location.href = `${baseUrl}/api/_internal/auth/${provider}?mode=link`;\n }\n}\n/**\n * Unlink an OAuth provider from the currently signed-in user's account.\n *\n * @example\n * ```ts\n * await unlinkOAuthProvider({ provider: 'github' });\n * ```\n * @param options.provider - The OAuth provider to unlink ('google' or 'github').\n */\nexport async function unlinkOAuthProvider(options: { provider: OAuthProvider }): Promise<void> {\n const { provider } = options;\n await callMethod('_system.user.unlinkOAuthProvider', { provider });\n}\n\n/**\n * Get the current auth token associated with the current session.\n * @returns The auth token or undefined if not authenticated.\n */\nexport function getAuthToken(): string | undefined {\n const config = getClientConfig();\n if (config) {\n return config.getAuthToken();\n }\n return getLocalStorageSession()?.authToken;\n}\n\nexport function getClientInfo(): ClientInfo {\n const config = getClientConfig();\n if (config) {\n return config.getClientInfo();\n }\n return {\n screenWidth: window.screen.width,\n screenHeight: window.screen.height,\n windowWidth: window.innerWidth,\n windowHeight: window.innerHeight,\n pixelRatio: window.devicePixelRatio,\n orientation: window.screen.orientation?.type ?? null,\n };\n}\n","export type ErrorHandler = (error: Error, methodName: string) => void;\n\nlet errorHandler: ErrorHandler = (error, methodName) => {\n console.error(`Error calling method '${methodName}':`, error);\n};\n\nexport function setErrorHandler(handler: ErrorHandler) {\n errorHandler = handler;\n}\n\nexport function handleError(error: Error, methodName: string) {\n return errorHandler(error, methodName);\n}\n","/*\n The \"use client\" directive is specifically for the Next.js layout component, which is rendered on the server by default.\n Because of this, we are explicitly marking it as a client component, so we can render this component on the client\n and properly initialize config on the client side.\n \n While this is specific to Next.js, it is simply ignored outside of Next.js and should not cause errors.\n*/\n'use client';\n\nimport { getAuthToken, getClientInfo } from '@/auth/client';\nimport { handleError } from '@/client/errorHandler';\nimport { getClientConfig } from '@/client/clientConfig';\nimport { reviveResponseTypes } from '@/methods/serialize';\n\nexport class MethodError extends Error {\n status: number;\n /**\n * Machine-readable error code set by the server (when available), so callers\n * can branch on the error kind without matching the human-readable message.\n * For example, a login attempt with an unverified email yields\n * `code === 'EMAIL_NOT_VERIFIED'`.\n */\n code?: string;\n\n constructor(message: string, status: number, code?: string) {\n super(message);\n this.name = 'MethodError';\n this.status = status;\n this.code = code;\n }\n}\n\nexport type MethodArgs = Record<string, unknown>;\n\nexport type CallMethodOptions = {\n errorHandler?: (error: Error, methodName: string) => void;\n};\n\n/**\n * Calls a server-side method (query or mutation) defined on a Modelence module.\n *\n * Both `args` and `options` are optional. Use the type parameter `T` to type the return value.\n *\n * @example\n * ```typescript\n * import { callMethod } from 'modelence/client';\n *\n * // No arguments\n * const todos = await callMethod<Todo[]>('todo.getAll');\n *\n * // With arguments\n * const todo = await callMethod<Todo>('todo.getOne', { id: '123' });\n *\n * // With a custom error handler\n * const created = await callMethod<Todo>(\n * 'todo.create',\n * { title: 'Buy groceries' },\n * { errorHandler: (error, methodName) => console.error(methodName, error) }\n * );\n * ```\n *\n * @param methodName - Fully qualified method name, e.g. `'todo.getAll'`.\n * @param args - Arguments passed to the server-side method. Defaults to `{}`.\n * @param options - Call-site options such as a custom {@link CallMethodOptions.errorHandler}. Defaults to `{}`.\n * @returns A promise that resolves to the method's return value.\n */\nexport async function callMethod<T = unknown>(\n methodName: string,\n args?: MethodArgs,\n options?: CallMethodOptions\n): Promise<T> {\n args = args ?? {};\n options = options ?? {};\n try {\n const baseUrl = getClientConfig()?.baseUrl ?? '';\n return await call<T>(`${baseUrl}/api/_internal/method/${methodName}`, args);\n } catch (error) {\n const handler = options.errorHandler ?? handleError;\n handler(error as Error, methodName);\n throw error;\n }\n}\n\nasync function call<T = unknown>(endpoint: string, args: MethodArgs): Promise<T> {\n const response = await fetch(endpoint, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n args,\n authToken: getAuthToken(),\n clientInfo: getClientInfo(),\n }),\n });\n\n if (!response.ok) {\n const error = await response.text();\n const code = response.headers?.get('X-Modelence-Error-Code') ?? undefined;\n throw new MethodError(error, response.status, code);\n }\n\n const text = await response.text();\n const result = text ? JSON.parse(text) : undefined;\n if (!result) {\n throw new Error('Invalid response from server');\n }\n\n return reviveResponseTypes(result.data, result.typeMap);\n}\n","import { AppConfig, ConfigKey, Configs } from './types';\n\nlet config: Record<ConfigKey, AppConfig> = {};\n\n/**\n * @sidebarTitle getConfig (client)\n *\n * @param key\n * @returns\n */\nexport function getConfig(key: ConfigKey): string | number | boolean | undefined {\n return config[key]?.value;\n}\n\nexport function _setConfig(configs: Configs) {\n config = configs;\n}\n","import { create } from 'zustand';\nimport { z } from 'zod';\nimport { callMethod } from './method';\nimport { _setConfig } from '../config/client';\nimport { setLocalStorageSession } from './localStorage';\nimport { getClientConfig } from './clientConfig';\nimport { time } from '../time';\nimport { Configs } from '../config/types';\n\ntype User = {\n id: string;\n handle: string;\n roles: string[];\n hasRole: (role: string) => boolean;\n requireRole: (role: string) => void;\n firstName?: string;\n lastName?: string;\n avatarUrl?: string;\n};\n\ntype SessionStore = {\n user: User | null;\n setUser: (user: User | null) => void;\n};\n\nexport const useSessionStore = create<SessionStore>((set) => ({\n user: null,\n setUser: (user) => set({ user }),\n}));\n\nlet isInitialized = false;\nconst SESSION_HEARTBEAT_INTERVAL = time.seconds(30);\nlet heartbeatTimer: ReturnType<typeof setTimeout> | null = null;\n\nconst userSchema = z.object({\n id: z.string(),\n handle: z.string(),\n roles: z.array(z.string()),\n firstName: z.string().optional(),\n lastName: z.string().optional(),\n avatarUrl: z.string().optional(),\n});\n\nfunction parseUser(user: unknown): User | null {\n if (!user) {\n return null;\n }\n\n const result = userSchema.safeParse(user);\n\n if (!result.success) {\n console.error('Session Error: Invalid user payload', result.error);\n return null;\n }\n\n const parsedData = result.data;\n\n return Object.freeze({\n ...parsedData,\n firstName: parsedData.firstName ?? undefined,\n lastName: parsedData.lastName ?? undefined,\n avatarUrl: parsedData.avatarUrl ?? undefined,\n hasRole: (role: string) => parsedData.roles.includes(role),\n requireRole: (role: string) => {\n if (!parsedData.roles.includes(role)) {\n throw new Error(`Access denied - role '${role}' required`);\n }\n },\n });\n}\n\nexport async function initSession() {\n if (isInitialized) {\n return;\n }\n\n isInitialized = true;\n\n const { configs, session, user } = await callMethod<{\n configs: Configs;\n session: object & { authToken: string };\n user: object;\n }>('_system.session.init');\n _setConfig(configs);\n\n const config = getClientConfig();\n if (config) {\n config.setAuthToken(session.authToken);\n } else {\n setLocalStorageSession(session);\n }\n\n useSessionStore.getState().setUser(parseUser(user));\n\n await loopSessionHeartbeat();\n}\n\nasync function loopSessionHeartbeat() {\n try {\n await callMethod('_system.session.heartbeat', {}, { errorHandler: () => {} });\n } catch {\n // Silently ignore heartbeat errors - they're expected during HMR/reconnects\n }\n heartbeatTimer = setTimeout(loopSessionHeartbeat, SESSION_HEARTBEAT_INTERVAL);\n}\n\nexport function setCurrentUser(user: unknown) {\n const enrichedUser = parseUser(user);\n useSessionStore.getState().setUser(enrichedUser);\n return enrichedUser;\n}\n\nexport function getHeartbeatTimer() {\n return heartbeatTimer;\n}\n\nexport function stopHeartbeatTimer() {\n if (heartbeatTimer) {\n clearTimeout(heartbeatTimer);\n heartbeatTimer = null;\n }\n}\n\n/**\n * `useSession` is a hook that returns the current user, and in the future will also return other details about the current session.\n *\n * @example\n * ```ts\n * import { useSession } from 'modelence/client';\n *\n * function MyComponent() {\n * const { user } = useSession();\n * return <div>{user?.handle}</div>;\n * }\n * ```\n */\nexport function useSession() {\n const user = useSessionStore((state) => state.user);\n return { user };\n}\n","/*\n The \"use client\" directive is specifically for the Next.js layout component, which is rendered on the server by default.\n Because of this, we are explicitly marking it as a client component, so we can render this component on the client\n and properly initialize config on the client side.\n \n While this is specific to Next.js, it is simply ignored outside of Next.js and should not cause errors.\n*/\n'use client';\n\nimport React, { useState, useEffect, ReactNode } from 'react';\nimport { initSession } from './session';\n\ninterface AppProviderProps {\n children: ReactNode;\n loadingElement?: ReactNode;\n}\n\nlet isInitialized = false;\n\nexport function AppProvider({ children, loadingElement }: AppProviderProps) {\n const [isLoading, setIsLoading] = useState(true);\n\n useEffect(() => {\n async function initConfig() {\n if (isInitialized) {\n return;\n }\n\n isInitialized = true;\n\n await initSession();\n setIsLoading(false);\n }\n\n void initConfig();\n }, []);\n\n if (isLoading) {\n return loadingElement ?? <div>Loading...</div>;\n }\n\n return children;\n}\n","'use client';\n\nimport type { ObjectId } from 'mongodb';\nimport type { ConfigParams, ConfigType, ValueType } from '../config/types';\nimport { callMethod, type MethodArgs } from './method';\nimport type { AnyMethodShape } from '../methods/types';\n\n// Pulls the config store value without importing server-side code\nimport { getConfig as _getClientConfig } from '../config/client';\n\n// ── type helpers ─────────────────────────────────────────────────────────────\n\n/**\n * Recursively maps ObjectId → string to match the sanitized runtime values\n * sent over the wire. Dates are preserved (revived via typeMap on the client).\n */\ntype Sanitized<T> = T extends ObjectId\n ? string\n : T extends Date\n ? Date\n : T extends (infer U)[]\n ? Sanitized<U>[]\n : T extends object\n ? { [K in keyof T]: Sanitized<T[K]> }\n : T;\n\ntype ExtractArgs<M> = M extends (args: infer A, ...rest: any[]) => any // eslint-disable-line @typescript-eslint/no-explicit-any\n ? A\n : M extends { handler: (args: infer A, ...rest: any[]) => any } // eslint-disable-line @typescript-eslint/no-explicit-any\n ? A\n : MethodArgs;\n\ntype ExtractResult<M> = M extends (...args: any[]) => Promise<infer R> // eslint-disable-line @typescript-eslint/no-explicit-any\n ? Sanitized<R>\n : M extends { handler: (...args: any[]) => Promise<infer R> } // eslint-disable-line @typescript-eslint/no-explicit-any\n ? Sanitized<R>\n : unknown;\n\ntype PublicKeyOf<TSchema extends Record<string, ConfigParams>> = {\n [K in keyof TSchema as TSchema[K] extends ConfigParams<ConfigType, true>\n ? string & K\n : never]: ValueType<TSchema[K]['type']>;\n};\n\ntype AnyModule = {\n name: string;\n configSchema: Record<string, ConfigParams>;\n queries: Record<string, AnyMethodShape>;\n mutations: Record<string, AnyMethodShape>;\n};\n\n// ── createClientModule ────────────────────────────────────────────────────────\n\n/**\n * Creates a typed client accessor for a module's public configs, queries, and mutations.\n *\n * Use `import type` to reference the module so no server code is bundled on the client.\n * Arg and return types for queries and mutations are inferred automatically from the\n * server-side handler signatures.\n *\n * @param moduleName - The module's name as passed to `new Module(name, ...)`.\n *\n * @example\n * ```ts\n * // src/client/payments.ts\n * import type paymentsModule from '../server/payments';\n * import { createClientModule } from 'modelence/client';\n *\n * export const payments = createClientModule<typeof paymentsModule>('payments');\n * ```\n *\n * ```ts\n * // src/components/Checkout.tsx\n * import { useQuery, useMutation } from '@tanstack/react-query';\n * import { payments } from '../client/payments';\n *\n * // Typed config — public keys only, private and secret keys excluded:\n * const currency = payments.getConfig('currency'); // string | undefined\n *\n * // Typed query — pass directly to useQuery:\n * const { data: products } = useQuery(payments.query('getProducts', { page: 1 }));\n *\n * // Typed mutation — pass directly to useMutation:\n * const { mutate: charge } = useMutation(payments.mutation('charge'));\n * charge({ amount: 100 }); // args typed from handler signature\n * ```\n */\nexport function createClientModule<TModule extends AnyModule>(moduleName: string) {\n return {\n getConfig<K extends keyof PublicKeyOf<TModule['configSchema']> & string>(\n key: K\n ): PublicKeyOf<TModule['configSchema']>[K] | undefined {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return _getClientConfig(`${moduleName}.${key}`) as any;\n },\n\n query<K extends keyof TModule['queries'] & string>(\n name: K,\n ...rest: {} extends ExtractArgs<TModule['queries'][K]>\n ? [args?: ExtractArgs<TModule['queries'][K]>]\n : [args: ExtractArgs<TModule['queries'][K]>]\n ) {\n const args = (rest[0] ?? {}) as ExtractArgs<TModule['queries'][K]>;\n return {\n queryKey: [moduleName, name, args] as const,\n queryFn: (): Promise<ExtractResult<TModule['queries'][K]>> =>\n callMethod<ExtractResult<TModule['queries'][K]>>(\n `${moduleName}.${name}`,\n args as MethodArgs\n ),\n };\n },\n\n mutation<K extends keyof TModule['mutations'] & string>(name: K) {\n return {\n mutationFn: (\n args: ExtractArgs<TModule['mutations'][K]>\n ): Promise<ExtractResult<TModule['mutations'][K]>> =>\n callMethod<ExtractResult<TModule['mutations'][K]>>(\n `${moduleName}.${name}`,\n args as MethodArgs\n ),\n };\n },\n\n /**\n * Returns options for `useInfiniteQuery`. The `getArgs` callback receives the\n * current `pageParam` and returns the args to pass to the query handler.\n * Spread the result into `useInfiniteQuery` alongside `getNextPageParam`.\n *\n * Annotate the `pageParam` type in the callback so TypeScript can infer the\n * page param type — no manual generic needed on `useInfiniteQuery`.\n */\n infiniteQuery<K extends keyof TModule['queries'] & string, TPageParam = unknown>(\n name: K,\n getArgs: (pageParam: TPageParam | undefined) => ExtractArgs<TModule['queries'][K]>\n ) {\n return {\n queryKey: [moduleName, name, 'infinite', getArgs(undefined)] as const,\n // Included so TanStack infers TPageParam from the callback type, not from a bare `undefined`.\n initialPageParam: undefined as TPageParam | undefined,\n queryFn: ({\n pageParam,\n }: {\n pageParam: TPageParam | undefined;\n }): Promise<ExtractResult<TModule['queries'][K]>> =>\n callMethod<ExtractResult<TModule['queries'][K]>>(\n `${moduleName}.${name}`,\n getArgs(pageParam) as MethodArgs\n ),\n };\n },\n };\n}\n","import type systemModule from './index';\nimport { createClientModule } from '../client/module';\n\nexport const systemConfig = createClientModule<typeof systemModule>('_system');\n","import React from 'react';\nimport ReactDOM from 'react-dom/client';\nimport { AppProvider } from '../client';\nimport { setErrorHandler, ErrorHandler } from './errorHandler';\n\nexport function renderApp({\n loadingElement,\n routesElement,\n favicon,\n errorHandler,\n}: {\n loadingElement: React.ReactNode;\n routesElement: React.ReactNode;\n favicon?: string;\n errorHandler?: ErrorHandler;\n}) {\n if (errorHandler) {\n setErrorHandler(errorHandler);\n }\n\n window.addEventListener('unload', () => {\n // The presence of any 'unload' event handler, even empty,\n // prevents bfcache in most browsers\n });\n\n ReactDOM.createRoot(document.getElementById('root')!).render(\n <React.StrictMode>\n <AppProvider loadingElement={loadingElement}>{routesElement}</AppProvider>\n </React.StrictMode>\n );\n\n if (favicon) {\n const link = document.querySelector(\"link[rel~='icon']\") as HTMLLinkElement;\n if (!link) {\n const newLink = document.createElement('link');\n newLink.rel = 'icon';\n newLink.href = favicon;\n document.head.appendChild(newLink);\n } else {\n link.href = favicon;\n }\n }\n}\n","import io, { Socket } from 'socket.io-client';\nimport { WebsocketClientProvider } from '../types';\nimport { ClientChannel } from '../clientChannel';\nimport { getAuthToken, getClientInfo } from '@/auth/client';\nimport { getClientConfig } from '@/client/clientConfig';\nimport { reviveResponseTypes } from '@/methods/serialize';\n\nlet socketClient: Socket | null = null;\n\ninterface ActiveLiveSubscription {\n subscriptionId: string;\n method: string;\n args: Record<string, unknown>;\n}\nconst activeLiveSubscriptions = new Map<string, ActiveLiveSubscription>();\n\nfunction getSocket(): Socket {\n if (!socketClient) {\n throw new Error('WebSocket not initialized. Call startWebsockets() first.');\n }\n return socketClient;\n}\n\nfunction resubscribeAll() {\n const authToken = getAuthToken();\n const clientInfo = getClientInfo();\n for (const sub of activeLiveSubscriptions.values()) {\n socketClient?.emit('subscribeLiveQuery', {\n subscriptionId: sub.subscriptionId,\n method: sub.method,\n args: sub.args,\n authToken,\n clientInfo,\n });\n }\n}\n\nfunction init(props: { channels?: ClientChannel<unknown>[] }) {\n const baseUrl = getClientConfig()?.baseUrl ?? '/';\n socketClient = io(baseUrl, {\n transports: ['websocket'],\n auth: {\n token: getAuthToken(),\n },\n });\n\n // Subscribe to all live queries on connect/reconnect\n socketClient.on('connect', () => {\n if (activeLiveSubscriptions.size > 0) {\n console.log(\n `[Modelence] WebSocket reconnected, re-subscribing to ${activeLiveSubscriptions.size} live queries`\n );\n resubscribeAll();\n }\n });\n\n props.channels?.forEach((channel) => channel.init());\n}\n\nfunction on<T = unknown>({\n category,\n listener,\n}: {\n category: string;\n listener: (data: T) => void;\n}) {\n getSocket().on(category, listener);\n}\n\nfunction once<T = unknown>({\n category,\n listener,\n}: {\n category: string;\n listener: (data: T) => void;\n}) {\n getSocket().once(category, listener);\n}\n\nfunction off<T = unknown>({\n category,\n listener,\n}: {\n category: string;\n listener: (data: T) => void;\n}) {\n getSocket().off(category, listener);\n}\n\nfunction emit({ eventName, category, id }: { eventName: string; category: string; id: string }) {\n getSocket().emit(eventName, `${category}:${id}`);\n}\n\nfunction joinChannel({ category, id }: { category: string; id: string }) {\n emit({\n eventName: 'joinChannel',\n category,\n id,\n });\n}\n\nfunction leaveChannel({ category, id }: { category: string; id: string }) {\n emit({\n eventName: 'leaveChannel',\n category,\n id,\n });\n}\n\nlet liveQueryCounter = 0;\n\nexport function subscribeLiveQuery<T = unknown>(\n method: string,\n args: Record<string, unknown>,\n onData: (data: T) => void,\n onError?: (error: string) => void\n): () => void {\n const subscriptionId = `sub-${++liveQueryCounter}-${Date.now()}`;\n\n const handleData = ({\n subscriptionId: sid,\n data,\n typeMap,\n }: {\n subscriptionId: string;\n data: T;\n typeMap?: Record<string, unknown>;\n }) => {\n if (sid === subscriptionId) {\n onData(reviveResponseTypes(data, typeMap));\n }\n };\n\n const handleError = ({\n subscriptionId: sid,\n error,\n }: {\n subscriptionId: string;\n error: string;\n }) => {\n if (sid === subscriptionId) {\n console.error(`[Modelence] Live query error for ${method}:`, error);\n onError?.(error);\n }\n };\n\n const socket = getSocket();\n socket.on('liveQueryData', handleData);\n socket.on('liveQueryError', handleError);\n\n activeLiveSubscriptions.set(subscriptionId, { subscriptionId, method, args });\n\n // Only emit if already connected; otherwise the connect handler will handle it\n if (socket.connected) {\n socket.emit('subscribeLiveQuery', {\n subscriptionId,\n method,\n args,\n authToken: getAuthToken(),\n clientInfo: getClientInfo(),\n });\n }\n\n // Return unsubscribe function\n return () => {\n activeLiveSubscriptions.delete(subscriptionId);\n socket.emit('unsubscribeLiveQuery', { subscriptionId });\n socket.off('liveQueryData', handleData);\n socket.off('liveQueryError', handleError);\n };\n}\n\nconst websocketProvider: WebsocketClientProvider = {\n init,\n on,\n once,\n off,\n emit,\n joinChannel,\n leaveChannel,\n};\n\nexport default websocketProvider;\n","import { ClientChannel } from './clientChannel';\nimport websocketProvider, { subscribeLiveQuery } from './socketio/client';\nimport { WebsocketClientProvider } from './types';\n\nexport { subscribeLiveQuery };\n\nlet websocketClientProvider: WebsocketClientProvider | null = null;\n\nexport function setWebsocketClientProvider(provider: WebsocketClientProvider | null) {\n websocketClientProvider = provider;\n}\n\nexport function getWebsocketClientProvider() {\n return websocketClientProvider;\n}\n\nexport function startWebsockets(props?: {\n provider?: WebsocketClientProvider;\n channels?: ClientChannel[];\n}) {\n if (websocketClientProvider) {\n console.warn('WebSocket already initialized. Skipping initialization.');\n return;\n }\n\n const provider = props?.provider || websocketProvider;\n setWebsocketClientProvider(provider);\n try {\n provider.init({\n channels: props?.channels,\n });\n } catch (error) {\n setWebsocketClientProvider(null);\n throw error;\n }\n}\n","import { getWebsocketClientProvider } from './client';\n\nexport class ClientChannel<T = unknown> {\n public readonly category: string;\n private readonly onMessage: (data: T) => void;\n\n constructor(category: string, onMessage: (data: T) => void) {\n this.category = category;\n this.onMessage = onMessage;\n }\n\n init() {\n getWebsocketClientProvider()?.on({\n category: this.category,\n listener: this.onMessage,\n });\n }\n\n joinChannel(id: string) {\n getWebsocketClientProvider()?.joinChannel({\n category: this.category,\n id,\n });\n }\n\n leaveChannel(id: string) {\n getWebsocketClientProvider()?.leaveChannel({\n category: this.category,\n id,\n });\n }\n}\n","import { callMethod } from '../client/method';\nimport type { FileVisibility, GetUploadUrlResult } from './types';\n\ntype UploadFileParams = {\n filePath: string;\n contentType: string;\n visibility: FileVisibility;\n};\n\ntype UploadFileResult = {\n filePath: string;\n};\n\nexport async function uploadFile(\n file: File | Blob,\n { filePath, contentType, visibility }: UploadFileParams\n): Promise<UploadFileResult> {\n const {\n url,\n fields,\n filePath: resolvedFilePath,\n } = await callMethod<GetUploadUrlResult>('_system.files.getUploadUrl', {\n filePath,\n contentType,\n visibility,\n });\n\n const formData = new FormData();\n for (const [key, value] of Object.entries(fields)) {\n formData.append(key, value);\n }\n formData.append('file', file);\n\n const uploadResponse = await fetch(url, {\n method: 'POST',\n body: formData,\n });\n\n if (!uploadResponse.ok) {\n throw new Error(`Failed to upload file: HTTP status: ${uploadResponse.status}`);\n }\n\n return { filePath: resolvedFilePath };\n}\n\nexport async function deleteFile(filePath: string): Promise<void> {\n await callMethod('_system.files.deleteFile', { filePath });\n}\n\nexport async function downloadFile(filePath: string): Promise<{ downloadUrl: string }> {\n return callMethod('_system.files.downloadFile', { filePath });\n}\n\nexport async function getFileUrl(filePath: string): Promise<{ url: string }> {\n return callMethod('_system.files.getFileUrl', { filePath });\n}\n","import React from 'react';\n\nimport { AppProvider as OriginalAppProvider } from './client/AppProvider';\n\nexport { configureClient, type ClientConfig } from './client/clientConfig';\nexport { getConfig } from './config/client';\nexport { createClientModule } from './client/module';\nexport type { ValueType } from './config/types';\nexport { systemConfig } from './system/client';\n\nexport const AppProvider =\n 'useClient' in React\n ? // @ts-ignore: React.useClient only exists in Next.js\n React.useClient(OriginalAppProvider)\n : OriginalAppProvider;\n\nexport { renderApp } from './client/renderApp';\nexport { callMethod, MethodError, type MethodArgs, type CallMethodOptions } from './client/method';\nexport { useSession } from './client/session';\nexport {\n signupWithPassword,\n loginWithPassword,\n verifyEmail,\n updateProfile,\n resendEmailVerification,\n logout,\n sendResetPasswordToken,\n resetPassword,\n linkOAuthProvider,\n unlinkOAuthProvider,\n type UserInfo,\n} from './auth/client';\nexport {\n getWebsocketClientProvider,\n setWebsocketClientProvider,\n startWebsockets,\n subscribeLiveQuery,\n} from './websocket/client';\nexport { ClientChannel } from './websocket/clientChannel';\nexport { getLocalStorageSession } from './client/localStorage';\nexport { uploadFile, deleteFile, downloadFile, getFileUrl } from './files/client';\n"]}
package/dist/index.d.ts CHANGED
@@ -14,10 +14,15 @@ declare const time: {
14
14
 
15
15
  declare abstract class ModelenceError extends Error {
16
16
  abstract status: number;
17
+ /**
18
+ * Optional machine-readable error code so clients can branch on the kind of
19
+ * error without string-matching `message` (which may be reworded or localized).
20
+ */
21
+ code?: string;
17
22
  }
18
23
  declare class AuthError extends ModelenceError {
19
24
  status: number;
20
- constructor(message: string);
25
+ constructor(message: string, code?: string);
21
26
  }
22
27
  declare class ValidationError extends ModelenceError {
23
28
  status: number;
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- export{b as AuthError,a as ModelenceError,d as RateLimitError,c as ValidationError}from'./chunk-C3UESBRX.js';export{a as time}from'./chunk-DO5TZLF5.js';import'./chunk-55J6XMHW.js';//# sourceMappingURL=index.js.map
1
+ export{b as AuthError,a as ModelenceError,d as RateLimitError,c as ValidationError}from'./chunk-MIRF7FP3.js';export{a as time}from'./chunk-DO5TZLF5.js';import'./chunk-55J6XMHW.js';//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- export{l as author,i as bin,n as bugs,s as default,q as dependencies,d as description,p as devDependencies,g as exports,h as files,o as homepage,m as license,e as main,b as name,r as peerDependencies,k as repository,j as scripts,a as type,f as types,c as version}from'./chunk-DZKWVTHR.js';//# sourceMappingURL=package-G6SV6T7V.js.map
2
- //# sourceMappingURL=package-G6SV6T7V.js.map
1
+ export{l as author,i as bin,n as bugs,s as default,q as dependencies,d as description,p as devDependencies,g as exports,h as files,o as homepage,m as license,e as main,b as name,r as peerDependencies,k as repository,j as scripts,a as type,f as types,c as version}from'./chunk-TRKYSUXZ.js';//# sourceMappingURL=package-HWYPZMTL.js.map
2
+ //# sourceMappingURL=package-HWYPZMTL.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"package-G6SV6T7V.js"}
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"package-HWYPZMTL.js"}
package/dist/server.d.ts CHANGED
@@ -137,7 +137,7 @@ type EmailConfig = {
137
137
  *
138
138
  * @example
139
139
  * ```typescript
140
- * import { time } from 'modelence/server';
140
+ * import { time } from 'modelence';
141
141
  *
142
142
  * const rule: AuthRateLimitOverride = {
143
143
  * type: 'ip',
@@ -170,7 +170,8 @@ type AuthRateLimitOverride = {
170
170
  *
171
171
  * @example Tighten the 15-minute signup cap; per-day default is preserved.
172
172
  * ```typescript
173
- * import { startApp, time } from 'modelence/server';
173
+ * import { startApp } from 'modelence/server';
174
+ * import { time } from 'modelence';
174
175
  *
175
176
  * startApp({
176
177
  * auth: {
@@ -245,6 +246,7 @@ type AuthOption = {
245
246
  * @example
246
247
  * ```typescript
247
248
  * import { startApp } from 'modelence/server';
249
+ * import { time } from 'modelence';
248
250
  *
249
251
  * startApp({
250
252
  * auth: {
@@ -432,6 +434,18 @@ type SecurityConfig = {
432
434
  * When set, `X-Frame-Options` is omitted since it cannot express multiple origins.
433
435
  */
434
436
  frameAncestors?: string[];
437
+ /**
438
+ * Express `trust proxy` setting, controlling how `req.protocol`, `req.ip` and
439
+ * `req.hostname` are derived from `X-Forwarded-*` headers.
440
+ *
441
+ * Defaults to `true` (trusts the whole chain) — fine when the app is only
442
+ * reachable through a trusted proxy. Tighten when self-hosting: a number is
443
+ * trusted hop count (e.g. `1`), a string/array trusts IPs or subnets
444
+ * (e.g. `['loopback', '10.0.0.0/8']`), `false` disables proxy trust.
445
+ *
446
+ * https://expressjs.com/en/guide/behind-proxies.html
447
+ */
448
+ trustProxy?: boolean | number | string | string[];
435
449
  };
436
450
 
437
451
  type WebsocketConfig = {