@rebasepro/server-postgresql 0.4.0 → 0.6.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.
Files changed (168) hide show
  1. package/README.md +69 -89
  2. package/dist/{server-postgresql/src/PostgresAdapter.d.ts → PostgresAdapter.d.ts} +1 -1
  3. package/dist/{server-postgresql/src/PostgresBackendDriver.d.ts → PostgresBackendDriver.d.ts} +2 -2
  4. package/dist/{server-postgresql/src/PostgresBootstrapper.d.ts → PostgresBootstrapper.d.ts} +11 -1
  5. package/dist/{server-postgresql/src/auth → auth}/services.d.ts +11 -11
  6. package/dist/{server-postgresql/src/collections → collections}/PostgresCollectionRegistry.d.ts +4 -0
  7. package/dist/{server-postgresql/src/data-transformer.d.ts → data-transformer.d.ts} +0 -3
  8. package/dist/{server-postgresql/src/databasePoolManager.d.ts → databasePoolManager.d.ts} +1 -1
  9. package/dist/index.es.js +10174 -11184
  10. package/dist/index.es.js.map +1 -1
  11. package/dist/index.umd.js +10735 -11462
  12. package/dist/index.umd.js.map +1 -1
  13. package/dist/{server-postgresql/src/services → services}/EntityPersistService.d.ts +0 -14
  14. package/dist/types.d.ts +3 -0
  15. package/dist/utils/pg-error-utils.d.ts +55 -0
  16. package/dist/{server-postgresql/src/websocket.d.ts → websocket.d.ts} +8 -3
  17. package/package.json +24 -21
  18. package/src/PostgresAdapter.ts +9 -10
  19. package/src/PostgresBackendDriver.ts +135 -122
  20. package/src/PostgresBootstrapper.ts +90 -16
  21. package/src/auth/ensure-tables.ts +28 -5
  22. package/src/auth/services.ts +56 -45
  23. package/src/cli.ts +140 -110
  24. package/src/collections/PostgresCollectionRegistry.ts +7 -0
  25. package/src/connection.ts +11 -6
  26. package/src/data-transformer.ts +73 -109
  27. package/src/databasePoolManager.ts +5 -3
  28. package/src/history/HistoryService.ts +3 -2
  29. package/src/history/ensure-history-table.ts +5 -4
  30. package/src/schema/auth-schema.ts +1 -2
  31. package/src/schema/doctor-cli.ts +2 -1
  32. package/src/schema/doctor.ts +40 -37
  33. package/src/schema/generate-drizzle-schema-logic.ts +56 -18
  34. package/src/schema/generate-drizzle-schema.ts +11 -11
  35. package/src/schema/introspect-db-inference.ts +25 -25
  36. package/src/schema/introspect-db-logic.ts +38 -38
  37. package/src/schema/introspect-db.ts +28 -27
  38. package/src/services/BranchService.ts +14 -0
  39. package/src/services/EntityFetchService.ts +28 -25
  40. package/src/services/EntityPersistService.ts +11 -124
  41. package/src/services/RelationService.ts +57 -37
  42. package/src/services/entity-helpers.ts +6 -2
  43. package/src/services/realtimeService.ts +45 -32
  44. package/src/types.ts +4 -0
  45. package/src/utils/drizzle-conditions.ts +31 -15
  46. package/src/utils/pg-error-utils.ts +211 -0
  47. package/src/websocket.ts +51 -33
  48. package/test/auth-services.test.ts +36 -19
  49. package/test/batch-many-to-many-regression.test.ts +119 -39
  50. package/test/data-transformer-hardening.test.ts +67 -33
  51. package/test/data-transformer.test.ts +4 -2
  52. package/test/doctor.test.ts +10 -5
  53. package/test/drizzle-conditions.test.ts +59 -6
  54. package/test/generate-drizzle-schema.test.ts +65 -40
  55. package/test/introspect-db-generation.test.ts +179 -81
  56. package/test/introspect-db-utils.test.ts +92 -37
  57. package/test/mocks/chalk.cjs +7 -0
  58. package/test/pg-error-utils.test.ts +221 -0
  59. package/test/postgresDataDriver.test.ts +14 -5
  60. package/test/property-ordering.test.ts +126 -79
  61. package/test/realtimeService.test.ts +6 -2
  62. package/test/relation-pipeline-gaps.test.ts +84 -36
  63. package/test/relations.test.ts +247 -0
  64. package/test/unmapped-tables-safety.test.ts +14 -6
  65. package/test/websocket.test.ts +1 -1
  66. package/tsconfig.json +5 -0
  67. package/tsconfig.prod.json +3 -0
  68. package/vite.config.ts +5 -5
  69. package/dist/common/src/collections/CollectionRegistry.d.ts +0 -56
  70. package/dist/common/src/collections/default-collections.d.ts +0 -9
  71. package/dist/common/src/collections/index.d.ts +0 -2
  72. package/dist/common/src/data/buildRebaseData.d.ts +0 -14
  73. package/dist/common/src/data/query_builder.d.ts +0 -55
  74. package/dist/common/src/index.d.ts +0 -4
  75. package/dist/common/src/util/builders.d.ts +0 -57
  76. package/dist/common/src/util/callbacks.d.ts +0 -6
  77. package/dist/common/src/util/collections.d.ts +0 -11
  78. package/dist/common/src/util/common.d.ts +0 -2
  79. package/dist/common/src/util/conditions.d.ts +0 -26
  80. package/dist/common/src/util/entities.d.ts +0 -58
  81. package/dist/common/src/util/enums.d.ts +0 -3
  82. package/dist/common/src/util/index.d.ts +0 -16
  83. package/dist/common/src/util/navigation_from_path.d.ts +0 -34
  84. package/dist/common/src/util/navigation_utils.d.ts +0 -20
  85. package/dist/common/src/util/parent_references_from_path.d.ts +0 -6
  86. package/dist/common/src/util/paths.d.ts +0 -14
  87. package/dist/common/src/util/permissions.d.ts +0 -6
  88. package/dist/common/src/util/references.d.ts +0 -2
  89. package/dist/common/src/util/relations.d.ts +0 -22
  90. package/dist/common/src/util/resolutions.d.ts +0 -72
  91. package/dist/common/src/util/storage.d.ts +0 -24
  92. package/dist/types/src/controllers/analytics_controller.d.ts +0 -7
  93. package/dist/types/src/controllers/auth.d.ts +0 -104
  94. package/dist/types/src/controllers/client.d.ts +0 -168
  95. package/dist/types/src/controllers/collection_registry.d.ts +0 -46
  96. package/dist/types/src/controllers/customization_controller.d.ts +0 -60
  97. package/dist/types/src/controllers/data.d.ts +0 -207
  98. package/dist/types/src/controllers/data_driver.d.ts +0 -218
  99. package/dist/types/src/controllers/database_admin.d.ts +0 -11
  100. package/dist/types/src/controllers/dialogs_controller.d.ts +0 -36
  101. package/dist/types/src/controllers/effective_role.d.ts +0 -4
  102. package/dist/types/src/controllers/email.d.ts +0 -36
  103. package/dist/types/src/controllers/index.d.ts +0 -18
  104. package/dist/types/src/controllers/local_config_persistence.d.ts +0 -20
  105. package/dist/types/src/controllers/navigation.d.ts +0 -225
  106. package/dist/types/src/controllers/registry.d.ts +0 -63
  107. package/dist/types/src/controllers/side_dialogs_controller.d.ts +0 -67
  108. package/dist/types/src/controllers/side_entity_controller.d.ts +0 -97
  109. package/dist/types/src/controllers/snackbar.d.ts +0 -24
  110. package/dist/types/src/controllers/storage.d.ts +0 -171
  111. package/dist/types/src/index.d.ts +0 -4
  112. package/dist/types/src/rebase_context.d.ts +0 -122
  113. package/dist/types/src/types/auth_adapter.d.ts +0 -301
  114. package/dist/types/src/types/backend.d.ts +0 -536
  115. package/dist/types/src/types/backend_hooks.d.ts +0 -172
  116. package/dist/types/src/types/builders.d.ts +0 -15
  117. package/dist/types/src/types/chips.d.ts +0 -5
  118. package/dist/types/src/types/collections.d.ts +0 -941
  119. package/dist/types/src/types/component_ref.d.ts +0 -47
  120. package/dist/types/src/types/cron.d.ts +0 -102
  121. package/dist/types/src/types/data_source.d.ts +0 -64
  122. package/dist/types/src/types/database_adapter.d.ts +0 -94
  123. package/dist/types/src/types/entities.d.ts +0 -145
  124. package/dist/types/src/types/entity_actions.d.ts +0 -104
  125. package/dist/types/src/types/entity_callbacks.d.ts +0 -173
  126. package/dist/types/src/types/entity_link_builder.d.ts +0 -7
  127. package/dist/types/src/types/entity_overrides.d.ts +0 -10
  128. package/dist/types/src/types/entity_views.d.ts +0 -87
  129. package/dist/types/src/types/export_import.d.ts +0 -21
  130. package/dist/types/src/types/formex.d.ts +0 -40
  131. package/dist/types/src/types/index.d.ts +0 -28
  132. package/dist/types/src/types/locales.d.ts +0 -4
  133. package/dist/types/src/types/modify_collections.d.ts +0 -5
  134. package/dist/types/src/types/plugins.d.ts +0 -282
  135. package/dist/types/src/types/properties.d.ts +0 -1181
  136. package/dist/types/src/types/property_config.d.ts +0 -74
  137. package/dist/types/src/types/relations.d.ts +0 -336
  138. package/dist/types/src/types/slots.d.ts +0 -262
  139. package/dist/types/src/types/translations.d.ts +0 -900
  140. package/dist/types/src/types/user_management_delegate.d.ts +0 -86
  141. package/dist/types/src/types/websockets.d.ts +0 -78
  142. package/dist/types/src/users/index.d.ts +0 -1
  143. package/dist/types/src/users/user.d.ts +0 -50
  144. package/drizzle.test.config.ts +0 -10
  145. /package/dist/{server-postgresql/src/auth → auth}/ensure-tables.d.ts +0 -0
  146. /package/dist/{server-postgresql/src/cli.d.ts → cli.d.ts} +0 -0
  147. /package/dist/{server-postgresql/src/connection.d.ts → connection.d.ts} +0 -0
  148. /package/dist/{server-postgresql/src/history → history}/HistoryService.d.ts +0 -0
  149. /package/dist/{server-postgresql/src/history → history}/ensure-history-table.d.ts +0 -0
  150. /package/dist/{server-postgresql/src/index.d.ts → index.d.ts} +0 -0
  151. /package/dist/{server-postgresql/src/interfaces.d.ts → interfaces.d.ts} +0 -0
  152. /package/dist/{server-postgresql/src/schema → schema}/auth-schema.d.ts +0 -0
  153. /package/dist/{server-postgresql/src/schema → schema}/doctor-cli.d.ts +0 -0
  154. /package/dist/{server-postgresql/src/schema → schema}/doctor.d.ts +0 -0
  155. /package/dist/{server-postgresql/src/schema → schema}/generate-drizzle-schema-logic.d.ts +0 -0
  156. /package/dist/{server-postgresql/src/schema → schema}/generate-drizzle-schema.d.ts +0 -0
  157. /package/dist/{server-postgresql/src/schema → schema}/introspect-db-inference.d.ts +0 -0
  158. /package/dist/{server-postgresql/src/schema → schema}/introspect-db-logic.d.ts +0 -0
  159. /package/dist/{server-postgresql/src/schema → schema}/introspect-db.d.ts +0 -0
  160. /package/dist/{server-postgresql/src/schema → schema}/test-schema.d.ts +0 -0
  161. /package/dist/{server-postgresql/src/services → services}/BranchService.d.ts +0 -0
  162. /package/dist/{server-postgresql/src/services → services}/EntityFetchService.d.ts +0 -0
  163. /package/dist/{server-postgresql/src/services → services}/RelationService.d.ts +0 -0
  164. /package/dist/{server-postgresql/src/services → services}/entity-helpers.d.ts +0 -0
  165. /package/dist/{server-postgresql/src/services → services}/entityService.d.ts +0 -0
  166. /package/dist/{server-postgresql/src/services → services}/index.d.ts +0 -0
  167. /package/dist/{server-postgresql/src/services → services}/realtimeService.d.ts +0 -0
  168. /package/dist/{server-postgresql/src/utils → utils}/drizzle-conditions.d.ts +0 -0
