@forgebase/database 0.0.1

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 (219) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +470 -0
  3. package/dist/cjs/adapters/base.d.ts +20 -0
  4. package/dist/cjs/adapters/base.d.ts.map +1 -0
  5. package/dist/cjs/adapters/base.js +13 -0
  6. package/dist/cjs/adapters/base.js.map +1 -0
  7. package/dist/cjs/adapters/index.d.ts +6 -0
  8. package/dist/cjs/adapters/index.d.ts.map +1 -0
  9. package/dist/cjs/adapters/index.js +24 -0
  10. package/dist/cjs/adapters/index.js.map +1 -0
  11. package/dist/cjs/adapters/postgres.d.ts +13 -0
  12. package/dist/cjs/adapters/postgres.d.ts.map +1 -0
  13. package/dist/cjs/adapters/postgres.js +51 -0
  14. package/dist/cjs/adapters/postgres.js.map +1 -0
  15. package/dist/cjs/adapters/sqlite.d.ts +13 -0
  16. package/dist/cjs/adapters/sqlite.d.ts.map +1 -0
  17. package/dist/cjs/adapters/sqlite.js +47 -0
  18. package/dist/cjs/adapters/sqlite.js.map +1 -0
  19. package/dist/cjs/adapters/types.d.ts +8 -0
  20. package/dist/cjs/adapters/types.d.ts.map +1 -0
  21. package/dist/cjs/adapters/types.js +3 -0
  22. package/dist/cjs/adapters/types.js.map +1 -0
  23. package/dist/cjs/database.d.ts +73 -0
  24. package/dist/cjs/database.d.ts.map +1 -0
  25. package/dist/cjs/database.js +673 -0
  26. package/dist/cjs/database.js.map +1 -0
  27. package/dist/cjs/errors.d.ts +37 -0
  28. package/dist/cjs/errors.d.ts.map +1 -0
  29. package/dist/cjs/errors.js +64 -0
  30. package/dist/cjs/errors.js.map +1 -0
  31. package/dist/cjs/index.d.ts +16 -0
  32. package/dist/cjs/index.d.ts.map +1 -0
  33. package/dist/cjs/index.js +31 -0
  34. package/dist/cjs/index.js.map +1 -0
  35. package/dist/cjs/kysely-hooks.d.ts +45 -0
  36. package/dist/cjs/kysely-hooks.d.ts.map +1 -0
  37. package/dist/cjs/kysely-hooks.js +93 -0
  38. package/dist/cjs/kysely-hooks.js.map +1 -0
  39. package/dist/cjs/libsql/example.d.ts +2 -0
  40. package/dist/cjs/libsql/example.d.ts.map +1 -0
  41. package/dist/cjs/libsql/example.js +44 -0
  42. package/dist/cjs/libsql/example.js.map +1 -0
  43. package/dist/cjs/libsql/index.d.ts +36 -0
  44. package/dist/cjs/libsql/index.d.ts.map +1 -0
  45. package/dist/cjs/libsql/index.js +155 -0
  46. package/dist/cjs/libsql/index.js.map +1 -0
  47. package/dist/cjs/permissionService.d.ts +20 -0
  48. package/dist/cjs/permissionService.d.ts.map +1 -0
  49. package/dist/cjs/permissionService.js +107 -0
  50. package/dist/cjs/permissionService.js.map +1 -0
  51. package/dist/cjs/rlsFunctionRegistry.d.ts +43 -0
  52. package/dist/cjs/rlsFunctionRegistry.d.ts.map +1 -0
  53. package/dist/cjs/rlsFunctionRegistry.js +63 -0
  54. package/dist/cjs/rlsFunctionRegistry.js.map +1 -0
  55. package/dist/cjs/rlsManager.d.ts +23 -0
  56. package/dist/cjs/rlsManager.d.ts.map +1 -0
  57. package/dist/cjs/rlsManager.js +371 -0
  58. package/dist/cjs/rlsManager.js.map +1 -0
  59. package/dist/cjs/schema.d.ts +15 -0
  60. package/dist/cjs/schema.d.ts.map +1 -0
  61. package/dist/cjs/schema.js +119 -0
  62. package/dist/cjs/schema.js.map +1 -0
  63. package/dist/cjs/sdk/client.d.ts +324 -0
  64. package/dist/cjs/sdk/client.d.ts.map +1 -0
  65. package/dist/cjs/sdk/client.js +554 -0
  66. package/dist/cjs/sdk/client.js.map +1 -0
  67. package/dist/cjs/sdk/examples.d.ts +68 -0
  68. package/dist/cjs/sdk/examples.d.ts.map +1 -0
  69. package/dist/cjs/sdk/examples.js +232 -0
  70. package/dist/cjs/sdk/examples.js.map +1 -0
  71. package/dist/cjs/sdk/server.d.ts +115 -0
  72. package/dist/cjs/sdk/server.d.ts.map +1 -0
  73. package/dist/cjs/sdk/server.js +140 -0
  74. package/dist/cjs/sdk/server.js.map +1 -0
  75. package/dist/cjs/types.d.ts +217 -0
  76. package/dist/cjs/types.d.ts.map +1 -0
  77. package/dist/cjs/types.js +5 -0
  78. package/dist/cjs/types.js.map +1 -0
  79. package/dist/cjs/utils/column-utils.d.ts +8 -0
  80. package/dist/cjs/utils/column-utils.d.ts.map +1 -0
  81. package/dist/cjs/utils/column-utils.js +131 -0
  82. package/dist/cjs/utils/column-utils.js.map +1 -0
  83. package/dist/cjs/utils/db.d.ts +2 -0
  84. package/dist/cjs/utils/db.d.ts.map +1 -0
  85. package/dist/cjs/utils/db.js +6 -0
  86. package/dist/cjs/utils/db.js.map +1 -0
  87. package/dist/cjs/utils/inspector.d.ts +39 -0
  88. package/dist/cjs/utils/inspector.d.ts.map +1 -0
  89. package/dist/cjs/utils/inspector.js +164 -0
  90. package/dist/cjs/utils/inspector.js.map +1 -0
  91. package/dist/cjs/utils/permission-initializer.d.ts +15 -0
  92. package/dist/cjs/utils/permission-initializer.d.ts.map +1 -0
  93. package/dist/cjs/utils/permission-initializer.js +173 -0
  94. package/dist/cjs/utils/permission-initializer.js.map +1 -0
  95. package/dist/cjs/websocket/RealtimeAdapter.d.ts +22 -0
  96. package/dist/cjs/websocket/RealtimeAdapter.d.ts.map +1 -0
  97. package/dist/cjs/websocket/RealtimeAdapter.js +3 -0
  98. package/dist/cjs/websocket/RealtimeAdapter.js.map +1 -0
  99. package/dist/cjs/websocket/SSEManager.d.ts +40 -0
  100. package/dist/cjs/websocket/SSEManager.d.ts.map +1 -0
  101. package/dist/cjs/websocket/SSEManager.js +268 -0
  102. package/dist/cjs/websocket/SSEManager.js.map +1 -0
  103. package/dist/cjs/websocket/WebSocketManager.d.ts +28 -0
  104. package/dist/cjs/websocket/WebSocketManager.d.ts.map +1 -0
  105. package/dist/cjs/websocket/WebSocketManager.js +156 -0
  106. package/dist/cjs/websocket/WebSocketManager.js.map +1 -0
  107. package/dist/cjs/websocket/index.d.ts +4 -0
  108. package/dist/cjs/websocket/index.d.ts.map +1 -0
  109. package/dist/cjs/websocket/index.js +20 -0
  110. package/dist/cjs/websocket/index.js.map +1 -0
  111. package/dist/esm/adapters/base.d.ts +20 -0
  112. package/dist/esm/adapters/base.d.ts.map +1 -0
  113. package/dist/esm/adapters/base.js +10 -0
  114. package/dist/esm/adapters/base.js.map +1 -0
  115. package/dist/esm/adapters/index.d.ts +6 -0
  116. package/dist/esm/adapters/index.d.ts.map +1 -0
  117. package/dist/esm/adapters/index.js +19 -0
  118. package/dist/esm/adapters/index.js.map +1 -0
  119. package/dist/esm/adapters/postgres.d.ts +13 -0
  120. package/dist/esm/adapters/postgres.d.ts.map +1 -0
  121. package/dist/esm/adapters/postgres.js +47 -0
  122. package/dist/esm/adapters/postgres.js.map +1 -0
  123. package/dist/esm/adapters/sqlite.d.ts +13 -0
  124. package/dist/esm/adapters/sqlite.d.ts.map +1 -0
  125. package/dist/esm/adapters/sqlite.js +43 -0
  126. package/dist/esm/adapters/sqlite.js.map +1 -0
  127. package/dist/esm/adapters/types.d.ts +8 -0
  128. package/dist/esm/adapters/types.d.ts.map +1 -0
  129. package/dist/esm/adapters/types.js +2 -0
  130. package/dist/esm/adapters/types.js.map +1 -0
  131. package/dist/esm/database.d.ts +73 -0
  132. package/dist/esm/database.d.ts.map +1 -0
  133. package/dist/esm/database.js +668 -0
  134. package/dist/esm/database.js.map +1 -0
  135. package/dist/esm/errors.d.ts +37 -0
  136. package/dist/esm/errors.d.ts.map +1 -0
  137. package/dist/esm/errors.js +55 -0
  138. package/dist/esm/errors.js.map +1 -0
  139. package/dist/esm/index.d.ts +16 -0
  140. package/dist/esm/index.d.ts.map +1 -0
  141. package/dist/esm/index.js +15 -0
  142. package/dist/esm/index.js.map +1 -0
  143. package/dist/esm/kysely-hooks.d.ts +45 -0
  144. package/dist/esm/kysely-hooks.d.ts.map +1 -0
  145. package/dist/esm/kysely-hooks.js +86 -0
  146. package/dist/esm/kysely-hooks.js.map +1 -0
  147. package/dist/esm/libsql/example.d.ts +2 -0
  148. package/dist/esm/libsql/example.d.ts.map +1 -0
  149. package/dist/esm/libsql/example.js +42 -0
  150. package/dist/esm/libsql/example.js.map +1 -0
  151. package/dist/esm/libsql/index.d.ts +36 -0
  152. package/dist/esm/libsql/index.d.ts.map +1 -0
  153. package/dist/esm/libsql/index.js +116 -0
  154. package/dist/esm/libsql/index.js.map +1 -0
  155. package/dist/esm/permissionService.d.ts +20 -0
  156. package/dist/esm/permissionService.d.ts.map +1 -0
  157. package/dist/esm/permissionService.js +103 -0
  158. package/dist/esm/permissionService.js.map +1 -0
  159. package/dist/esm/rlsFunctionRegistry.d.ts +43 -0
  160. package/dist/esm/rlsFunctionRegistry.d.ts.map +1 -0
  161. package/dist/esm/rlsFunctionRegistry.js +60 -0
  162. package/dist/esm/rlsFunctionRegistry.js.map +1 -0
  163. package/dist/esm/rlsManager.d.ts +23 -0
  164. package/dist/esm/rlsManager.d.ts.map +1 -0
  165. package/dist/esm/rlsManager.js +366 -0
  166. package/dist/esm/rlsManager.js.map +1 -0
  167. package/dist/esm/schema.d.ts +15 -0
  168. package/dist/esm/schema.d.ts.map +1 -0
  169. package/dist/esm/schema.js +113 -0
  170. package/dist/esm/schema.js.map +1 -0
  171. package/dist/esm/sdk/client.d.ts +324 -0
  172. package/dist/esm/sdk/client.d.ts.map +1 -0
  173. package/dist/esm/sdk/client.js +550 -0
  174. package/dist/esm/sdk/client.js.map +1 -0
  175. package/dist/esm/sdk/examples.d.ts +68 -0
  176. package/dist/esm/sdk/examples.d.ts.map +1 -0
  177. package/dist/esm/sdk/examples.js +229 -0
  178. package/dist/esm/sdk/examples.js.map +1 -0
  179. package/dist/esm/sdk/server.d.ts +115 -0
  180. package/dist/esm/sdk/server.d.ts.map +1 -0
  181. package/dist/esm/sdk/server.js +136 -0
  182. package/dist/esm/sdk/server.js.map +1 -0
  183. package/dist/esm/types.d.ts +217 -0
  184. package/dist/esm/types.d.ts.map +1 -0
  185. package/dist/esm/types.js +2 -0
  186. package/dist/esm/types.js.map +1 -0
  187. package/dist/esm/utils/column-utils.d.ts +8 -0
  188. package/dist/esm/utils/column-utils.d.ts.map +1 -0
  189. package/dist/esm/utils/column-utils.js +127 -0
  190. package/dist/esm/utils/column-utils.js.map +1 -0
  191. package/dist/esm/utils/db.d.ts +2 -0
  192. package/dist/esm/utils/db.d.ts.map +1 -0
  193. package/dist/esm/utils/db.js +3 -0
  194. package/dist/esm/utils/db.js.map +1 -0
  195. package/dist/esm/utils/inspector.d.ts +39 -0
  196. package/dist/esm/utils/inspector.d.ts.map +1 -0
  197. package/dist/esm/utils/inspector.js +160 -0
  198. package/dist/esm/utils/inspector.js.map +1 -0
  199. package/dist/esm/utils/permission-initializer.d.ts +15 -0
  200. package/dist/esm/utils/permission-initializer.d.ts.map +1 -0
  201. package/dist/esm/utils/permission-initializer.js +137 -0
  202. package/dist/esm/utils/permission-initializer.js.map +1 -0
  203. package/dist/esm/websocket/RealtimeAdapter.d.ts +22 -0
  204. package/dist/esm/websocket/RealtimeAdapter.d.ts.map +1 -0
  205. package/dist/esm/websocket/RealtimeAdapter.js +2 -0
  206. package/dist/esm/websocket/RealtimeAdapter.js.map +1 -0
  207. package/dist/esm/websocket/SSEManager.d.ts +40 -0
  208. package/dist/esm/websocket/SSEManager.d.ts.map +1 -0
  209. package/dist/esm/websocket/SSEManager.js +231 -0
  210. package/dist/esm/websocket/SSEManager.js.map +1 -0
  211. package/dist/esm/websocket/WebSocketManager.d.ts +28 -0
  212. package/dist/esm/websocket/WebSocketManager.d.ts.map +1 -0
  213. package/dist/esm/websocket/WebSocketManager.js +152 -0
  214. package/dist/esm/websocket/WebSocketManager.js.map +1 -0
  215. package/dist/esm/websocket/index.d.ts +4 -0
  216. package/dist/esm/websocket/index.d.ts.map +1 -0
  217. package/dist/esm/websocket/index.js +4 -0
  218. package/dist/esm/websocket/index.js.map +1 -0
  219. package/package.json +67 -0
