@rebasepro/server-core 0.0.1-canary.4d4fb3e

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 (254) 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 +48 -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 +36 -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 +12 -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-BeMqpmfQ.js +239 -0
  78. package/dist/index-BeMqpmfQ.js.map +1 -0
  79. package/dist/index-bl4J3lNb.js +55823 -0
  80. package/dist/index-bl4J3lNb.js.map +1 -0
  81. package/dist/index.es.js +58 -0
  82. package/dist/index.es.js.map +1 -0
  83. package/dist/index.umd.js +56062 -0
  84. package/dist/index.umd.js.map +1 -0
  85. package/dist/server-core/src/api/ast-schema-editor.d.ts +21 -0
  86. package/dist/server-core/src/api/collections_for_test/callbacks_test_collection.d.ts +2 -0
  87. package/dist/server-core/src/api/errors.d.ts +35 -0
  88. package/dist/server-core/src/api/graphql/graphql-schema-generator.d.ts +35 -0
  89. package/dist/server-core/src/api/graphql/index.d.ts +1 -0
  90. package/dist/server-core/src/api/index.d.ts +9 -0
  91. package/dist/server-core/src/api/openapi-generator.d.ts +2 -0
  92. package/dist/server-core/src/api/rest/api-generator.d.ts +64 -0
  93. package/dist/server-core/src/api/rest/index.d.ts +1 -0
  94. package/dist/server-core/src/api/rest/query-parser.d.ts +9 -0
  95. package/dist/server-core/src/api/schema-editor-routes.d.ts +3 -0
  96. package/dist/server-core/src/api/server.d.ts +40 -0
  97. package/dist/server-core/src/api/types.d.ts +90 -0
  98. package/dist/server-core/src/auth/admin-routes.d.ts +7 -0
  99. package/dist/server-core/src/auth/google-oauth.d.ts +20 -0
  100. package/dist/server-core/src/auth/index.d.ts +12 -0
  101. package/dist/server-core/src/auth/interfaces.d.ts +270 -0
  102. package/dist/server-core/src/auth/jwt.d.ts +42 -0
  103. package/dist/server-core/src/auth/middleware.d.ts +56 -0
  104. package/dist/server-core/src/auth/password.d.ts +22 -0
  105. package/dist/server-core/src/auth/rate-limiter.d.ts +31 -0
  106. package/dist/server-core/src/auth/routes.d.ts +17 -0
  107. package/dist/server-core/src/bootstrappers/index.d.ts +0 -0
  108. package/dist/server-core/src/collections/BackendCollectionRegistry.d.ts +13 -0
  109. package/dist/server-core/src/collections/loader.d.ts +5 -0
  110. package/dist/server-core/src/db/interfaces.d.ts +18 -0
  111. package/dist/server-core/src/email/index.d.ts +6 -0
  112. package/dist/server-core/src/email/smtp-email-service.d.ts +25 -0
  113. package/dist/server-core/src/email/templates.d.ts +33 -0
  114. package/dist/server-core/src/email/types.d.ts +110 -0
  115. package/dist/server-core/src/functions/function-loader.d.ts +17 -0
  116. package/dist/server-core/src/functions/function-routes.d.ts +10 -0
  117. package/dist/server-core/src/functions/index.d.ts +3 -0
  118. package/dist/server-core/src/history/history-routes.d.ts +23 -0
  119. package/dist/server-core/src/history/index.d.ts +1 -0
  120. package/dist/server-core/src/index.d.ts +24 -0
  121. package/dist/server-core/src/init.d.ts +49 -0
  122. package/dist/server-core/src/serve-spa.d.ts +30 -0
  123. package/dist/server-core/src/services/driver-registry.d.ts +78 -0
  124. package/dist/server-core/src/storage/LocalStorageController.d.ts +46 -0
  125. package/dist/server-core/src/storage/S3StorageController.d.ts +36 -0
  126. package/dist/server-core/src/storage/index.d.ts +18 -0
  127. package/dist/server-core/src/storage/routes.d.ts +38 -0
  128. package/dist/server-core/src/storage/storage-registry.d.ts +78 -0
  129. package/dist/server-core/src/storage/types.d.ts +91 -0
  130. package/dist/server-core/src/types/index.d.ts +11 -0
  131. package/dist/server-core/src/utils/logging.d.ts +9 -0
  132. package/dist/server-core/src/utils/sql.d.ts +27 -0
  133. package/dist/types/src/controllers/analytics_controller.d.ts +7 -0
  134. package/dist/types/src/controllers/auth.d.ts +117 -0
  135. package/dist/types/src/controllers/client.d.ts +58 -0
  136. package/dist/types/src/controllers/collection_registry.d.ts +44 -0
  137. package/dist/types/src/controllers/customization_controller.d.ts +54 -0
  138. package/dist/types/src/controllers/data.d.ts +141 -0
  139. package/dist/types/src/controllers/data_driver.d.ts +168 -0
  140. package/dist/types/src/controllers/database_admin.d.ts +11 -0
  141. package/dist/types/src/controllers/dialogs_controller.d.ts +36 -0
  142. package/dist/types/src/controllers/effective_role.d.ts +4 -0
  143. package/dist/types/src/controllers/index.d.ts +17 -0
  144. package/dist/types/src/controllers/local_config_persistence.d.ts +20 -0
  145. package/dist/types/src/controllers/navigation.d.ts +213 -0
  146. package/dist/types/src/controllers/registry.d.ts +51 -0
  147. package/dist/types/src/controllers/side_dialogs_controller.d.ts +67 -0
  148. package/dist/types/src/controllers/side_entity_controller.d.ts +89 -0
  149. package/dist/types/src/controllers/snackbar.d.ts +24 -0
  150. package/dist/types/src/controllers/storage.d.ts +173 -0
  151. package/dist/types/src/index.d.ts +4 -0
  152. package/dist/types/src/rebase_context.d.ts +101 -0
  153. package/dist/types/src/types/backend.d.ts +533 -0
  154. package/dist/types/src/types/builders.d.ts +14 -0
  155. package/dist/types/src/types/chips.d.ts +5 -0
  156. package/dist/types/src/types/collections.d.ts +812 -0
  157. package/dist/types/src/types/data_source.d.ts +64 -0
  158. package/dist/types/src/types/entities.d.ts +145 -0
  159. package/dist/types/src/types/entity_actions.d.ts +98 -0
  160. package/dist/types/src/types/entity_callbacks.d.ts +173 -0
  161. package/dist/types/src/types/entity_link_builder.d.ts +7 -0
  162. package/dist/types/src/types/entity_overrides.d.ts +9 -0
  163. package/dist/types/src/types/entity_views.d.ts +61 -0
  164. package/dist/types/src/types/export_import.d.ts +21 -0
  165. package/dist/types/src/types/index.d.ts +22 -0
  166. package/dist/types/src/types/locales.d.ts +4 -0
  167. package/dist/types/src/types/modify_collections.d.ts +5 -0
  168. package/dist/types/src/types/plugins.d.ts +225 -0
  169. package/dist/types/src/types/properties.d.ts +1091 -0
  170. package/dist/types/src/types/property_config.d.ts +70 -0
  171. package/dist/types/src/types/relations.d.ts +336 -0
  172. package/dist/types/src/types/slots.d.ts +228 -0
  173. package/dist/types/src/types/translations.d.ts +826 -0
  174. package/dist/types/src/types/user_management_delegate.d.ts +120 -0
  175. package/dist/types/src/types/websockets.d.ts +78 -0
  176. package/dist/types/src/users/index.d.ts +2 -0
  177. package/dist/types/src/users/roles.d.ts +22 -0
  178. package/dist/types/src/users/user.d.ts +46 -0
  179. package/history_diff.log +385 -0
  180. package/jest.config.cjs +16 -0
  181. package/package.json +86 -0
  182. package/scratch.ts +8 -0
  183. package/src/api/ast-schema-editor.ts +289 -0
  184. package/src/api/collections_for_test/callbacks_test_collection.ts +57 -0
  185. package/src/api/errors.ts +155 -0
  186. package/src/api/graphql/graphql-schema-generator.ts +334 -0
  187. package/src/api/graphql/index.ts +2 -0
  188. package/src/api/index.ts +11 -0
  189. package/src/api/openapi-generator.ts +160 -0
  190. package/src/api/rest/api-generator.ts +466 -0
  191. package/src/api/rest/index.ts +2 -0
  192. package/src/api/rest/query-parser.ts +155 -0
  193. package/src/api/schema-editor-routes.ts +39 -0
  194. package/src/api/server.ts +245 -0
  195. package/src/api/types.ts +90 -0
  196. package/src/auth/admin-routes.ts +488 -0
  197. package/src/auth/google-oauth.ts +60 -0
  198. package/src/auth/index.ts +21 -0
  199. package/src/auth/interfaces.ts +316 -0
  200. package/src/auth/jwt.ts +164 -0
  201. package/src/auth/middleware.ts +235 -0
  202. package/src/auth/password.ts +75 -0
  203. package/src/auth/rate-limiter.ts +129 -0
  204. package/src/auth/routes.ts +730 -0
  205. package/src/bootstrappers/index.ts +1 -0
  206. package/src/collections/BackendCollectionRegistry.ts +20 -0
  207. package/src/collections/loader.ts +49 -0
  208. package/src/db/interfaces.ts +60 -0
  209. package/src/email/index.ts +17 -0
  210. package/src/email/smtp-email-service.ts +88 -0
  211. package/src/email/templates.ts +301 -0
  212. package/src/email/types.ts +112 -0
  213. package/src/functions/function-loader.ts +91 -0
  214. package/src/functions/function-routes.ts +31 -0
  215. package/src/functions/index.ts +3 -0
  216. package/src/history/history-routes.ts +128 -0
  217. package/src/history/index.ts +2 -0
  218. package/src/index.ts +56 -0
  219. package/src/init.ts +309 -0
  220. package/src/serve-spa.ts +81 -0
  221. package/src/services/driver-registry.ts +182 -0
  222. package/src/storage/LocalStorageController.ts +368 -0
  223. package/src/storage/S3StorageController.ts +295 -0
  224. package/src/storage/index.ts +32 -0
  225. package/src/storage/routes.ts +247 -0
  226. package/src/storage/storage-registry.ts +187 -0
  227. package/src/storage/types.ts +122 -0
  228. package/src/types/index.ts +27 -0
  229. package/src/utils/logging.ts +35 -0
  230. package/src/utils/sql.ts +38 -0
  231. package/test/admin-routes.test.ts +591 -0
  232. package/test/api-generator.test.ts +458 -0
  233. package/test/ast-schema-editor.test.ts +61 -0
  234. package/test/auth-middleware-hono.test.ts +321 -0
  235. package/test/auth-routes.test.ts +868 -0
  236. package/test/driver-registry.test.ts +280 -0
  237. package/test/errors-hono.test.ts +133 -0
  238. package/test/errors.test.ts +150 -0
  239. package/test/jwt-security.test.ts +173 -0
  240. package/test/jwt.test.ts +311 -0
  241. package/test/middleware.test.ts +295 -0
  242. package/test/password.test.ts +165 -0
  243. package/test/query-parser.test.ts +258 -0
  244. package/test/rate-limiter.test.ts +102 -0
  245. package/test/storage-local.test.ts +278 -0
  246. package/test/storage-registry.test.ts +280 -0
  247. package/test/storage-routes.test.ts +218 -0
  248. package/test/storage-s3.test.ts +301 -0
  249. package/test-ast.ts +28 -0
  250. package/test_output.txt +1133 -0
  251. package/tsconfig.json +49 -0
  252. package/tsconfig.prod.json +20 -0
  253. package/vite.config.ts +78 -0
  254. package/vite.config.ts.timestamp-1775065397568-8a853255edf6e.mjs +46 -0
