@rebasepro/server-core 0.0.1-canary.09e5ec5

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 (300) hide show
  1. package/LICENSE +6 -0
  2. package/README.md +40 -0
  3. package/build-errors.txt +52 -0
  4. package/coverage/clover.xml +3739 -0
  5. package/coverage/coverage-final.json +31 -0
  6. package/coverage/lcov-report/base.css +224 -0
  7. package/coverage/lcov-report/block-navigation.js +87 -0
  8. package/coverage/lcov-report/favicon.png +0 -0
  9. package/coverage/lcov-report/index.html +266 -0
  10. package/coverage/lcov-report/prettify.css +1 -0
  11. package/coverage/lcov-report/prettify.js +2 -0
  12. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  13. package/coverage/lcov-report/sorter.js +210 -0
  14. package/coverage/lcov-report/src/api/ast-schema-editor.ts.html +952 -0
  15. package/coverage/lcov-report/src/api/errors.ts.html +472 -0
  16. package/coverage/lcov-report/src/api/graphql/graphql-schema-generator.ts.html +1069 -0
  17. package/coverage/lcov-report/src/api/graphql/index.html +116 -0
  18. package/coverage/lcov-report/src/api/index.html +176 -0
  19. package/coverage/lcov-report/src/api/openapi-generator.ts.html +565 -0
  20. package/coverage/lcov-report/src/api/rest/api-generator.ts.html +994 -0
  21. package/coverage/lcov-report/src/api/rest/index.html +131 -0
  22. package/coverage/lcov-report/src/api/rest/query-parser.ts.html +550 -0
  23. package/coverage/lcov-report/src/api/schema-editor-routes.ts.html +202 -0
  24. package/coverage/lcov-report/src/api/server.ts.html +823 -0
  25. package/coverage/lcov-report/src/auth/admin-routes.ts.html +973 -0
  26. package/coverage/lcov-report/src/auth/index.html +176 -0
  27. package/coverage/lcov-report/src/auth/jwt.ts.html +574 -0
  28. package/coverage/lcov-report/src/auth/middleware.ts.html +745 -0
  29. package/coverage/lcov-report/src/auth/password.ts.html +310 -0
  30. package/coverage/lcov-report/src/auth/services.ts.html +2074 -0
  31. package/coverage/lcov-report/src/collections/index.html +116 -0
  32. package/coverage/lcov-report/src/collections/loader.ts.html +232 -0
  33. package/coverage/lcov-report/src/db/auth-schema.ts.html +523 -0
  34. package/coverage/lcov-report/src/db/data-transformer.ts.html +1753 -0
  35. package/coverage/lcov-report/src/db/entityService.ts.html +700 -0
  36. package/coverage/lcov-report/src/db/index.html +146 -0
  37. package/coverage/lcov-report/src/db/services/EntityFetchService.ts.html +4048 -0
  38. package/coverage/lcov-report/src/db/services/EntityPersistService.ts.html +883 -0
  39. package/coverage/lcov-report/src/db/services/RelationService.ts.html +3121 -0
  40. package/coverage/lcov-report/src/db/services/entity-helpers.ts.html +442 -0
  41. package/coverage/lcov-report/src/db/services/index.html +176 -0
  42. package/coverage/lcov-report/src/db/services/index.ts.html +124 -0
  43. package/coverage/lcov-report/src/generate-drizzle-schema-logic.ts.html +1960 -0
  44. package/coverage/lcov-report/src/index.html +116 -0
  45. package/coverage/lcov-report/src/services/driver-registry.ts.html +631 -0
  46. package/coverage/lcov-report/src/services/index.html +131 -0
  47. package/coverage/lcov-report/src/services/postgresDataDriver.ts.html +3025 -0
  48. package/coverage/lcov-report/src/storage/LocalStorageController.ts.html +1189 -0
  49. package/coverage/lcov-report/src/storage/S3StorageController.ts.html +970 -0
  50. package/coverage/lcov-report/src/storage/index.html +161 -0
  51. package/coverage/lcov-report/src/storage/storage-registry.ts.html +646 -0
  52. package/coverage/lcov-report/src/storage/types.ts.html +451 -0
  53. package/coverage/lcov-report/src/utils/drizzle-conditions.ts.html +3082 -0
  54. package/coverage/lcov-report/src/utils/index.html +116 -0
  55. package/coverage/lcov.info +7179 -0
  56. package/dist/common/src/collections/CollectionRegistry.d.ts +56 -0
  57. package/dist/common/src/collections/index.d.ts +1 -0
  58. package/dist/common/src/data/buildRebaseData.d.ts +14 -0
  59. package/dist/common/src/index.d.ts +3 -0
  60. package/dist/common/src/util/builders.d.ts +57 -0
  61. package/dist/common/src/util/callbacks.d.ts +6 -0
  62. package/dist/common/src/util/collections.d.ts +11 -0
  63. package/dist/common/src/util/common.d.ts +2 -0
  64. package/dist/common/src/util/conditions.d.ts +26 -0
  65. package/dist/common/src/util/entities.d.ts +58 -0
  66. package/dist/common/src/util/enums.d.ts +3 -0
  67. package/dist/common/src/util/index.d.ts +16 -0
  68. package/dist/common/src/util/navigation_from_path.d.ts +34 -0
  69. package/dist/common/src/util/navigation_utils.d.ts +20 -0
  70. package/dist/common/src/util/parent_references_from_path.d.ts +6 -0
  71. package/dist/common/src/util/paths.d.ts +14 -0
  72. package/dist/common/src/util/permissions.d.ts +5 -0
  73. package/dist/common/src/util/references.d.ts +2 -0
  74. package/dist/common/src/util/relations.d.ts +22 -0
  75. package/dist/common/src/util/resolutions.d.ts +72 -0
  76. package/dist/common/src/util/storage.d.ts +24 -0
  77. package/dist/index-DXVBFp5V.js +37 -0
  78. package/dist/index-DXVBFp5V.js.map +1 -0
  79. package/dist/index.es.js +49934 -0
  80. package/dist/index.es.js.map +1 -0
  81. package/dist/index.umd.js +49968 -0
  82. package/dist/index.umd.js.map +1 -0
  83. package/dist/server-core/src/api/ast-schema-editor.d.ts +21 -0
  84. package/dist/server-core/src/api/collections_for_test/callbacks_test_collection.d.ts +2 -0
  85. package/dist/server-core/src/api/errors.d.ts +35 -0
  86. package/dist/server-core/src/api/graphql/graphql-schema-generator.d.ts +35 -0
  87. package/dist/server-core/src/api/graphql/index.d.ts +1 -0
  88. package/dist/server-core/src/api/index.d.ts +9 -0
  89. package/dist/server-core/src/api/openapi-generator.d.ts +16 -0
  90. package/dist/server-core/src/api/rest/api-generator.d.ts +64 -0
  91. package/dist/server-core/src/api/rest/index.d.ts +1 -0
  92. package/dist/server-core/src/api/rest/query-parser.d.ts +9 -0
  93. package/dist/server-core/src/api/schema-editor-routes.d.ts +3 -0
  94. package/dist/server-core/src/api/server.d.ts +40 -0
  95. package/dist/server-core/src/api/types.d.ts +90 -0
  96. package/dist/server-core/src/auth/admin-routes.d.ts +16 -0
  97. package/dist/server-core/src/auth/apple-oauth.d.ts +30 -0
  98. package/dist/server-core/src/auth/bitbucket-oauth.d.ts +11 -0
  99. package/dist/server-core/src/auth/discord-oauth.d.ts +14 -0
  100. package/dist/server-core/src/auth/facebook-oauth.d.ts +14 -0
  101. package/dist/server-core/src/auth/github-oauth.d.ts +15 -0
  102. package/dist/server-core/src/auth/gitlab-oauth.d.ts +13 -0
  103. package/dist/server-core/src/auth/google-oauth.d.ts +14 -0
  104. package/dist/server-core/src/auth/index.d.ts +23 -0
  105. package/dist/server-core/src/auth/interfaces.d.ts +309 -0
  106. package/dist/server-core/src/auth/jwt.d.ts +43 -0
  107. package/dist/server-core/src/auth/linkedin-oauth.d.ts +18 -0
  108. package/dist/server-core/src/auth/microsoft-oauth.d.ts +16 -0
  109. package/dist/server-core/src/auth/middleware.d.ts +81 -0
  110. package/dist/server-core/src/auth/password.d.ts +22 -0
  111. package/dist/server-core/src/auth/rate-limiter.d.ts +31 -0
  112. package/dist/server-core/src/auth/routes.d.ts +27 -0
  113. package/dist/server-core/src/auth/slack-oauth.d.ts +12 -0
  114. package/dist/server-core/src/auth/spotify-oauth.d.ts +12 -0
  115. package/dist/server-core/src/auth/twitter-oauth.d.ts +18 -0
  116. package/dist/server-core/src/bootstrappers/index.d.ts +0 -0
  117. package/dist/server-core/src/collections/BackendCollectionRegistry.d.ts +13 -0
  118. package/dist/server-core/src/collections/loader.d.ts +5 -0
  119. package/dist/server-core/src/cron/cron-loader.d.ts +17 -0
  120. package/dist/server-core/src/cron/cron-routes.d.ts +14 -0
  121. package/dist/server-core/src/cron/cron-scheduler.d.ts +61 -0
  122. package/dist/server-core/src/cron/cron-store.d.ts +32 -0
  123. package/dist/server-core/src/cron/index.d.ts +6 -0
  124. package/dist/server-core/src/db/interfaces.d.ts +18 -0
  125. package/dist/server-core/src/email/index.d.ts +6 -0
  126. package/dist/server-core/src/email/smtp-email-service.d.ts +25 -0
  127. package/dist/server-core/src/email/templates.d.ts +42 -0
  128. package/dist/server-core/src/email/types.d.ts +107 -0
  129. package/dist/server-core/src/functions/function-loader.d.ts +17 -0
  130. package/dist/server-core/src/functions/function-routes.d.ts +10 -0
  131. package/dist/server-core/src/functions/index.d.ts +3 -0
  132. package/dist/server-core/src/history/history-routes.d.ts +23 -0
  133. package/dist/server-core/src/history/index.d.ts +1 -0
  134. package/dist/server-core/src/index.d.ts +29 -0
  135. package/dist/server-core/src/init.d.ts +159 -0
  136. package/dist/server-core/src/serve-spa.d.ts +30 -0
  137. package/dist/server-core/src/services/driver-registry.d.ts +78 -0
  138. package/dist/server-core/src/singleton.d.ts +35 -0
  139. package/dist/server-core/src/storage/LocalStorageController.d.ts +46 -0
  140. package/dist/server-core/src/storage/S3StorageController.d.ts +36 -0
  141. package/dist/server-core/src/storage/index.d.ts +25 -0
  142. package/dist/server-core/src/storage/routes.d.ts +38 -0
  143. package/dist/server-core/src/storage/storage-registry.d.ts +78 -0
  144. package/dist/server-core/src/storage/types.d.ts +103 -0
  145. package/dist/server-core/src/types/index.d.ts +11 -0
  146. package/dist/server-core/src/utils/dev-port.d.ts +35 -0
  147. package/dist/server-core/src/utils/logger.d.ts +31 -0
  148. package/dist/server-core/src/utils/logging.d.ts +9 -0
  149. package/dist/server-core/src/utils/request-logger.d.ts +19 -0
  150. package/dist/server-core/src/utils/sql.d.ts +27 -0
  151. package/dist/types/src/controllers/analytics_controller.d.ts +7 -0
  152. package/dist/types/src/controllers/auth.d.ts +119 -0
  153. package/dist/types/src/controllers/client.d.ts +170 -0
  154. package/dist/types/src/controllers/collection_registry.d.ts +45 -0
  155. package/dist/types/src/controllers/customization_controller.d.ts +60 -0
  156. package/dist/types/src/controllers/data.d.ts +168 -0
  157. package/dist/types/src/controllers/data_driver.d.ts +160 -0
  158. package/dist/types/src/controllers/database_admin.d.ts +11 -0
  159. package/dist/types/src/controllers/dialogs_controller.d.ts +36 -0
  160. package/dist/types/src/controllers/effective_role.d.ts +4 -0
  161. package/dist/types/src/controllers/email.d.ts +34 -0
  162. package/dist/types/src/controllers/index.d.ts +18 -0
  163. package/dist/types/src/controllers/local_config_persistence.d.ts +20 -0
  164. package/dist/types/src/controllers/navigation.d.ts +213 -0
  165. package/dist/types/src/controllers/registry.d.ts +54 -0
  166. package/dist/types/src/controllers/side_dialogs_controller.d.ts +67 -0
  167. package/dist/types/src/controllers/side_entity_controller.d.ts +90 -0
  168. package/dist/types/src/controllers/snackbar.d.ts +24 -0
  169. package/dist/types/src/controllers/storage.d.ts +171 -0
  170. package/dist/types/src/index.d.ts +4 -0
  171. package/dist/types/src/rebase_context.d.ts +105 -0
  172. package/dist/types/src/types/backend.d.ts +536 -0
  173. package/dist/types/src/types/builders.d.ts +15 -0
  174. package/dist/types/src/types/chips.d.ts +5 -0
  175. package/dist/types/src/types/collections.d.ts +856 -0
  176. package/dist/types/src/types/cron.d.ts +102 -0
  177. package/dist/types/src/types/data_source.d.ts +64 -0
  178. package/dist/types/src/types/entities.d.ts +145 -0
  179. package/dist/types/src/types/entity_actions.d.ts +98 -0
  180. package/dist/types/src/types/entity_callbacks.d.ts +173 -0
  181. package/dist/types/src/types/entity_link_builder.d.ts +7 -0
  182. package/dist/types/src/types/entity_overrides.d.ts +10 -0
  183. package/dist/types/src/types/entity_views.d.ts +61 -0
  184. package/dist/types/src/types/export_import.d.ts +21 -0
  185. package/dist/types/src/types/index.d.ts +23 -0
  186. package/dist/types/src/types/locales.d.ts +4 -0
  187. package/dist/types/src/types/modify_collections.d.ts +5 -0
  188. package/dist/types/src/types/plugins.d.ts +279 -0
  189. package/dist/types/src/types/properties.d.ts +1176 -0
  190. package/dist/types/src/types/property_config.d.ts +70 -0
  191. package/dist/types/src/types/relations.d.ts +336 -0
  192. package/dist/types/src/types/slots.d.ts +252 -0
  193. package/dist/types/src/types/translations.d.ts +870 -0
  194. package/dist/types/src/types/user_management_delegate.d.ts +121 -0
  195. package/dist/types/src/types/websockets.d.ts +78 -0
  196. package/dist/types/src/users/index.d.ts +2 -0
  197. package/dist/types/src/users/roles.d.ts +22 -0
  198. package/dist/types/src/users/user.d.ts +46 -0
  199. package/history_diff.log +385 -0
  200. package/jest.config.cjs +16 -0
  201. package/package.json +86 -0
  202. package/scratch.ts +9 -0
  203. package/src/api/ast-schema-editor.ts +289 -0
  204. package/src/api/collections_for_test/callbacks_test_collection.ts +60 -0
  205. package/src/api/errors.ts +179 -0
  206. package/src/api/graphql/graphql-schema-generator.ts +336 -0
  207. package/src/api/graphql/index.ts +2 -0
  208. package/src/api/index.ts +11 -0
  209. package/src/api/openapi-generator.ts +715 -0
  210. package/src/api/rest/api-generator.ts +472 -0
  211. package/src/api/rest/index.ts +2 -0
  212. package/src/api/rest/query-parser.ts +155 -0
  213. package/src/api/schema-editor-routes.ts +41 -0
  214. package/src/api/server.ts +248 -0
  215. package/src/api/types.ts +90 -0
  216. package/src/auth/admin-routes.ts +529 -0
  217. package/src/auth/apple-oauth.ts +130 -0
  218. package/src/auth/bitbucket-oauth.ts +82 -0
  219. package/src/auth/discord-oauth.ts +83 -0
  220. package/src/auth/facebook-oauth.ts +72 -0
  221. package/src/auth/github-oauth.ts +110 -0
  222. package/src/auth/gitlab-oauth.ts +70 -0
  223. package/src/auth/google-oauth.ts +48 -0
  224. package/src/auth/index.ts +34 -0
  225. package/src/auth/interfaces.ts +363 -0
  226. package/src/auth/jwt.ts +181 -0
  227. package/src/auth/linkedin-oauth.ts +81 -0
  228. package/src/auth/microsoft-oauth.ts +88 -0
  229. package/src/auth/middleware.ts +384 -0
  230. package/src/auth/password.ts +77 -0
  231. package/src/auth/rate-limiter.ts +129 -0
  232. package/src/auth/routes.ts +788 -0
  233. package/src/auth/slack-oauth.ts +71 -0
  234. package/src/auth/spotify-oauth.ts +67 -0
  235. package/src/auth/twitter-oauth.ts +120 -0
  236. package/src/bootstrappers/index.ts +1 -0
  237. package/src/collections/BackendCollectionRegistry.ts +20 -0
  238. package/src/collections/loader.ts +49 -0
  239. package/src/cron/cron-loader.ts +89 -0
  240. package/src/cron/cron-routes.test.ts +265 -0
  241. package/src/cron/cron-routes.ts +85 -0
  242. package/src/cron/cron-scheduler.test.ts +421 -0
  243. package/src/cron/cron-scheduler.ts +413 -0
  244. package/src/cron/cron-store.ts +163 -0
  245. package/src/cron/index.ts +6 -0
  246. package/src/db/interfaces.ts +60 -0
  247. package/src/email/index.ts +18 -0
  248. package/src/email/smtp-email-service.ts +91 -0
  249. package/src/email/templates.ts +388 -0
  250. package/src/email/types.ts +105 -0
  251. package/src/functions/function-loader.ts +119 -0
  252. package/src/functions/function-routes.ts +31 -0
  253. package/src/functions/index.ts +3 -0
  254. package/src/history/history-routes.ts +129 -0
  255. package/src/history/index.ts +2 -0
  256. package/src/index.ts +66 -0
  257. package/src/init.ts +727 -0
  258. package/src/serve-spa.ts +81 -0
  259. package/src/services/driver-registry.ts +182 -0
  260. package/src/singleton.test.ts +28 -0
  261. package/src/singleton.ts +70 -0
  262. package/src/storage/LocalStorageController.ts +365 -0
  263. package/src/storage/S3StorageController.ts +298 -0
  264. package/src/storage/index.ts +43 -0
  265. package/src/storage/routes.ts +264 -0
  266. package/src/storage/storage-registry.ts +187 -0
  267. package/src/storage/types.ts +134 -0
  268. package/src/types/index.ts +27 -0
  269. package/src/utils/dev-port.ts +176 -0
  270. package/src/utils/logger.ts +143 -0
  271. package/src/utils/logging.ts +38 -0
  272. package/src/utils/request-logger.ts +66 -0
  273. package/src/utils/sql.ts +38 -0
  274. package/test/admin-routes.test.ts +640 -0
  275. package/test/api-generator.test.ts +501 -0
  276. package/test/ast-schema-editor.test.ts +63 -0
  277. package/test/auth-middleware-hono.test.ts +556 -0
  278. package/test/auth-routes.test.ts +1047 -0
  279. package/test/driver-registry.test.ts +282 -0
  280. package/test/error-propagation.test.ts +226 -0
  281. package/test/errors-hono.test.ts +133 -0
  282. package/test/errors.test.ts +155 -0
  283. package/test/jwt-security.test.ts +182 -0
  284. package/test/jwt.test.ts +324 -0
  285. package/test/middleware.test.ts +300 -0
  286. package/test/password.test.ts +165 -0
  287. package/test/query-parser.test.ts +263 -0
  288. package/test/rate-limiter.test.ts +102 -0
  289. package/test/safe-compare.test.ts +66 -0
  290. package/test/singleton.test.ts +59 -0
  291. package/test/storage-local.test.ts +271 -0
  292. package/test/storage-registry.test.ts +282 -0
  293. package/test/storage-routes.test.ts +222 -0
  294. package/test/storage-s3.test.ts +304 -0
  295. package/test-ast.ts +28 -0
  296. package/test.ts +6 -0
  297. package/test_output.txt +1133 -0
  298. package/tsconfig.json +49 -0
  299. package/tsconfig.prod.json +20 -0
  300. package/vite.config.ts +80 -0