@@ -0,0 +1,156 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.WebSocketManager = void 0;
4
+ const uWebSockets_js_1 = require("uWebSockets.js");
5
+ const rlsManager_1 = require("../rlsManager");
6
+ class WebSocketManager {
7
+ constructor(port, permissionService) {
8
+ this.port = port;
9
+ this.permissionService = permissionService;
10
+ this.clients = new Map();
11
+ this.tableSubscriptions = new Map();
12
+ this.app = (0, uWebSockets_js_1.App)();
13
+ this.initialize();
14
+ }
15
+ /**
16
+ * Initialize the WebSocket server
17
+ */
18
+ initialize() {
19
+ this.setupWebSocketServer();
20
+ }
21
+ setupWebSocketServer() {
22
+ this.app.ws('/*', {
23
+ compression: uWebSockets_js_1.SHARED_COMPRESSOR,
24
+ maxPayloadLength: 16 * 1024 * 1024,
25
+ idleTimeout: 10,
26
+ upgrade: (res, req, context) => {
27
+ res.upgrade({
28
+ userContext: JSON.parse(req.getHeader('user-context')),
29
+ },
30
+ /* Spell these correctly */
31
+ req.getHeader('sec-websocket-key'), req.getHeader('sec-websocket-protocol'), req.getHeader('sec-websocket-extensions'), context);
32
+ },
33
+ open: (ws) => {
34
+ const socketClient = ws;
35
+ socketClient.id = Math.random().toString(36).substr(2, 9);
36
+ socketClient.subscribedTables = new Set();
37
+ socketClient.userContext = ws.userContext;
38
+ this.clients.set(socketClient.id, socketClient);
39
+ },
40
+ message: async (ws, message) => {
41
+ const socketClient = ws;
42
+ const msg = JSON.parse(Buffer.from(message).toString());
43
+ switch (msg.type) {
44
+ case 'subscribe':
45
+ await this.handleSubscribe(socketClient, msg.tableName);
46
+ break;
47
+ case 'unsubscribe':
48
+ this.handleUnsubscribe(socketClient, msg.tableName);
49
+ break;
50
+ default:
51
+ this.sendError(socketClient, 'Invalid message type');
52
+ break;
53
+ }
54
+ },
55
+ close: (ws) => {
56
+ const socketClient = ws;
57
+ this.removeClient(socketClient);
58
+ },
59
+ drain: (ws) => {
60
+ const socketClient = ws;
61
+ this.removeClient(socketClient);
62
+ },
63
+ });
64
+ this.app.listen(this.port, () => {
65
+ console.log(`WebSocket server listening on port ${this.port}`);
66
+ });
67
+ }
68
+ async handleSubscribe(client, tableName) {
69
+ if (!client.userContext) {
70
+ this.sendError(client, 'Authentication required');
71
+ return;
72
+ }
73
+ // Check table permissions
74
+ const permissions = await this.permissionService.getPermissionsForTable(tableName);
75
+ if (!this.canSubscribe(client.userContext, permissions)) {
76
+ this.sendError(client, 'Permission denied');
77
+ return;
78
+ }
79
+ client.subscribedTables.add(tableName);
80
+ if (!this.tableSubscriptions.has(tableName)) {
81
+ this.tableSubscriptions.set(tableName, new Set());
82
+ }
83
+ this.tableSubscriptions.get(tableName).add(client.id);
84
+ }
85
+ handleUnsubscribe(client, tableName) {
86
+ client.subscribedTables.delete(tableName);
87
+ this.tableSubscriptions.get(tableName)?.delete(client.id);
88
+ }
89
+ removeClient(client) {
90
+ client.subscribedTables.forEach((tableName) => {
91
+ this.tableSubscriptions.get(tableName)?.delete(client.id);
92
+ });
93
+ this.clients.delete(client.id);
94
+ }
95
+ async canSubscribe(userContext, permissions) {
96
+ if (!permissions)
97
+ return false;
98
+ const selectRules = permissions.operations.SELECT;
99
+ if (!selectRules)
100
+ return false;
101
+ // Create a copy of the rules without fieldCheck
102
+ const rulesWithoutFieldCheck = selectRules.map((rule) => {
103
+ const { fieldCheck, ...ruleWithoutFieldCheck } = rule;
104
+ return ruleWithoutFieldCheck;
105
+ });
106
+ // Check if the user has the required permissions to subscribe
107
+ return (0, rlsManager_1.evaluatePermission)(rulesWithoutFieldCheck, userContext);
108
+ }
109
+ async processBatch(clients, tableName, event, data, permissions) {
110
+ const BATCH_SIZE = 100; // Adjust based on your needs
111
+ for (let i = 0; i < clients.length; i += BATCH_SIZE) {
112
+ const batchClients = clients.slice(i, i + BATCH_SIZE);
113
+ await Promise.all(batchClients.map(async (client) => {
114
+ if (!client.userContext || !permissions.operations.SELECT)
115
+ return;
116
+ // Filter data based on user permissions
117
+ const filteredData = data.filter((item) => (0, rlsManager_1.evaluatePermission)(permissions.operations.SELECT, client.userContext, item));
118
+ if (filteredData.length > 0) {
119
+ client.send(JSON.stringify({
120
+ event,
121
+ tableName,
122
+ data: filteredData,
123
+ }));
124
+ }
125
+ }));
126
+ }
127
+ }
128
+ async broadcast(tableName, event, data) {
129
+ const subscribers = this.tableSubscriptions.get(tableName);
130
+ if (!subscribers)
131
+ return;
132
+ const permissions = await this.permissionService.getPermissionsForTable(tableName);
133
+ if (!permissions || !permissions.operations.SELECT)
134
+ return;
135
+ // Get all active clients for this table
136
+ const activeClients = Array.from(subscribers)
137
+ .map((clientId) => this.clients.get(clientId))
138
+ .filter((client) => client !== undefined);
139
+ // Handle single record vs array of records
140
+ const dataArray = Array.isArray(data) ? data : [data];
141
+ // Process in batches
142
+ await this.processBatch(activeClients, tableName, event, dataArray, permissions);
143
+ }
144
+ sendError(client, message) {
145
+ client.send(JSON.stringify({ type: 'error', message }));
146
+ }
147
+ /**
148
+ * Get the port the WebSocket server is listening on
149
+ * @returns The port number
150
+ */
151
+ getPort() {
152
+ return this.port;
153
+ }
154
+ }
155
+ exports.WebSocketManager = WebSocketManager;
156
+ //# sourceMappingURL=WebSocketManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WebSocketManager.js","sourceRoot":"","sources":["../../../src/websocket/WebSocketManager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export * from './RealtimeAdapter';
2
+ export * from './WebSocketManager';
3
+ export * from './SSEManager';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/websocket/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,cAAc,CAAC"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./RealtimeAdapter"), exports);
18
+ __exportStar(require("./WebSocketManager"), exports);
19
+ __exportStar(require("./SSEManager"), exports);
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/websocket/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,qDAAmC;AACnC,+CAA6B"}
@@ -0,0 +1,20 @@
1
+ import { WindowFunction, OrderByClause } from '../sdk/server';
2
+ export interface DatabaseAdapter {
3
+ buildWindowFunction(wf: WindowFunction): string;
4
+ buildOrderByClause(clauses: OrderByClause[]): {
5
+ column: string;
6
+ order: 'asc' | 'desc';
7
+ null?: 'first' | 'last';
8
+ }[];
9
+ supportsFeature(feature: DatabaseFeature): boolean;
10
+ sanitizeIdentifier(identifier: string): string;
11
+ }
12
+ export declare enum DatabaseFeature {
13
+ WindowFunctions = "windowFunctions",
14
+ CTEs = "ctes",
15
+ RecursiveCTEs = "recursiveCTEs",
16
+ NullsOrdering = "nullsOrdering",
17
+ JsonOperations = "jsonOperations",
18
+ ArrayOperations = "arrayOperations"
19
+ }
20
+ //# sourceMappingURL=base.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../src/adapters/base.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAE9D,MAAM,WAAW,eAAe;IAC9B,mBAAmB,CAAC,EAAE,EAAE,cAAc,GAAG,MAAM,CAAC;IAChD,kBAAkB,CAChB,OAAO,EAAE,aAAa,EAAE,GACvB;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,KAAK,GAAG,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,OAAO,GAAG,MAAM,CAAA;KAAE,EAAE,CAAC;IACxE,eAAe,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC;IACnD,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAAC;CAChD;AAED,oBAAY,eAAe;IACzB,eAAe,oBAAoB;IACnC,IAAI,SAAS;IACb,aAAa,kBAAkB;IAC/B,aAAa,kBAAkB;IAC/B,cAAc,mBAAmB;IACjC,eAAe,oBAAoB;CACpC"}
@@ -0,0 +1,10 @@
1
+ export var DatabaseFeature;
2
+ (function (DatabaseFeature) {
3
+ DatabaseFeature["WindowFunctions"] = "windowFunctions";
4
+ DatabaseFeature["CTEs"] = "ctes";
5
+ DatabaseFeature["RecursiveCTEs"] = "recursiveCTEs";
6
+ DatabaseFeature["NullsOrdering"] = "nullsOrdering";
7
+ DatabaseFeature["JsonOperations"] = "jsonOperations";
8
+ DatabaseFeature["ArrayOperations"] = "arrayOperations";
9
+ })(DatabaseFeature || (DatabaseFeature = {}));
10
+ //# sourceMappingURL=base.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.js","sourceRoot":"","sources":["../../../src/adapters/base.ts"],"names":[],"mappings":"AAWA,MAAM,CAAN,IAAY,eAOX;AAPD,WAAY,eAAe;IACzB,sDAAmC,CAAA;IACnC,gCAAa,CAAA;IACb,kDAA+B,CAAA;IAC/B,kDAA+B,CAAA;IAC/B,oDAAiC,CAAA;IACjC,sDAAmC,CAAA;AACrC,CAAC,EAPW,eAAe,KAAf,eAAe,QAO1B"}
@@ -0,0 +1,6 @@
1
+ import type { Kysely } from 'kysely';
2
+ import type { DatabaseAdapter } from './base';
3
+ export declare function getAdapter(db: Kysely<any>): DatabaseAdapter;
4
+ export { DatabaseFeature } from './base';
5
+ export type { DatabaseAdapter } from './base';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/adapters/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAE9C,wBAAgB,UAAU,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,eAAe,CAgB3D;AAED,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AACzC,YAAY,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC"}
@@ -0,0 +1,19 @@
1
+ import { SQLiteAdapter } from './sqlite';
2
+ import { PostgresAdapter } from './postgres';
3
+ export function getAdapter(db) {
4
+ // Try to determine the adapter from the executor or provided config
5
+ // Kysely structure: db.getExecutor().adapter
6
+ // This is a heuristic based on Kysely internal class names or we can rely on passed config if we had it.
7
+ // Assuming standard Kysely adapters.
8
+ const adapterName = db.getExecutor().adapter.constructor.name;
9
+ if (adapterName.includes('Postgres')) {
10
+ return new PostgresAdapter();
11
+ }
12
+ else if (adapterName.includes('Sqlite') || adapterName.includes('Libsql')) {
13
+ return new SQLiteAdapter();
14
+ }
15
+ // Default fallback or more checks
16
+ return new SQLiteAdapter(); // Safest default for now? Or better throw?
17
+ }
18
+ export { DatabaseFeature } from './base';
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/adapters/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAG7C,MAAM,UAAU,UAAU,CAAC,EAAe;IACxC,oEAAoE;IACpE,6CAA6C;IAE7C,yGAAyG;IACzG,qCAAqC;IACrC,MAAM,WAAW,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC;IAE9D,IAAI,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;QACrC,OAAO,IAAI,eAAe,EAAE,CAAC;IAC/B,CAAC;SAAM,IAAI,WAAW,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC5E,OAAO,IAAI,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED,kCAAkC;IAClC,OAAO,IAAI,aAAa,EAAE,CAAC,CAAC,2CAA2C;AACzE,CAAC;AAED,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC"}
@@ -0,0 +1,13 @@
1
+ import { type DatabaseAdapter, DatabaseFeature } from './base';
2
+ import type { WindowFunction, OrderByClause } from '../sdk/server';
3
+ export declare class PostgresAdapter implements DatabaseAdapter {
4
+ buildWindowFunction(wf: WindowFunction): string;
5
+ buildOrderByClause(clauses: OrderByClause[]): {
6
+ column: string;
7
+ order: 'asc' | 'desc';
8
+ null?: 'first' | 'last';
9
+ }[];
10
+ supportsFeature(feature: DatabaseFeature): boolean;
11
+ sanitizeIdentifier(identifier: string): string;
12
+ }
13
+ //# sourceMappingURL=postgres.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postgres.d.ts","sourceRoot":"","sources":["../../../src/adapters/postgres.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,eAAe,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAC/D,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAEnE,qBAAa,eAAgB,YAAW,eAAe;IACrD,mBAAmB,CAAC,EAAE,EAAE,cAAc,GAAG,MAAM;IAwB/C,kBAAkB,CAChB,OAAO,EAAE,aAAa,EAAE,GACvB;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,KAAK,GAAG,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,OAAO,GAAG,MAAM,CAAA;KAAE,EAAE;IASvE,eAAe,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO;IAYlD,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM;CAI/C"}
@@ -0,0 +1,47 @@
1
+ import { DatabaseFeature } from './base';
2
+ export class PostgresAdapter {
3
+ buildWindowFunction(wf) {
4
+ // PostgreSQL full window function support
5
+ const fnCall = wf.type === 'row_number'
6
+ ? 'ROW_NUMBER()'
7
+ : `${wf.type}(${wf.field || '*'})`;
8
+ let overClause = 'OVER (';
9
+ if (wf.partitionBy?.length) {
10
+ overClause += `PARTITION BY ${wf.partitionBy.join(',')}`;
11
+ }
12
+ if (wf.orderBy?.length) {
13
+ overClause += ` ORDER BY ${wf.orderBy
14
+ .map((ob) => `${ob.field} ${ob.direction || 'ASC'}`)
15
+ .join(',')}`;
16
+ }
17
+ if (wf.frameClause) {
18
+ overClause += ` ${wf.frameClause}`;
19
+ }
20
+ overClause += ')';
21
+ return `${fnCall} ${overClause} AS ${wf.alias}`;
22
+ }
23
+ buildOrderByClause(clauses) {
24
+ // PostgreSQL supports NULLS FIRST/LAST natively
25
+ return clauses.map(({ field, direction, nulls }) => ({
26
+ column: field,
27
+ order: direction || 'asc',
28
+ nulls: nulls,
29
+ }));
30
+ }
31
+ supportsFeature(feature) {
32
+ const supported = {
33
+ [DatabaseFeature.WindowFunctions]: true,
34
+ [DatabaseFeature.CTEs]: true,
35
+ [DatabaseFeature.RecursiveCTEs]: true,
36
+ [DatabaseFeature.NullsOrdering]: true,
37
+ [DatabaseFeature.JsonOperations]: true,
38
+ [DatabaseFeature.ArrayOperations]: true,
39
+ };
40
+ return supported[feature] || false;
41
+ }
42
+ sanitizeIdentifier(identifier) {
43
+ // PostgreSQL identifier sanitization
44
+ return `"${identifier.replace(/"/g, '""')}"`;
45
+ }
46
+ }
47
+ //# sourceMappingURL=postgres.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postgres.js","sourceRoot":"","sources":["../../../src/adapters/postgres.ts"],"names":[],"mappings":"AAAA,OAAO,EAAwB,eAAe,EAAE,MAAM,QAAQ,CAAC;AAG/D,MAAM,OAAO,eAAe;IAC1B,mBAAmB,CAAC,EAAkB;QACpC,0CAA0C;QAC1C,MAAM,MAAM,GACV,EAAE,CAAC,IAAI,KAAK,YAAY;YACtB,CAAC,CAAC,cAAc;YAChB,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,KAAK,IAAI,GAAG,GAAG,CAAC;QAEvC,IAAI,UAAU,GAAG,QAAQ,CAAC;QAC1B,IAAI,EAAE,CAAC,WAAW,EAAE,MAAM,EAAE,CAAC;YAC3B,UAAU,IAAI,gBAAgB,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QAC3D,CAAC;QACD,IAAI,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,CAAC;YACvB,UAAU,IAAI,aAAa,EAAE,CAAC,OAAO;iBAClC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,SAAS,IAAI,KAAK,EAAE,CAAC;iBACnD,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QACjB,CAAC;QACD,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;YACnB,UAAU,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QACrC,CAAC;QACD,UAAU,IAAI,GAAG,CAAC;QAElB,OAAO,GAAG,MAAM,IAAI,UAAU,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC;IAClD,CAAC;IAED,kBAAkB,CAChB,OAAwB;QAExB,gDAAgD;QAChD,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;YACnD,MAAM,EAAE,KAAK;YACb,KAAK,EAAE,SAAS,IAAI,KAAK;YACzB,KAAK,EAAE,KAAK;SACb,CAAC,CAAC,CAAC;IACN,CAAC;IAED,eAAe,CAAC,OAAwB;QACtC,MAAM,SAAS,GAAG;YAChB,CAAC,eAAe,CAAC,eAAe,CAAC,EAAE,IAAI;YACvC,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,IAAI;YAC5B,CAAC,eAAe,CAAC,aAAa,CAAC,EAAE,IAAI;YACrC,CAAC,eAAe,CAAC,aAAa,CAAC,EAAE,IAAI;YACrC,CAAC,eAAe,CAAC,cAAc,CAAC,EAAE,IAAI;YACtC,CAAC,eAAe,CAAC,eAAe,CAAC,EAAE,IAAI;SACxC,CAAC;QACF,OAAO,SAAS,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC;IACrC,CAAC;IAED,kBAAkB,CAAC,UAAkB;QACnC,qCAAqC;QACrC,OAAO,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC;IAC/C,CAAC;CACF"}
@@ -0,0 +1,13 @@
1
+ import { type DatabaseAdapter, DatabaseFeature } from './base';
2
+ import { WindowFunction, OrderByClause } from '../sdk/server';
3
+ export declare class SQLiteAdapter implements DatabaseAdapter {
4
+ buildWindowFunction(wf: WindowFunction): string;
5
+ buildOrderByClause(clauses: OrderByClause[]): {
6
+ column: string;
7
+ order: 'asc' | 'desc';
8
+ null?: 'first' | 'last';
9
+ }[];
10
+ supportsFeature(feature: DatabaseFeature): boolean;
11
+ sanitizeIdentifier(identifier: string): string;
12
+ }
13
+ //# sourceMappingURL=sqlite.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sqlite.d.ts","sourceRoot":"","sources":["../../../src/adapters/sqlite.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,eAAe,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAE9D,qBAAa,aAAc,YAAW,eAAe;IACnD,mBAAmB,CAAC,EAAE,EAAE,cAAc,GAAG,MAAM;IAqB/C,kBAAkB,CAChB,OAAO,EAAE,aAAa,EAAE,GACvB;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,KAAK,GAAG,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,OAAO,GAAG,MAAM,CAAA;KAAE,EAAE;IAQvE,eAAe,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO;IAYlD,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM;CAI/C"}
@@ -0,0 +1,43 @@
1
+ import { DatabaseFeature } from './base';
2
+ export class SQLiteAdapter {
3
+ buildWindowFunction(wf) {
4
+ // SQLite specific window function syntax
5
+ const fnCall = wf.type === 'row_number'
6
+ ? 'ROW_NUMBER()'
7
+ : `${wf.type}(${wf.field || '*'})`;
8
+ let overClause = 'OVER (';
9
+ if (wf.partitionBy?.length) {
10
+ overClause += `PARTITION BY ${wf.partitionBy.join(',')}`;
11
+ }
12
+ if (wf.orderBy?.length) {
13
+ overClause += ` ORDER BY ${wf.orderBy
14
+ .map((ob) => `${ob.field} ${ob.direction || 'ASC'}`)
15
+ .join(',')}`;
16
+ }
17
+ overClause += ')';
18
+ return `${fnCall} ${overClause} AS ${wf.alias}`;
19
+ }
20
+ buildOrderByClause(clauses) {
21
+ return clauses.map(({ field, direction, nulls }) => ({
22
+ column: field,
23
+ order: direction || 'asc',
24
+ nulls: nulls,
25
+ }));
26
+ }
27
+ supportsFeature(feature) {
28
+ const supported = {
29
+ [DatabaseFeature.WindowFunctions]: true, // Only in SQLite 3.25.0+
30
+ [DatabaseFeature.CTEs]: true,
31
+ [DatabaseFeature.RecursiveCTEs]: true,
32
+ [DatabaseFeature.NullsOrdering]: false,
33
+ [DatabaseFeature.JsonOperations]: false,
34
+ [DatabaseFeature.ArrayOperations]: false,
35
+ };
36
+ return supported[feature] || false;
37
+ }
38
+ sanitizeIdentifier(identifier) {
39
+ // SQLite identifier sanitization
40
+ return `"${identifier.replace(/"/g, '""')}"`;
41
+ }
42
+ }
43
+ //# sourceMappingURL=sqlite.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sqlite.js","sourceRoot":"","sources":["../../../src/adapters/sqlite.ts"],"names":[],"mappings":"AAAA,OAAO,EAAwB,eAAe,EAAE,MAAM,QAAQ,CAAC;AAG/D,MAAM,OAAO,aAAa;IACxB,mBAAmB,CAAC,EAAkB;QACpC,yCAAyC;QACzC,MAAM,MAAM,GACV,EAAE,CAAC,IAAI,KAAK,YAAY;YACtB,CAAC,CAAC,cAAc;YAChB,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,KAAK,IAAI,GAAG,GAAG,CAAC;QAEvC,IAAI,UAAU,GAAG,QAAQ,CAAC;QAC1B,IAAI,EAAE,CAAC,WAAW,EAAE,MAAM,EAAE,CAAC;YAC3B,UAAU,IAAI,gBAAgB,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QAC3D,CAAC;QACD,IAAI,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,CAAC;YACvB,UAAU,IAAI,aAAa,EAAE,CAAC,OAAO;iBAClC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,SAAS,IAAI,KAAK,EAAE,CAAC;iBACnD,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QACjB,CAAC;QACD,UAAU,IAAI,GAAG,CAAC;QAElB,OAAO,GAAG,MAAM,IAAI,UAAU,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC;IAClD,CAAC;IAED,kBAAkB,CAChB,OAAwB;QAExB,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;YACnD,MAAM,EAAE,KAAK;YACb,KAAK,EAAE,SAAS,IAAI,KAAK;YACzB,KAAK,EAAE,KAAK;SACb,CAAC,CAAC,CAAC;IACN,CAAC;IAED,eAAe,CAAC,OAAwB;QACtC,MAAM,SAAS,GAAG;YAChB,CAAC,eAAe,CAAC,eAAe,CAAC,EAAE,IAAI,EAAE,yBAAyB;YAClE,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,IAAI;YAC5B,CAAC,eAAe,CAAC,aAAa,CAAC,EAAE,IAAI;YACrC,CAAC,eAAe,CAAC,aAAa,CAAC,EAAE,KAAK;YACtC,CAAC,eAAe,CAAC,cAAc,CAAC,EAAE,KAAK;YACvC,CAAC,eAAe,CAAC,eAAe,CAAC,EAAE,KAAK;SACzC,CAAC;QACF,OAAO,SAAS,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC;IACrC,CAAC;IAED,kBAAkB,CAAC,UAAkB;QACnC,iCAAiC;QACjC,OAAO,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC;IAC/C,CAAC;CACF"}
@@ -0,0 +1,8 @@
1
+ export interface RequestAdapter {
2
+ getBody: <T>(request: any) => Promise<T>;
3
+ getQuery: (request: any) => Record<string, any>;
4
+ getParams: (request: any) => Record<string, any>;
5
+ getHeaders: (request: any) => Record<string, string>;
6
+ }
7
+ export type SupportedFramework = 'express' | 'fastify' | 'hono';
8
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/adapters/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,GAAG,KAAK,OAAO,CAAC,CAAC,CAAC,CAAA;IACxC,QAAQ,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAC/C,SAAS,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAChD,UAAU,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACrD;AAED,MAAM,MAAM,kBAAkB,GAAG,SAAS,GAAG,SAAS,GAAG,MAAM,CAAA"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/adapters/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,73 @@
1
+ import { Kysely, type Transaction } from 'kysely';
2
+ import { PermissionService } from './permissionService';
3
+ import { DBInspector } from './utils/inspector';
4
+ import { KyselyHooks } from './kysely-hooks';
5
+ import { type ForgeDatabaseConfig, type ForgeDatabaseEndpoints, type PermissionInitializationReport, type TablePermissions } from './types';
6
+ import { RealtimeAdapter } from './websocket/RealtimeAdapter';
7
+ export declare class ForgeDatabase {
8
+ private config;
9
+ private queryHandler;
10
+ private hooks;
11
+ private permissionService;
12
+ protected dbInspector: DBInspector;
13
+ private defaultPermissions;
14
+ realtimeAdapter?: RealtimeAdapter;
15
+ protected excludedTables: string[];
16
+ constructor(config?: ForgeDatabaseConfig);
17
+ getDbInspector(): DBInspector;
18
+ ready(): Promise<void>;
19
+ getExcludedTables(): string[];
20
+ getDefaultPermissions(): TablePermissions;
21
+ /**
22
+ * Initialize permissions for all tables in the database
23
+ * This is a non-blocking operation that runs in the background
24
+ */
25
+ private initializeTablePermissions;
26
+ /**
27
+ * Add a table to the excluded tables list
28
+ * @param tables List of tables to exclude
29
+ */
30
+ addExcludedTables(tables: string[]): void;
31
+ /**
32
+ * Remove a table from the excluded tables list
33
+ * @param tables List of tables to include
34
+ */
35
+ removeExcludedTables(tables: string[]): void;
36
+ /**
37
+ * Manually trigger permission initialization for all tables
38
+ * @param reportPath Optional path to save the report file
39
+ * @param onComplete Optional callback function to call when initialization is complete
40
+ */
41
+ initializePermissions(reportPath?: string, onComplete?: (report: PermissionInitializationReport) => void): void;
42
+ /**
43
+ * Get the database schema
44
+ * @returns Database schema
45
+ */
46
+ getEndpoints(): ForgeDatabaseEndpoints;
47
+ /**
48
+ * Get the knex instance
49
+ * @returns Knex instance
50
+ */
51
+ getDbInstance(): Kysely<any>;
52
+ getHooksDb(): KyselyHooks;
53
+ getPermissionService(): PermissionService;
54
+ /**
55
+ * Execute a function within a transaction
56
+ * @param callback Function to execute within the transaction
57
+ * @returns Result of the callback function
58
+ */
59
+ transaction<T>(callback: (trx: Transaction<any>) => Promise<T>): Promise<T>;
60
+ /**
61
+ * Get the endpoints for the database
62
+ * @returns Endpoints for the database
63
+ */
64
+ endpoints: ForgeDatabaseEndpoints;
65
+ parseQueryParams(params: Record<string, any>): Record<string, any>;
66
+ }
67
+ /**
68
+ * Create a new instance of the ForgeDatabase class
69
+ * @param config Configuration object for the ForgeDatabase instance
70
+ * @returns A new instance of the ForgeDatabase class
71
+ */
72
+ export declare const createForgeDatabase: (config: ForgeDatabaseConfig) => ForgeDatabase;
73
+ //# sourceMappingURL=database.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"database.d.ts","sourceRoot":"","sources":["../../src/database.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,KAAK,WAAW,EAA2B,MAAM,QAAQ,CAAC;AAC3E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD,OAAO,EAAE,WAAW,EAAuB,MAAM,mBAAmB,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAM7C,OAAO,EAOL,KAAK,mBAAmB,EACxB,KAAK,sBAAsB,EAG3B,KAAK,8BAA8B,EAEnC,KAAK,gBAAgB,EACtB,MAAM,SAAS,CAAC;AAiBjB,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAK9D,qBAAa,aAAa;IAgCZ,OAAO,CAAC,MAAM;IA/B1B,OAAO,CAAC,YAAY,CAAqB;IACzC,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,iBAAiB,CAAoB;IAC7C,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC;IACnC,OAAO,CAAC,kBAAkB,CAuBxB;IACK,eAAe,CAAC,EAAE,eAAe,CAAC;IACzC,SAAS,CAAC,cAAc,EAAE,MAAM,EAAE,CAAyB;gBAEvC,MAAM,GAAE,mBAAwB;IAkD7C,cAAc,IAAI,WAAW;IAIvB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5B,iBAAiB,IAAI,MAAM,EAAE;IAIpC,qBAAqB,IAAI,gBAAgB;IAIzC;;;OAGG;IACH,OAAO,CAAC,0BAA0B;IAOlC;;;OAGG;IACI,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE;IAGzC;;;OAGG;IACI,oBAAoB,CAAC,MAAM,EAAE,MAAM,EAAE;IAM5C;;;;OAIG;IACI,qBAAqB,CAC1B,UAAU,CAAC,EAAE,MAAM,EACnB,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE,8BAA8B,KAAK,IAAI,GAC5D,IAAI;IAmBP;;;OAGG;IACI,YAAY;IAInB;;;OAGG;IACI,aAAa,IAAI,MAAM,CAAC,GAAG,CAAC;IAI5B,UAAU,IAAI,WAAW;IAIzB,oBAAoB,IAAI,iBAAiB;IAIhD;;;;OAIG;IACU,WAAW,CAAC,CAAC,EACxB,QAAQ,EAAE,CAAC,GAAG,EAAE,WAAW,CAAC,GAAG,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,GAC9C,OAAO,CAAC,CAAC,CAAC;IASb;;;OAGG;IACI,SAAS,EAAE,sBAAsB,CA69BtC;IAEF,gBAAgB,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;CAqBnE;AAED;;;;GAIG;AACH,eAAO,MAAM,mBAAmB,GAAI,QAAQ,mBAAmB,kBAE9D,CAAC"}