@@ -0,0 +1,187 @@
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
+
14
+ import { StorageController } from "./types";
15
+
16
+ /**
17
+ * The default storage identifier used when:
18
+ * - A single storage controller is provided (not a map)
19
+ * - A property doesn't specify a storageId
20
+ */
21
+ export const DEFAULT_STORAGE_ID = "(default)";
22
+
23
+ /**
24
+ * Registry for managing multiple storage controllers
25
+ */
26
+ export interface StorageRegistry {
27
+ /**
28
+ * Register a storage controller with an ID
29
+ * @param id - Unique identifier for this storage (e.g., "media", "backups")
30
+ * @param controller - The StorageController instance
31
+ */
32
+ register(id: string, controller: StorageController): void;
33
+
34
+ /**
35
+ * Get the default storage controller (id = "(default)")
36
+ * @throws Error if no default storage is registered
37
+ */
38
+ getDefault(): StorageController;
39
+
40
+ /**
41
+ * Get a storage controller by ID
42
+ * @param id - Storage identifier, or undefined/null for default
43
+ * @returns The StorageController, or undefined if not found
44
+ */
45
+ get(id: string | undefined | null): StorageController | undefined;
46
+
47
+ /**
48
+ * Get a storage controller by ID, with fallback to default
49
+ * @param id - Storage identifier, or undefined/null for default
50
+ * @returns The StorageController (falls back to default if id not found)
51
+ * @throws Error if neither the specified nor default storage exists
52
+ */
53
+ getOrDefault(id: string | undefined | null): StorageController;
54
+
55
+ /**
56
+ * Check if a storage with the given ID exists
57
+ */
58
+ has(id: string): boolean;
59
+
60
+ /**
61
+ * List all registered storage IDs
62
+ */
63
+ list(): string[];
64
+
65
+ /**
66
+ * Get the number of registered storage controllers
67
+ */
68
+ size(): number;
69
+ }
70
+
71
+ /**
72
+ * Default implementation of StorageRegistry
73
+ */
74
+ export class DefaultStorageRegistry implements StorageRegistry {
75
+ private controllers = new Map<string, StorageController>();
76
+
77
+ /**
78
+ * Create a StorageRegistry from either a single controller or a map
79
+ * @param input - Single StorageController (maps to "(default)") or Record<string, StorageController>
80
+ */
81
+ static create(
82
+ input: StorageController | Record<string, StorageController>
83
+ ): DefaultStorageRegistry {
84
+ const registry = new DefaultStorageRegistry();
85
+
86
+ if (isStorageController(input)) {
87
+ // Single controller → register as "(default)"
88
+ registry.register(DEFAULT_STORAGE_ID, input);
89
+ } else {
90
+ // Map of controllers → register each
91
+ for (const [id, controller] of Object.entries(input)) {
92
+ if (isStorageController(controller)) {
93
+ registry.register(id, controller);
94
+ }
95
+ }
96
+ // Ensure there's a default if not explicitly provided
97
+ if (!registry.has(DEFAULT_STORAGE_ID) && registry.size() > 0) {
98
+ // If no explicit "(default)", use the first one as default
99
+ const firstId = Object.keys(input).find(k => isStorageController(input[k]));
100
+ if (firstId) {
101
+ console.warn(
102
+ `[StorageRegistry] No "${DEFAULT_STORAGE_ID}" storage provided. ` +
103
+ `Using "${firstId}" as the default.`
104
+ );
105
+ registry.register(DEFAULT_STORAGE_ID, input[firstId]);
106
+ }
107
+ }
108
+ }
109
+
110
+ return registry;
111
+ }
112
+
113
+ register(id: string, controller: StorageController): void {
114
+ if (this.controllers.has(id)) {
115
+ console.warn(`[StorageRegistry] Overwriting storage with id "${id}"`);
116
+ }
117
+ this.controllers.set(id, controller);
118
+ }
119
+
120
+ getDefault(): StorageController {
121
+ const controller = this.controllers.get(DEFAULT_STORAGE_ID);
122
+ if (!controller) {
123
+ throw new Error(
124
+ `[StorageRegistry] No default storage registered. ` +
125
+ `Register one with id "${DEFAULT_STORAGE_ID}" or pass a single StorageController.`
126
+ );
127
+ }
128
+ return controller;
129
+ }
130
+
131
+ get(id: string | undefined | null): StorageController | undefined {
132
+ if (id === undefined || id === null) {
133
+ return this.controllers.get(DEFAULT_STORAGE_ID);
134
+ }
135
+ return this.controllers.get(id);
136
+ }
137
+
138
+ getOrDefault(id: string | undefined | null): StorageController {
139
+ // If no ID specified, return default
140
+ if (id === undefined || id === null) {
141
+ return this.getDefault();
142
+ }
143
+
144
+ // Try to get by ID
145
+ const controller = this.controllers.get(id);
146
+ if (controller) {
147
+ return controller;
148
+ }
149
+
150
+ // Fallback to default with warning
151
+ console.warn(
152
+ `[StorageRegistry] Storage "${id}" not found, falling back to "${DEFAULT_STORAGE_ID}"`
153
+ );
154
+ return this.getDefault();
155
+ }
156
+
157
+ has(id: string): boolean {
158
+ return this.controllers.has(id);
159
+ }
160
+
161
+ list(): string[] {
162
+ return Array.from(this.controllers.keys());
163
+ }
164
+
165
+ size(): number {
166
+ return this.controllers.size;
167
+ }
168
+ }
169
+
170
+ /**
171
+ * Type guard to check if an object is a StorageController
172
+ * vs a Record<string, StorageController> (multiple storages)
173
+ */
174
+ function isStorageController(obj: unknown): obj is StorageController {
175
+ if (typeof obj !== "object" || obj === null) {
176
+ return false;
177
+ }
178
+ const controller = obj as StorageController;
179
+ // Check for required StorageController properties
180
+ return (
181
+ typeof controller.uploadFile === "function" &&
182
+ typeof controller.getDownloadURL === "function" &&
183
+ typeof controller.deleteFile === "function" &&
184
+ typeof controller.list === "function" &&
185
+ typeof controller.getType === "function"
186
+ );
187
+ }
@@ -0,0 +1,122 @@
1
+ /**
2
+ * Storage configuration and types for Rebase backend
3
+ */
4
+
5
+ import { StorageSource, UploadFileProps, UploadFileResult, DownloadConfig, StorageListResult, StorageReference } from "@rebasepro/types";
6
+
7
+ /**
8
+ * Local filesystem storage configuration
9
+ */
10
+ export interface LocalStorageConfig {
11
+ type: 'local';
12
+ /** Base directory for file storage (e.g., './uploads') */
13
+ basePath: string;
14
+ /** Maximum file size in bytes (default: 50MB) */
15
+ maxFileSize?: number;
16
+ /** Allowed MIME types (if not set, all types allowed) */
17
+ allowedMimeTypes?: string[];
18
+ /** Base URL for generating download URLs (default: auto-detected from request) */
19
+ baseUrl?: string;
20
+ }
21
+
22
+ /**
23
+ * S3-compatible storage configuration (works with AWS S3 and MinIO)
24
+ */
25
+ export interface S3StorageConfig {
26
+ type: 's3';
27
+ /** S3 bucket name */
28
+ bucket: string;
29
+ /** AWS region (e.g., 'us-east-1') */
30
+ region?: string;
31
+ /** Custom endpoint URL (required for MinIO) */
32
+ endpoint?: string;
33
+ /** AWS access key ID */
34
+ accessKeyId: string;
35
+ /** AWS secret access key */
36
+ secretAccessKey: string;
37
+ /** Use path-style URLs (required for MinIO) */
38
+ forcePathStyle?: boolean;
39
+ /** Maximum file size in bytes (default: 50MB) */
40
+ maxFileSize?: number;
41
+ /** Allowed MIME types (if not set, all types allowed) */
42
+ allowedMimeTypes?: string[];
43
+ /** URL expiration time in seconds for signed URLs (default: 3600) */
44
+ signedUrlExpiration?: number;
45
+ }
46
+
47
+ /**
48
+ * Storage configuration - either local filesystem or S3-compatible
49
+ */
50
+ export type BackendStorageConfig = LocalStorageConfig | S3StorageConfig;
51
+
52
+ /**
53
+ * Storage controller interface for backend implementations
54
+ */
55
+ export interface StorageController {
56
+ /**
57
+ * Upload a file
58
+ */
59
+ uploadFile(props: UploadFileProps): Promise<UploadFileResult>;
60
+
61
+ /**
62
+ * Get a download URL for a file
63
+ */
64
+ getDownloadURL(path: string, bucket?: string): Promise<DownloadConfig>;
65
+
66
+ /**
67
+ * Get file as a File object
68
+ */
69
+ getFile(path: string, bucket?: string): Promise<File | null>;
70
+
71
+ /**
72
+ * Delete a file
73
+ */
74
+ deleteFile(path: string, bucket?: string): Promise<void>;
75
+
76
+ /**
77
+ * List files in a path
78
+ */
79
+ list(path: string, options?: {
80
+ bucket?: string;
81
+ maxResults?: number;
82
+ pageToken?: string;
83
+ }): Promise<StorageListResult>;
84
+
85
+ /**
86
+ * Get the storage configuration type
87
+ */
88
+ getType(): 'local' | 's3';
89
+ }
90
+
91
+ /**
92
+ * Default maximum file size (50MB)
93
+ */
94
+ export const DEFAULT_MAX_FILE_SIZE = 50 * 1024 * 1024;
95
+
96
+ /**
97
+ * Common image MIME types
98
+ */
99
+ export const IMAGE_MIME_TYPES = [
100
+ 'image/jpeg',
101
+ 'image/png',
102
+ 'image/gif',
103
+ 'image/webp',
104
+ 'image/svg+xml',
105
+ 'image/bmp',
106
+ 'image/tiff'
107
+ ];
108
+
109
+ /**
110
+ * Common document MIME types
111
+ */
112
+ export const DOCUMENT_MIME_TYPES = [
113
+ 'application/pdf',
114
+ 'application/msword',
115
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
116
+ 'application/vnd.ms-excel',
117
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
118
+ 'application/vnd.ms-powerpoint',
119
+ 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
120
+ 'text/plain',
121
+ 'text/csv'
122
+ ];
@@ -0,0 +1,27 @@
1
+ import {
2
+ Entity,
3
+ EntityCollection,
4
+ EntityStatus,
5
+ FilterValues,
6
+ FetchCollectionProps,
7
+ FetchEntityProps,
8
+ SaveEntityProps,
9
+ DeleteEntityProps,
10
+ WebSocketMessage,
11
+ CollectionUpdateMessage,
12
+ EntityUpdateMessage
13
+ } from "@rebasepro/types";
14
+
15
+ // Subscription types
16
+ export interface ListenCollectionRequest<M extends Record<string, unknown> = Record<string, unknown>> extends FetchCollectionProps<M> {
17
+ subscriptionId: string;
18
+ onUpdate: (entities: Entity<M>[]) => void;
19
+ onError?: (error: Error) => void;
20
+ }
21
+
22
+ export interface ListenEntityRequest<M extends Record<string, unknown> = Record<string, unknown>> extends FetchEntityProps<M> {
23
+ subscriptionId: string;
24
+ onUpdate: (entity: Entity<M> | null) => void;
25
+ onError?: (error: Error) => void;
26
+ }
27
+
@@ -0,0 +1,35 @@
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 function configureLogLevel(logLevel?: string) {
6
+ const LOG_LEVEL = logLevel || process.env.LOG_LEVEL || 'info';
7
+ const logLevels = { error: 0, warn: 1, info: 2, debug: 3 };
8
+ const currentLevel = logLevels[LOG_LEVEL as keyof typeof logLevels] ?? 2;
9
+
10
+ if (currentLevel < 3) console.debug = () => { };
11
+ if (currentLevel < 2) console.log = () => { };
12
+ if (currentLevel < 1) console.warn = () => { };
13
+ if (currentLevel < 0) console.error = () => { };
14
+ }
15
+
16
+ /**
17
+ * Reset console methods to their original state
18
+ */
19
+ export function resetConsole() {
20
+ // Store original methods if not already stored
21
+ if (!(global as unknown as Record<string, unknown>).__originalConsole) {
22
+ (global as unknown as Record<string, unknown>).__originalConsole = {
23
+ log: console.log,
24
+ warn: console.warn,
25
+ error: console.error,
26
+ debug: console.debug
27
+ };
28
+ }
29
+
30
+ const original = (global as unknown as Record<string, unknown>).__originalConsole as Console;
31
+ console.log = original.log;
32
+ console.warn = original.warn;
33
+ console.error = original.error;
34
+ console.debug = original.debug;
35
+ }
@@ -0,0 +1,38 @@
1
+ import { sql, SQL } from "drizzle-orm";
2
+
3
+ /**
4
+ * Returns a SQL chunk calling `auth.uid()` — the current user's ID.
5
+ * This is a Supabase-style helper function created in the `auth` schema
6
+ * that reads `app.user_id` set per-transaction by `withAuth()`.
7
+ *
8
+ * @example
9
+ * sql`${table.user_id} = ${authUid()}`
10
+ */
11
+ export const authUid = (): SQL => {
12
+ return sql`auth.uid()`;
13
+ };
14
+
15
+ /**
16
+ * Returns a SQL chunk calling `auth.roles()` — the current user's roles
17
+ * as a comma-separated string.
18
+ * Reads `app.user_roles` set per-transaction by `withAuth()`.
19
+ *
20
+ * @example
21
+ * sql`auth.roles() ~ 'admin'`
22
+ */
23
+ export const authRoles = (): SQL => {
24
+ return sql`auth.roles()`;
25
+ };
26
+
27
+ /**
28
+ * Returns a SQL chunk calling `auth.jwt()` — the full JWT claims as JSONB.
29
+ * Reads `app.jwt` set per-transaction by `withAuth()`.
30
+ *
31
+ * @example
32
+ * sql`auth.jwt()->>'sub'`
33
+ */
34
+ export const authJwt = (): SQL => {
35
+ return sql`auth.jwt()`;
36
+ };
37
+
38
+