@@ -1,122 +0,0 @@
1
- import type { AnalyticsController } from "./controllers/analytics_controller";
2
- import type { AuthController } from "./controllers/auth";
3
- import type { StorageSource } from "./controllers/storage";
4
- import type { UserConfigurationPersistence } from "./controllers/local_config_persistence";
5
- import type { DatabaseAdmin } from "./types/backend";
6
- import type { RebaseClient } from "./controllers/client";
7
- import type { RebaseData } from "./controllers/data";
8
- import type { User } from "./users";
9
- import type { UserManagementDelegate } from "./types/user_management_delegate";
10
- /**
11
- * Context that is provided to entity callbacks (hooks).
12
- * It contains only the dependencies that are available in both the frontend and the backend.
13
- * @group Hooks and utilities
14
- */
15
- export type RebaseCallContext<USER extends User = User> = {
16
- /**
17
- * The Rebase client instance.
18
- * Available in all entity callbacks (beforeSave, afterSave, afterRead,
19
- * beforeDelete, afterDelete) and in CollectionActionsProps via context.
20
- * Use it to call backend functions, access data, storage, etc.
21
- *
22
- * @example
23
- * // In a beforeSave callback:
24
- * const result = await context.client.functions.invoke('my-function', { ... });
25
- *
26
- * @example
27
- * // In a CollectionAction component:
28
- * const { client } = props.context;
29
- * const result = await client.functions.invoke('extract-job', { url });
30
- */
31
- client: RebaseClient;
32
- /**
33
- * Unified data access — `context.data.products.create(...)`.
34
- * Access any collection as a dynamic property.
35
- */
36
- data: RebaseData;
37
- /**
38
- * Used storage implementation
39
- */
40
- storageSource: StorageSource;
41
- /**
42
- * Set by the backend when callbacks are executed on the server.
43
- */
44
- user?: USER;
45
- };
46
- /**
47
- * Context that includes the internal controllers and contexts used by the app.
48
- * Some controllers and context included in this context can be accessed
49
- * directly from their respective hooks.
50
- * @group Hooks and utilities
51
- * @see useRebaseContext
52
- */
53
- export type RebaseContext<USER extends User = User, AuthControllerType extends AuthController<USER> = AuthController<USER>> = RebaseCallContext<USER> & {
54
- authController: AuthControllerType;
55
- /**
56
- * Controller mapping strings to collections
57
- */
58
- collectionRegistryController?: import("./controllers/collection_registry").CollectionRegistryController;
59
- /**
60
- * Controller for navigation state
61
- */
62
- navigationStateController?: import("./controllers/navigation").NavigationStateController;
63
- /**
64
- * Controller for side dialogs (side sheets)
65
- */
66
- sideDialogsController?: import("./controllers/side_dialogs_controller").SideDialogsController;
67
- /**
68
- * Controller to open the side dialog displaying entity forms
69
- */
70
- sideEntityController?: import("./controllers/side_entity_controller").SideEntityController;
71
- /**
72
- * Controller resolving URLs in the CMS
73
- */
74
- urlController?: import("./controllers/navigation").UrlController;
75
- /**
76
- * Controller to handle simple confirmation and alert dialogs
77
- */
78
- dialogsController?: import("./controllers/dialogs_controller").DialogsController;
79
- /**
80
- * Controller for CMS customization
81
- */
82
- customizationController?: import("./controllers/customization_controller").CustomizationController;
83
- /**
84
- * Controller for effective role
85
- */
86
- effectiveRoleController?: {
87
- effectiveRole: string | null;
88
- setEffectiveRole: (role: string | null) => void;
89
- };
90
- /**
91
- * Use this controller to access data stored in the browser for the user
92
- */
93
- userConfigPersistence?: UserConfigurationPersistence;
94
- /**
95
- * Callback to send analytics events
96
- */
97
- analyticsController?: AnalyticsController;
98
- /**
99
- * This section is used to manage users in the CMS.
100
- * It is used to show user information in various places of the CMS,
101
- * for example, to show who created or modified an entity,
102
- * or to assign ownership of an entity.
103
- *
104
- * In the base CMS, this information is not used for access control.
105
- * You can pass your own implementation of this section, to populate
106
- * the dropdown of users when assigning ownership of an entity,
107
- * or to show more information about the user.
108
- *
109
- * If you are using the Rebase user management plugin, this
110
- * section will be implemented automatically.
111
- */
112
- userManagement?: UserManagementDelegate<USER>;
113
- /**
114
- * Administrative database operations (SQL, schema discovery).
115
- * Only available in developer/admin contexts.
116
- */
117
- databaseAdmin?: DatabaseAdmin;
118
- /**
119
- * Controller for snackbars
120
- */
121
- snackbarController?: import("./controllers/snackbar").SnackbarController;
122
- };
@@ -1,301 +0,0 @@
1
- /**
2
- * @module AuthAdapter
3
- *
4
- * Pluggable authentication abstraction for Rebase.
5
- *
6
- * An `AuthAdapter` decouples authentication from the database layer,
7
- * allowing users to bring their own auth system (Clerk, Auth0, Firebase Auth,
8
- * custom JWT, etc.) while keeping the Rebase admin frontend fully functional.
9
- *
10
- * @example Built-in auth (default — zero config change)
11
- * ```ts
12
- * initializeRebaseBackend({
13
- * auth: { jwtSecret: "...", google: { clientId: "..." } },
14
- * database: createPostgresAdapter({ ... }),
15
- * });
16
- * ```
17
- *
18
- * @example Custom auth
19
- * ```ts
20
- * import { createCustomAuthAdapter } from "@rebasepro/server-core";
21
- *
22
- * initializeRebaseBackend({
23
- * auth: createCustomAuthAdapter({
24
- * verifyRequest: async (req) => { ... },
25
- * }),
26
- * database: createPostgresAdapter({ ... }),
27
- * });
28
- * ```
29
- *
30
- * @group Auth
31
- */
32
- import type { Hono } from "hono";
33
- /**
34
- * The normalized user object returned by `AuthAdapter.verifyRequest()`.
35
- *
36
- * Regardless of the auth provider, every request is resolved to this shape
37
- * so that downstream middleware (RLS scoping, route guards) can work uniformly.
38
- *
39
- * @group Auth
40
- */
41
- export interface AuthenticatedUser {
42
- /** Unique user identifier (provider-specific). */
43
- uid: string;
44
- /** Primary email address. */
45
- email: string;
46
- /** Human-readable display name. */
47
- displayName?: string | null;
48
- /** Avatar URL. */
49
- photoUrl?: string | null;
50
- /** Role identifiers the user holds. */
51
- roles: string[];
52
- /** Whether the user has admin privileges. */
53
- isAdmin: boolean;
54
- /** Raw bearer token from the request (for forwarding). */
55
- rawToken?: string;
56
- /** Extra claims/metadata from the auth provider. */
57
- claims?: Record<string, unknown>;
58
- }
59
- /**
60
- * Feature flags advertised by an auth adapter.
61
- *
62
- * The frontend reads these from `GET /api/auth/config` to dynamically
63
- * show/hide UI elements (login form, registration, password reset, etc.).
64
- *
65
- * @group Auth
66
- */
67
- export interface AuthAdapterCapabilities {
68
- /**
69
- * Whether this adapter mounts its own `/auth/*` routes.
70
- *
71
- * - `true` for the built-in Rebase auth (login, register, refresh, etc.)
72
- * - `false` for external providers like Clerk or Auth0 that handle
73
- * auth flows outside of the Rebase backend.
74
- */
75
- hasBuiltInAuthRoutes: boolean;
76
- /** Supports email/password login. */
77
- emailPasswordLogin: boolean;
78
- /** Supports new user registration. */
79
- registration: boolean;
80
- /** Supports password reset flow. */
81
- passwordReset: boolean;
82
- /** Supports session listing/revocation. */
83
- sessionManagement: boolean;
84
- /** Supports profile updates (display name, photo). */
85
- profileUpdate: boolean;
86
- /** Supports email verification. */
87
- emailVerification: boolean;
88
- /** List of enabled OAuth provider IDs (e.g. `["google", "github"]`). */
89
- enabledProviders: string[];
90
- /**
91
- * For external auth (Clerk, Auth0, etc.): the URL where the user should
92
- * be redirected for login. The Rebase frontend will navigate here instead
93
- * of showing its own login form.
94
- */
95
- externalLoginUrl?: string;
96
- /**
97
- * True when no users exist yet — first-user bootstrap mode.
98
- * Only applicable for built-in auth.
99
- */
100
- needsSetup?: boolean;
101
- /** Whether new user registration is enabled (may differ from `registration` capability at runtime). */
102
- registrationEnabled?: boolean;
103
- }
104
- /**
105
- * Options for paginated user listing.
106
- * @group Auth
107
- */
108
- export interface AuthUserListOptions {
109
- limit?: number;
110
- offset?: number;
111
- search?: string;
112
- orderBy?: string;
113
- orderDir?: "asc" | "desc";
114
- roleId?: string;
115
- }
116
- /**
117
- * Paginated user listing result.
118
- * @group Auth
119
- */
120
- export interface AuthUserListResult {
121
- users: AuthUserData[];
122
- total: number;
123
- limit: number;
124
- offset: number;
125
- }
126
- /**
127
- * User data exposed by the auth adapter.
128
- * @group Auth
129
- */
130
- export interface AuthUserData {
131
- id: string;
132
- email: string;
133
- displayName?: string | null;
134
- photoUrl?: string | null;
135
- emailVerified?: boolean;
136
- metadata?: Record<string, unknown>;
137
- createdAt?: Date;
138
- updatedAt?: Date;
139
- }
140
- /**
141
- * Data for creating a user.
142
- * @group Auth
143
- */
144
- export interface AuthCreateUserData {
145
- email: string;
146
- password?: string;
147
- displayName?: string;
148
- photoUrl?: string;
149
- metadata?: Record<string, unknown>;
150
- }
151
- /**
152
- * User management operations for the admin panel.
153
- *
154
- * Optional — if not provided by the adapter, the user management UI is hidden.
155
- *
156
- * @group Auth
157
- */
158
- export interface UserManagementAdapter {
159
- listUsers(options?: AuthUserListOptions): Promise<AuthUserListResult>;
160
- getUserById(id: string): Promise<AuthUserData | null>;
161
- createUser(data: AuthCreateUserData): Promise<AuthUserData>;
162
- updateUser(id: string, data: Partial<AuthCreateUserData>): Promise<AuthUserData | null>;
163
- deleteUser(id: string): Promise<void>;
164
- getUserRoles(userId: string): Promise<string[]>;
165
- setUserRoles(userId: string, roleIds: string[]): Promise<void>;
166
- }
167
- /**
168
- * Pluggable authentication adapter for Rebase.
169
- *
170
- * This is the **key interface** that decouples authentication from the
171
- * database layer. Each auth adapter knows how to:
172
- *
173
- * 1. Verify incoming HTTP requests (`verifyRequest`)
174
- * 2. Optionally manage users (for the admin panel)
175
- * 3. Optionally mount auth-specific routes (login, register, etc.)
176
- * 4. Advertise its capabilities so the frontend can adapt
177
- *
178
- * The built-in Rebase auth implements this interface internally.
179
- * External providers (Clerk, Auth0, Firebase Auth) provide their own adapters.
180
- * Users with custom auth can use `createCustomAuthAdapter()` for a minimal setup.
181
- *
182
- * @group Auth
183
- */
184
- export interface AuthAdapter {
185
- /**
186
- * Unique identifier for this auth adapter.
187
- *
188
- * @example "rebase-builtin", "clerk", "auth0", "firebase", "custom"
189
- */
190
- readonly id: string;
191
- /**
192
- * Verify an incoming request and extract the authenticated user.
193
- *
194
- * This replaces the hardcoded JWT verification in server-core's middleware.
195
- * Each adapter implements its own token verification strategy:
196
- * - Built-in: verify Rebase JWT
197
- * - Clerk: call Clerk's `verifyToken()`
198
- * - Auth0: validate Auth0 JWT with JWKS
199
- * - Custom: whatever logic the user provides
200
- *
201
- * @param request - The raw `Request` object (portable across Hono, Express, Fastify)
202
- * @returns The authenticated user, or `null` for unauthenticated requests.
203
- * Throw an error to reject the request with 401.
204
- */
205
- verifyRequest(request: Request): Promise<AuthenticatedUser | null>;
206
- /**
207
- * Verify a raw bearer token and extract the authenticated user.
208
- *
209
- * Used for **WebSocket authentication**, where there is no HTTP `Request`
210
- * object — only a token string sent over the socket.
211
- *
212
- * If not implemented, the default behavior synthesizes a minimal `Request`
213
- * with an `Authorization: Bearer <token>` header and delegates to
214
- * `verifyRequest()`. Adapters should override this if their token
215
- * verification logic doesn't depend on request headers/cookies.
216
- *
217
- * @param token - The raw bearer token string.
218
- * @returns The authenticated user, or `null` if the token is invalid.
219
- */
220
- verifyToken?(token: string): Promise<AuthenticatedUser | null>;
221
- /**
222
- * User CRUD for the admin panel's user management UI.
223
- * Optional — if not provided, user management UI is hidden.
224
- */
225
- userManagement?: UserManagementAdapter;
226
- /**
227
- * Mount adapter-specific auth routes (login, register, refresh, etc.).
228
- *
229
- * - Built-in adapter: mounts `/auth/login`, `/auth/register`, etc.
230
- * - External adapter: typically returns `undefined` (auth is handled externally).
231
- * - Custom adapter: user mounts their own routes.
232
- *
233
- * The return type uses `Hono<any, any, any>` because this sub-app will be
234
- * mounted into a parent app via `.route()`, which accepts any Hono env type.
235
- * Adapter implementations are free to use their own env (e.g. `Hono<HonoEnv>`).
236
- *
237
- * @returns A Hono sub-app with auth routes, or `undefined` to skip route mounting.
238
- */
239
- createAuthRoutes?(): Hono<any, any, any> | undefined;
240
- /**
241
- * Mount admin routes for user management.
242
- *
243
- * Same typing rationale as `createAuthRoutes` — the sub-app env is
244
- * unconstrained to support arbitrary adapter implementations.
245
- *
246
- * @returns A Hono sub-app with admin routes, or `undefined` to skip.
247
- */
248
- createAdminRoutes?(): Hono<any, any, any> | undefined;
249
- /**
250
- * Advertise what this auth adapter supports.
251
- *
252
- * The frontend reads this from `GET /api/auth/config` to dynamically
253
- * show/hide UI elements. This is the bridge between backend capabilities
254
- * and the frontend's `AuthCapabilities` type.
255
- */
256
- getCapabilities(): AuthAdapterCapabilities | Promise<AuthAdapterCapabilities>;
257
- /**
258
- * Called during backend initialization.
259
- * Use for running migrations, creating tables, seeding initial data, etc.
260
- */
261
- initialize?(): Promise<void>;
262
- /**
263
- * Called during graceful shutdown.
264
- * Use for closing connections, flushing caches, etc.
265
- */
266
- destroy?(): Promise<void>;
267
- /**
268
- * A static secret key for server-to-server / script authentication.
269
- *
270
- * When set, requests with `Authorization: Bearer <serviceKey>` bypass
271
- * normal token verification and are granted admin-level access.
272
- */
273
- serviceKey?: string;
274
- }
275
- /**
276
- * Options for creating a minimal custom auth adapter via `createCustomAuthAdapter()`.
277
- *
278
- * This is the simplest way to plug an existing auth system into Rebase.
279
- * Only `verifyRequest` is required — everything else is optional.
280
- *
281
- * @group Auth
282
- */
283
- export interface CustomAuthAdapterOptions {
284
- /**
285
- * Verify an incoming request and return the authenticated user.
286
- * This is the only required method.
287
- */
288
- verifyRequest: (request: Request) => Promise<AuthenticatedUser | null>;
289
- /**
290
- * Verify a raw bearer token for WebSocket authentication.
291
- * Optional — if omitted, a synthetic `Request` is constructed and passed
292
- * to `verifyRequest`.
293
- */
294
- verifyToken?: (token: string) => Promise<AuthenticatedUser | null>;
295
- /** Optional user management for the admin panel. */
296
- userManagement?: UserManagementAdapter;
297
- /** Static service key for server-to-server auth. */
298
- serviceKey?: string;
299
- /** Override default capabilities. */
300
- capabilities?: Partial<AuthAdapterCapabilities>;
301
- }