@@ -0,0 +1,35 @@
1
+ import type { RebaseClient } from "@rebasepro/types";
2
+ /**
3
+ * @internal Called once during server initialization to set the backing instance.
4
+ * This is invoked by `initializeRebaseBackend()` — never call it manually.
5
+ */
6
+ export declare function _initRebase(client: RebaseClient): void;
7
+ /**
8
+ * @internal Allows overriding the underlying instance for unit testing.
9
+ * Throws an error if used in a non-test environment to prevent production abuse.
10
+ */
11
+ export declare function _setRebaseMock(mockInstance: Partial<RebaseClient>): void;
12
+ /**
13
+ * @internal Resets the singleton instance, useful for afterEach() in test suites.
14
+ */
15
+ export declare function _resetRebaseMock(): void;
16
+ /**
17
+ * The server-side Rebase singleton.
18
+ *
19
+ * Initialized automatically during server startup. Provides access to all
20
+ * app-scoped services: **data**, **auth**, **storage**, and **email**.
21
+ *
22
+ * `rebase.data` runs with **admin privileges** (no RLS). For user-scoped
23
+ * queries inside request handlers, continue using the handler's context
24
+ * or the RLS-scoped driver.
25
+ *
26
+ * @example
27
+ * ```typescript
28
+ * import { rebase } from "@rebasepro/server-core";
29
+ *
30
+ * // In a Hono handler, cron job, hook, or service file:
31
+ * await rebase.email?.send({ to: "admin@co.com", subject: "Alert", html: "<p>Hi</p>" });
32
+ * const jobs = await rebase.data.jobs.find({ limit: 10 });
33
+ * ```
34
+ */
35
+ export declare const rebase: RebaseClient;
@@ -0,0 +1,46 @@
1
+ /**
2
+ * Local filesystem storage controller
3
+ */
4
+ import { StorageController, LocalStorageConfig } from "./types";
5
+ import { UploadFileProps, UploadFileResult, DownloadConfig, StorageListResult } from "@rebasepro/types";
6
+ /**
7
+ * Local filesystem storage implementation
8
+ * Stores files in a directory structure: {basePath}/{bucket}/{path}
9
+ */
10
+ export declare class LocalStorageController implements StorageController {
11
+ private config;
12
+ private basePath;
13
+ constructor(config: LocalStorageConfig);
14
+ getType(): "local";
15
+ /**
16
+ * Ensure directory exists, creating it if necessary
17
+ */
18
+ private ensureDir;
19
+ /**
20
+ * Get the full filesystem path for a storage path.
21
+ * Includes a path traversal guard to prevent escaping the base directory.
22
+ */
23
+ private getFullPath;
24
+ /**
25
+ * Validate file before upload
26
+ */
27
+ private validateFile;
28
+ putObject({ file, key, metadata, bucket }: UploadFileProps): Promise<UploadFileResult>;
29
+ getSignedUrl(key: string, bucket?: string): Promise<DownloadConfig>;
30
+ getObject(key: string, bucket?: string): Promise<File | null>;
31
+ deleteObject(key: string, bucket?: string): Promise<void>;
32
+ listObjects(prefix: string, options?: {
33
+ bucket?: string;
34
+ maxResults?: number;
35
+ pageToken?: string;
36
+ }): Promise<StorageListResult>;
37
+ /**
38
+ * Get the absolute filesystem path for serving files
39
+ * Used by the storage routes to serve files directly
40
+ */
41
+ getAbsolutePath(key: string, bucket?: string): string;
42
+ /**
43
+ * Get the base path for the storage
44
+ */
45
+ getBasePath(): string;
46
+ }
@@ -0,0 +1,36 @@
1
+ /**
2
+ * S3-compatible storage controller (works with AWS S3 and MinIO)
3
+ */
4
+ import { StorageController, S3StorageConfig } from "./types";
5
+ import { UploadFileProps, UploadFileResult, DownloadConfig, StorageListResult } from "@rebasepro/types";
6
+ /**
7
+ * S3-compatible storage implementation
8
+ * Works with AWS S3 and MinIO (with forcePathStyle option)
9
+ */
10
+ export declare class S3StorageController implements StorageController {
11
+ private config;
12
+ private client;
13
+ constructor(config: S3StorageConfig);
14
+ getType(): "s3";
15
+ /**
16
+ * Validate file before upload
17
+ */
18
+ private validateFile;
19
+ /**
20
+ * Get the bucket name - either from parameter or config
21
+ */
22
+ private getBucket;
23
+ putObject({ file, key, metadata, bucket }: UploadFileProps): Promise<UploadFileResult>;
24
+ /**
25
+ * Flatten nested metadata to string values (S3 requirement)
26
+ */
27
+ private flattenMetadata;
28
+ getSignedUrl(key: string, bucket?: string): Promise<DownloadConfig>;
29
+ getObject(key: string, bucket?: string): Promise<File | null>;
30
+ deleteObject(key: string, bucket?: string): Promise<void>;
31
+ listObjects(prefix: string, options?: {
32
+ bucket?: string;
33
+ maxResults?: number;
34
+ pageToken?: string;
35
+ }): Promise<StorageListResult>;
36
+ }
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Storage module for Rebase backend
3
+ *
4
+ * Provides pluggable file storage with two built-in providers:
5
+ * - **Local filesystem** — zero config, great for dev and single-server deployments.
6
+ * - **S3-compatible** — works with AWS S3, Cloudflare R2, MinIO, Hetzner Object Storage,
7
+ * Backblaze B2, DigitalOcean Spaces, and GCS (via S3 interop).
8
+ *
9
+ * For other providers (native GCS SDK, Azure Blob, etc.), implement the
10
+ * `StorageController` interface and pass the instance directly to the `storage` config.
11
+ */
12
+ export * from "./types";
13
+ export { LocalStorageController } from "./LocalStorageController";
14
+ export { S3StorageController } from "./S3StorageController";
15
+ export { createStorageRoutes } from "./routes";
16
+ export type { StorageRoutesConfig } from "./routes";
17
+ export * from "./storage-registry";
18
+ import { BackendStorageConfig, StorageController } from "./types";
19
+ /**
20
+ * Create a storage controller from a config object.
21
+ *
22
+ * For custom providers, implement `StorageController` directly instead
23
+ * of going through this factory.
24
+ */
25
+ export declare function createStorageController(config: BackendStorageConfig): StorageController;
@@ -0,0 +1,38 @@
1
+ /**
2
+ * Storage REST API routes using Hono
3
+ */
4
+ import { Hono } from "hono";
5
+ import { StorageController } from "./types";
6
+ import { HonoEnv } from "../api/types";
7
+ export interface StorageRoutesConfig {
8
+ controller: StorageController;
9
+ /** Base path for storage routes (default: '/api/storage') */
10
+ basePath?: string;
11
+ /** Require authentication for write operations (default: true) */
12
+ requireAuth?: boolean;
13
+ /** Allow unauthenticated read access to stored files (default: false).
14
+ * When false and requireAuth is true, reads also require authentication. */
15
+ publicRead?: boolean;
16
+ }
17
+ /**
18
+ * Extract the wildcard portion of a route path from the full request path.
19
+ *
20
+ * Hono's `c.req.param('*')` does not work reliably in sub-routers mounted
21
+ * via `app.route(prefix, subRouter)`. Instead we derive the wildcard value
22
+ * from the fully-resolved `c.req.path` and `c.req.routePath`.
23
+ *
24
+ * For a route `/metadata/*` mounted at `/api/storage`, a request to
25
+ * `/api/storage/metadata/default/file.jpg` yields routePath
26
+ * `/api/storage/metadata/*`. We strip the prefix (everything before `/*`)
27
+ * plus one character for the trailing `/` to obtain `default/file.jpg`.
28
+ */
29
+ export declare function extractWildcardPath(c: {
30
+ req: {
31
+ path: string;
32
+ routePath: string;
33
+ };
34
+ }): string;
35
+ /**
36
+ * Create storage REST API routes
37
+ */
38
+ export declare function createStorageRoutes(config: StorageRoutesConfig): Hono<HonoEnv>;
@@ -0,0 +1,78 @@
1
+ /**
2
+ * Storage Registry
3
+ *
4
+ * Manages multiple storage controllers for Rebase backend.
5
+ * Allows different storage backends for different use cases.
6
+ *
7
+ * Usage:
8
+ * - Single storage: Pass a single StorageController → maps to "(default)"
9
+ * - Multiple storages: Pass a map of { storageId: StorageController }
10
+ * - String properties use `storageId` in their config to specify which storage to use
11
+ * - Properties without `storageId` fallback to "(default)"
12
+ */
13
+ import { StorageController } from "./types";
14
+ /**
15
+ * The default storage identifier used when:
16
+ * - A single storage controller is provided (not a map)
17
+ * - A property doesn't specify a storageId
18
+ */
19
+ export declare const DEFAULT_STORAGE_ID = "(default)";
20
+ /**
21
+ * Registry for managing multiple storage controllers
22
+ */
23
+ export interface StorageRegistry {
24
+ /**
25
+ * Register a storage controller with an ID
26
+ * @param id - Unique identifier for this storage (e.g., "media", "backups")
27
+ * @param controller - The StorageController instance
28
+ */
29
+ register(id: string, controller: StorageController): void;
30
+ /**
31
+ * Get the default storage controller (id = "(default)")
32
+ * @throws Error if no default storage is registered
33
+ */
34
+ getDefault(): StorageController;
35
+ /**
36
+ * Get a storage controller by ID
37
+ * @param id - Storage identifier, or undefined/null for default
38
+ * @returns The StorageController, or undefined if not found
39
+ */
40
+ get(id: string | undefined | null): StorageController | undefined;
41
+ /**
42
+ * Get a storage controller by ID, with fallback to default
43
+ * @param id - Storage identifier, or undefined/null for default
44
+ * @returns The StorageController (falls back to default if id not found)
45
+ * @throws Error if neither the specified nor default storage exists
46
+ */
47
+ getOrDefault(id: string | undefined | null): StorageController;
48
+ /**
49
+ * Check if a storage with the given ID exists
50
+ */
51
+ has(id: string): boolean;
52
+ /**
53
+ * List all registered storage IDs
54
+ */
55
+ list(): string[];
56
+ /**
57
+ * Get the number of registered storage controllers
58
+ */
59
+ size(): number;
60
+ }
61
+ /**
62
+ * Default implementation of StorageRegistry
63
+ */
64
+ export declare class DefaultStorageRegistry implements StorageRegistry {
65
+ private controllers;
66
+ /**
67
+ * Create a StorageRegistry from either a single controller or a map
68
+ * @param input - Single StorageController (maps to "(default)") or Record<string, StorageController>
69
+ */
70
+ static create(input: StorageController | Record<string, StorageController>): DefaultStorageRegistry;
71
+ register(id: string, controller: StorageController): void;
72
+ getDefault(): StorageController;
73
+ get(id: string | undefined | null): StorageController | undefined;
74
+ getOrDefault(id: string | undefined | null): StorageController;
75
+ has(id: string): boolean;
76
+ list(): string[];
77
+ size(): number;
78
+ }
@@ -0,0 +1,103 @@
1
+ /**
2
+ * Storage configuration and types for Rebase backend
3
+ */
4
+ import { UploadFileProps, UploadFileResult, DownloadConfig, StorageListResult } from "@rebasepro/types";
5
+ /**
6
+ * Local filesystem storage configuration
7
+ */
8
+ export interface LocalStorageConfig {
9
+ type: "local";
10
+ /** Base directory for file storage (e.g., './uploads') */
11
+ basePath: string;
12
+ /** Maximum file size in bytes (default: 50MB) */
13
+ maxFileSize?: number;
14
+ /** Allowed MIME types (if not set, all types allowed) */
15
+ allowedMimeTypes?: string[];
16
+ /** Base URL for generating download URLs (default: auto-detected from request) */
17
+ baseUrl?: string;
18
+ }
19
+ /**
20
+ * S3-compatible storage configuration (works with AWS S3 and MinIO)
21
+ */
22
+ export interface S3StorageConfig {
23
+ type: "s3";
24
+ /** S3 bucket name */
25
+ bucket: string;
26
+ /** AWS region (e.g., 'us-east-1') */
27
+ region?: string;
28
+ /** Custom endpoint URL (required for MinIO, Cloudflare R2, Hetzner Object Storage) */
29
+ endpoint?: string;
30
+ /** AWS access key ID */
31
+ accessKeyId: string;
32
+ /** AWS secret access key */
33
+ secretAccessKey: string;
34
+ /** Use path-style URLs (required for MinIO) */
35
+ forcePathStyle?: boolean;
36
+ /** Maximum file size in bytes (default: 50MB) */
37
+ maxFileSize?: number;
38
+ /** Allowed MIME types (if not set, all types allowed) */
39
+ allowedMimeTypes?: string[];
40
+ /** URL expiration time in seconds for signed URLs (default: 3600) */
41
+ signedUrlExpiration?: number;
42
+ }
43
+ /**
44
+ * Storage configuration — local filesystem or S3-compatible.
45
+ *
46
+ * **Built-in providers:**
47
+ * - `local` — Zero-config filesystem storage. Great for dev and single-server deployments (Hetzner, bare metal).
48
+ * - `s3` — Any S3-compatible provider. AWS S3, Cloudflare R2, MinIO, Hetzner Object Storage,
49
+ * Backblaze B2, DigitalOcean Spaces, and even GCS (via its S3-compatible interoperability API).
50
+ *
51
+ * **Custom providers:**
52
+ * For cloud-native storage (GCS, Azure Blob, etc.), implement the `StorageController`
53
+ * interface and pass the instance directly to the `storage` config.
54
+ */
55
+ export type BackendStorageConfig = LocalStorageConfig | S3StorageConfig;
56
+ /**
57
+ * Storage controller interface for backend implementations
58
+ */
59
+ export interface StorageController {
60
+ /**
61
+ * Upload an object
62
+ */
63
+ putObject(props: UploadFileProps): Promise<UploadFileResult>;
64
+ /**
65
+ * Get a download URL (signed URL equivalent) for an object
66
+ */
67
+ getSignedUrl(key: string, bucket?: string): Promise<DownloadConfig>;
68
+ /**
69
+ * Get object as a File
70
+ */
71
+ getObject(key: string, bucket?: string): Promise<File | null>;
72
+ /**
73
+ * Delete an object
74
+ */
75
+ deleteObject(key: string, bucket?: string): Promise<void>;
76
+ /**
77
+ * List objects in a prefix
78
+ */
79
+ listObjects(prefix: string, options?: {
80
+ bucket?: string;
81
+ maxResults?: number;
82
+ pageToken?: string;
83
+ }): Promise<StorageListResult>;
84
+ /**
85
+ * Get the storage provider identifier.
86
+ *
87
+ * Built-in values are `'local'` and `'s3'`. Custom implementations
88
+ * should return their own identifier (e.g. `'gcs'`, `'azure'`).
89
+ */
90
+ getType(): string;
91
+ }
92
+ /**
93
+ * Default maximum file size (50MB)
94
+ */
95
+ export declare const DEFAULT_MAX_FILE_SIZE: number;
96
+ /**
97
+ * Common image MIME types
98
+ */
99
+ export declare const IMAGE_MIME_TYPES: string[];
100
+ /**
101
+ * Common document MIME types
102
+ */
103
+ export declare const DOCUMENT_MIME_TYPES: string[];
@@ -0,0 +1,11 @@
1
+ import { Entity, FetchCollectionProps, FetchEntityProps } from "@rebasepro/types";
2
+ export interface ListenCollectionRequest<M extends Record<string, unknown> = Record<string, unknown>> extends FetchCollectionProps<M> {
3
+ subscriptionId: string;
4
+ onUpdate: (entities: Entity<M>[]) => void;
5
+ onError?: (error: Error) => void;
6
+ }
7
+ export interface ListenEntityRequest<M extends Record<string, unknown> = Record<string, unknown>> extends FetchEntityProps<M> {
8
+ subscriptionId: string;
9
+ onUpdate: (entity: Entity<M> | null) => void;
10
+ onError?: (error: Error) => void;
11
+ }
@@ -0,0 +1,35 @@
1
+ /**
2
+ * Dev-mode port resolution utilities.
3
+ *
4
+ * Provides a `listen` wrapper that automatically retries the next port when
5
+ * the requested one is already in use, and writes the resolved port to a
6
+ * well-known temp file so the CLI / frontend can discover it.
7
+ *
8
+ * Port affinity: when a port file already exists (e.g. after a tsx watch
9
+ * restart), the saved port is tried FIRST so the backend stays on the same
10
+ * port the frontend was configured with.
11
+ *
12
+ * This module is dev-only and should never run in production.
13
+ */
14
+ import type { Server } from "http";
15
+ /** Filename written next to the project `.env` so the CLI can read it. */
16
+ export declare const DEV_PORT_FILENAME = ".rebase-dev-port";
17
+ /**
18
+ * Try to `listen` on `startPort`. If the port is busy (`EADDRINUSE`), increment
19
+ * and retry up to `maxAttempts` times.
20
+ *
21
+ * When a port file already exists (written by a previous run), the saved port
22
+ * is tried first to maintain port affinity across tsx watch restarts.
23
+ *
24
+ * Resolves with the port that was actually bound.
25
+ */
26
+ export declare function listenWithPortRetry(server: Server, startPort: number, options?: {
27
+ host?: string;
28
+ maxAttempts?: number;
29
+ /** Absolute path to write the resolved port file into. Defaults to `process.cwd()`. */
30
+ portFileDir?: string;
31
+ }): Promise<number>;
32
+ /**
33
+ * Clean up the dev port file and state file (call on graceful shutdown).
34
+ */
35
+ export declare function cleanupDevPortFile(dir: string): void;
@@ -0,0 +1,31 @@
1
+ /**
2
+ * Structured Logger for Rebase Backend
3
+ *
4
+ * Outputs JSON lines when `NODE_ENV=production`, human-readable prefixed
5
+ * lines otherwise. Designed to work with Google Cloud Logging severity levels.
6
+ *
7
+ * Usage:
8
+ * import { logger } from "./utils/logger";
9
+ * logger.info("Server started", { port: 3001 });
10
+ * logger.error("Request failed", { path: "/api/test", error: err });
11
+ */
12
+ export type LogLevel = "debug" | "info" | "warn" | "error";
13
+ export interface LogEntry {
14
+ severity: string;
15
+ message: string;
16
+ timestamp: string;
17
+ [key: string]: unknown;
18
+ }
19
+ export interface Logger {
20
+ debug(message: string, data?: Record<string, unknown>): void;
21
+ info(message: string, data?: Record<string, unknown>): void;
22
+ warn(message: string, data?: Record<string, unknown>): void;
23
+ error(message: string, data?: Record<string, unknown>): void;
24
+ child(defaultFields: Record<string, unknown>): Logger;
25
+ }
26
+ /**
27
+ * Singleton logger instance.
28
+ * In production: emits JSON lines with `severity`, `message`, `timestamp`.
29
+ * In development: emits human-readable prefixed lines.
30
+ */
31
+ export declare const logger: Logger;
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Configure console log levels based on environment variable
3
+ * Call this early in your application to set up proper logging levels
4
+ */
5
+ export declare function configureLogLevel(logLevel?: string): void;
6
+ /**
7
+ * Reset console methods to their original state
8
+ */
9
+ export declare function resetConsole(): void;
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Structured HTTP request logging middleware for Hono.
3
+ *
4
+ * Logs every request with method, path, status code, latency, and
5
+ * content-length. In production, outputs JSON for Cloud Logging; in
6
+ * development, emits a coloured one-liner.
7
+ *
8
+ * @example
9
+ * ```ts
10
+ * import { requestLogger } from "@rebasepro/server-core";
11
+ * app.use("/*", requestLogger());
12
+ * ```
13
+ */
14
+ import type { MiddlewareHandler } from "hono";
15
+ export interface RequestLoggerOptions {
16
+ /** Paths to skip logging (e.g. "/health"). Supports exact match. */
17
+ skip?: string[];
18
+ }
19
+ export declare function requestLogger(options?: RequestLoggerOptions): MiddlewareHandler;
@@ -0,0 +1,27 @@
1
+ import { SQL } from "drizzle-orm";
2
+ /**
3
+ * Returns a SQL chunk calling `auth.uid()` — the current user's ID.
4
+ * This is a Supabase-style helper function created in the `auth` schema
5
+ * that reads `app.user_id` set per-transaction by `withAuth()`.
6
+ *
7
+ * @example
8
+ * sql`${table.user_id} = ${authUid()}`
9
+ */
10
+ export declare const authUid: () => SQL;
11
+ /**
12
+ * Returns a SQL chunk calling `auth.roles()` — the current user's roles
13
+ * as a comma-separated string.
14
+ * Reads `app.user_roles` set per-transaction by `withAuth()`.
15
+ *
16
+ * @example
17
+ * sql`auth.roles() ~ 'admin'`
18
+ */
19
+ export declare const authRoles: () => SQL;
20
+ /**
21
+ * Returns a SQL chunk calling `auth.jwt()` — the full JWT claims as JSONB.
22
+ * Reads `app.jwt` set per-transaction by `withAuth()`.
23
+ *
24
+ * @example
25
+ * sql`auth.jwt()->>'sub'`
26
+ */
27
+ export declare const authJwt: () => SQL;
@@ -0,0 +1,7 @@
1
+ export type AnalyticsController = {
2
+ /**
3
+ * Callback used to get analytics events from the CMS
4
+ */
5
+ onAnalyticsEvent?: (event: AnalyticsEvent, data?: object) => void;
6
+ };
7
+ export type AnalyticsEvent = "entity_click" | "entity_click_from_reference" | "reference_selection_clear" | "reference_selection_toggle" | "reference_selected_single" | "reference_selection_new_entity" | "edit_entity_clicked" | "entity_edited" | "new_entity_click" | "new_entity_saved" | "copy_entity_click" | "entity_copied" | "single_delete_dialog_open" | "multiple_delete_dialog_open" | "single_entity_deleted" | "multiple_entities_deleted" | "drawer_navigate_to_home" | "drawer_navigate_to_collection" | "drawer_navigate_to_view" | "home_navigate_to_collection" | "home_favorite_navigate_to_collection" | "home_navigate_to_view" | "home_navigate_to_admin_view" | "home_favorite_navigate_to_view" | "home_move_card" | "home_move_group" | "home_drop_new_group" | "collection_inline_editing" | "view_mode_changed" | "kanban_card_moved" | "kanban_column_reorder" | "kanban_property_changed" | "kanban_new_entity_in_column" | "kanban_backfill_order" | "card_view_entity_click" | "unmapped_event";
@@ -0,0 +1,119 @@
1
+ import { StorageSource } from "./storage";
2
+ import { Role, User } from "../users";
3
+ import { RebaseData } from "./data";
4
+ /**
5
+ * Capabilities advertised by an auth provider.
6
+ * UI components use this to show/hide features dynamically
7
+ * (e.g. password reset, registration, session management).
8
+ * @group Hooks and utilities
9
+ */
10
+ export interface AuthCapabilities {
11
+ emailPasswordLogin?: boolean;
12
+ googleLogin?: boolean;
13
+ registration?: boolean;
14
+ passwordReset?: boolean;
15
+ sessionManagement?: boolean;
16
+ profileUpdate?: boolean;
17
+ emailVerification?: boolean;
18
+ /** List of enabled OAuth provider IDs (e.g. ["google", "github", "discord"]) */
19
+ enabledProviders?: string[];
20
+ }
21
+ /**
22
+ * Controller for retrieving the logged user or performing auth related operations.
23
+ * Note that if you are implementing your AuthController, you probably will want
24
+ * to do it as the result of a hook.
25
+ * @group Hooks and utilities
26
+ */
27
+ export type AuthController<USER extends User = User, ExtraData = unknown> = {
28
+ /**
29
+ * The user currently logged in
30
+ * The values can be: the user object, null if they skipped login
31
+ */
32
+ user: USER | null;
33
+ /**
34
+ * Initial loading flag. It is used not to display the login screen
35
+ * when the app first loads, and it has not been checked whether the user
36
+ * is logged in or not.
37
+ */
38
+ initialLoading?: boolean;
39
+ /**
40
+ * Loading flag. It is used to display a loading screen when the user is
41
+ * logging in or out.
42
+ */
43
+ authLoading: boolean;
44
+ /**
45
+ * Sign out
46
+ */
47
+ signOut: () => Promise<void>;
48
+ /**
49
+ * Error initializing the authentication
50
+ */
51
+ authError?: unknown;
52
+ /**
53
+ * Error dispatched by the auth provider
54
+ */
55
+ authProviderError?: unknown;
56
+ /**
57
+ * You can use this method to retrieve the auth token for the current user.
58
+ */
59
+ getAuthToken: () => Promise<string>;
60
+ /**
61
+ * Has the user skipped the login process
62
+ */
63
+ loginSkipped: boolean;
64
+ extra: ExtraData;
65
+ setExtra: (extra: ExtraData) => void;
66
+ setUser?(user: USER | null): void;
67
+ setUserRoles?(roles: Role[]): void;
68
+ /**
69
+ * Capabilities advertised by the auth provider.
70
+ * UI components use this to feature-detect what the backend supports.
71
+ */
72
+ capabilities?: AuthCapabilities;
73
+ };
74
+ /**
75
+ * Extended auth controller with common optional auth methods.
76
+ * Backend implementations (Rebase backend, Firebase, Supabase, etc.)
77
+ * extend this with their own backend-specific extras.
78
+ * @group Hooks and utilities
79
+ */
80
+ export interface AuthControllerExtended<USER extends User = User, ExtraData = unknown> extends AuthController<USER, ExtraData> {
81
+ /** Login with email and password */
82
+ emailPasswordLogin?(email: string, password: string): Promise<void>;
83
+ /** Login with a Google ID token or trigger Google popup */
84
+ googleLogin?(idToken: string): Promise<void>;
85
+ /** Register a new user */
86
+ register?(email: string, password: string, displayName?: string): Promise<void>;
87
+ /** Skip login (for anonymous access if enabled) */
88
+ skipLogin?(): void;
89
+ /** Request password reset email */
90
+ forgotPassword?(email: string): Promise<void>;
91
+ /** Reset password using a token */
92
+ resetPassword?(token: string, password: string): Promise<void>;
93
+ /** Change password for the authenticated user */
94
+ changePassword?(oldPassword: string, newPassword: string): Promise<void>;
95
+ /** Update user profile */
96
+ updateProfile?(displayName?: string, photoURL?: string): Promise<USER>;
97
+ }
98
+ /**
99
+ * Implement this function to allow access to specific users.
100
+ * @group Hooks and utilities
101
+ */
102
+ export type Authenticator<USER extends User = User> = (props: {
103
+ /**
104
+ * Logged-in user or null
105
+ */
106
+ user: USER | null;
107
+ /**
108
+ * AuthController
109
+ */
110
+ authController: AuthController<USER>;
111
+ /**
112
+ * Unified data access API
113
+ */
114
+ data: RebaseData;
115
+ /**
116
+ * Used storage implementation
117
+ */
118
+ storageSource: StorageSource;
119
+ }) => boolean | Promise<boolean>;