@sena-ai/platform-core 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (158) hide show
  1. package/dist/app.d.ts +9 -0
  2. package/dist/app.d.ts.map +1 -0
  3. package/dist/app.js +147 -0
  4. package/dist/app.js.map +1 -0
  5. package/dist/auth/handler.d.ts +19 -0
  6. package/dist/auth/handler.d.ts.map +1 -0
  7. package/dist/auth/handler.js +213 -0
  8. package/dist/auth/handler.js.map +1 -0
  9. package/dist/auth/session.d.ts +16 -0
  10. package/dist/auth/session.d.ts.map +1 -0
  11. package/dist/auth/session.js +54 -0
  12. package/dist/auth/session.js.map +1 -0
  13. package/dist/db/d1/index.d.ts +14 -0
  14. package/dist/db/d1/index.d.ts.map +1 -0
  15. package/dist/db/d1/index.js +252 -0
  16. package/dist/db/d1/index.js.map +1 -0
  17. package/dist/db/d1/schema.d.ts +610 -0
  18. package/dist/db/d1/schema.d.ts.map +1 -0
  19. package/dist/db/d1/schema.js +58 -0
  20. package/dist/db/d1/schema.js.map +1 -0
  21. package/dist/db/mysql/index.d.ts +14 -0
  22. package/dist/db/mysql/index.d.ts.map +1 -0
  23. package/dist/db/mysql/index.js +248 -0
  24. package/dist/db/mysql/index.js.map +1 -0
  25. package/dist/db/mysql/schema.d.ts +562 -0
  26. package/dist/db/mysql/schema.d.ts.map +1 -0
  27. package/dist/db/mysql/schema.js +61 -0
  28. package/dist/db/mysql/schema.js.map +1 -0
  29. package/dist/db/postgresql/index.d.ts +14 -0
  30. package/dist/db/postgresql/index.d.ts.map +1 -0
  31. package/dist/db/postgresql/index.js +246 -0
  32. package/dist/db/postgresql/index.js.map +1 -0
  33. package/dist/db/postgresql/schema.d.ts +591 -0
  34. package/dist/db/postgresql/schema.d.ts.map +1 -0
  35. package/dist/db/postgresql/schema.js +64 -0
  36. package/dist/db/postgresql/schema.js.map +1 -0
  37. package/dist/index.d.ts +6 -0
  38. package/dist/index.d.ts.map +1 -0
  39. package/dist/index.js +3 -0
  40. package/dist/index.js.map +1 -0
  41. package/dist/relay/api-proxy.d.ts +10 -0
  42. package/dist/relay/api-proxy.d.ts.map +1 -0
  43. package/dist/relay/api-proxy.js +40 -0
  44. package/dist/relay/api-proxy.js.map +1 -0
  45. package/dist/runtime/cf/crypto.d.ts +7 -0
  46. package/dist/runtime/cf/crypto.d.ts.map +1 -0
  47. package/dist/runtime/cf/crypto.js +48 -0
  48. package/dist/runtime/cf/crypto.js.map +1 -0
  49. package/dist/runtime/cf/index.d.ts +20 -0
  50. package/dist/runtime/cf/index.d.ts.map +1 -0
  51. package/dist/runtime/cf/index.js +14 -0
  52. package/dist/runtime/cf/index.js.map +1 -0
  53. package/dist/runtime/cf/relay.d.ts +11 -0
  54. package/dist/runtime/cf/relay.d.ts.map +1 -0
  55. package/dist/runtime/cf/relay.js +57 -0
  56. package/dist/runtime/cf/relay.js.map +1 -0
  57. package/dist/runtime/cf/vault.d.ts +7 -0
  58. package/dist/runtime/cf/vault.d.ts.map +1 -0
  59. package/dist/runtime/cf/vault.js +68 -0
  60. package/dist/runtime/cf/vault.js.map +1 -0
  61. package/dist/runtime/node/crypto.d.ts +6 -0
  62. package/dist/runtime/node/crypto.d.ts.map +1 -0
  63. package/dist/runtime/node/crypto.js +26 -0
  64. package/dist/runtime/node/crypto.js.map +1 -0
  65. package/dist/runtime/node/index.d.ts +17 -0
  66. package/dist/runtime/node/index.d.ts.map +1 -0
  67. package/dist/runtime/node/index.js +14 -0
  68. package/dist/runtime/node/index.js.map +1 -0
  69. package/dist/runtime/node/relay.d.ts +6 -0
  70. package/dist/runtime/node/relay.d.ts.map +1 -0
  71. package/dist/runtime/node/relay.js +73 -0
  72. package/dist/runtime/node/relay.js.map +1 -0
  73. package/dist/runtime/node/vault.d.ts +7 -0
  74. package/dist/runtime/node/vault.d.ts.map +1 -0
  75. package/dist/runtime/node/vault.js +41 -0
  76. package/dist/runtime/node/vault.js.map +1 -0
  77. package/dist/slack/events.d.ts +15 -0
  78. package/dist/slack/events.d.ts.map +1 -0
  79. package/dist/slack/events.js +63 -0
  80. package/dist/slack/events.js.map +1 -0
  81. package/dist/slack/oauth.d.ts +13 -0
  82. package/dist/slack/oauth.d.ts.map +1 -0
  83. package/dist/slack/oauth.js +90 -0
  84. package/dist/slack/oauth.js.map +1 -0
  85. package/dist/slack/provisioner.d.ts +60 -0
  86. package/dist/slack/provisioner.d.ts.map +1 -0
  87. package/dist/slack/provisioner.js +156 -0
  88. package/dist/slack/provisioner.js.map +1 -0
  89. package/dist/types/crypto.d.ts +15 -0
  90. package/dist/types/crypto.d.ts.map +1 -0
  91. package/dist/types/crypto.js +2 -0
  92. package/dist/types/crypto.js.map +1 -0
  93. package/dist/types/index.d.ts +6 -0
  94. package/dist/types/index.d.ts.map +1 -0
  95. package/dist/types/index.js +2 -0
  96. package/dist/types/index.js.map +1 -0
  97. package/dist/types/platform.d.ts +25 -0
  98. package/dist/types/platform.d.ts.map +1 -0
  99. package/dist/types/platform.js +2 -0
  100. package/dist/types/platform.js.map +1 -0
  101. package/dist/types/relay.d.ts +16 -0
  102. package/dist/types/relay.d.ts.map +1 -0
  103. package/dist/types/relay.js +2 -0
  104. package/dist/types/relay.js.map +1 -0
  105. package/dist/types/repository.d.ts +78 -0
  106. package/dist/types/repository.d.ts.map +1 -0
  107. package/dist/types/repository.js +6 -0
  108. package/dist/types/repository.js.map +1 -0
  109. package/dist/types/vault.d.ts +9 -0
  110. package/dist/types/vault.d.ts.map +1 -0
  111. package/dist/types/vault.js +2 -0
  112. package/dist/types/vault.js.map +1 -0
  113. package/dist/web/api.d.ts +9 -0
  114. package/dist/web/api.d.ts.map +1 -0
  115. package/dist/web/api.js +144 -0
  116. package/dist/web/api.js.map +1 -0
  117. package/dist/web/pages.d.ts +4 -0
  118. package/dist/web/pages.d.ts.map +1 -0
  119. package/dist/web/pages.js +401 -0
  120. package/dist/web/pages.js.map +1 -0
  121. package/dist/web/setup.d.ts +5 -0
  122. package/dist/web/setup.d.ts.map +1 -0
  123. package/dist/web/setup.js +208 -0
  124. package/dist/web/setup.js.map +1 -0
  125. package/package.json +46 -0
  126. package/src/app.ts +221 -0
  127. package/src/auth/handler.ts +343 -0
  128. package/src/auth/session.ts +89 -0
  129. package/src/db/d1/index.ts +304 -0
  130. package/src/db/d1/schema.ts +62 -0
  131. package/src/db/mysql/index.ts +301 -0
  132. package/src/db/mysql/schema.ts +78 -0
  133. package/src/db/postgresql/index.ts +311 -0
  134. package/src/db/postgresql/schema.ts +82 -0
  135. package/src/index.ts +21 -0
  136. package/src/relay/api-proxy.ts +61 -0
  137. package/src/runtime/cf/crypto.ts +74 -0
  138. package/src/runtime/cf/index.ts +31 -0
  139. package/src/runtime/cf/relay.ts +74 -0
  140. package/src/runtime/cf/vault.ts +99 -0
  141. package/src/runtime/node/crypto.ts +33 -0
  142. package/src/runtime/node/index.ts +28 -0
  143. package/src/runtime/node/relay.ts +98 -0
  144. package/src/runtime/node/vault.ts +50 -0
  145. package/src/slack/events.ts +92 -0
  146. package/src/slack/oauth.ts +127 -0
  147. package/src/slack/provisioner.ts +256 -0
  148. package/src/types/crypto.ts +14 -0
  149. package/src/types/index.ts +14 -0
  150. package/src/types/platform.ts +31 -0
  151. package/src/types/relay.ts +16 -0
  152. package/src/types/repository.ts +93 -0
  153. package/src/types/vault.ts +8 -0
  154. package/src/web/api.ts +204 -0
  155. package/src/web/pages.ts +458 -0
  156. package/src/web/setup.ts +270 -0
  157. package/tsconfig.json +19 -0
  158. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,562 @@
1
+ /**
2
+ * Table prefix.
3
+ * When set, all tables get a `{prefix}_` prefix.
4
+ * E.g.: 'sena' -> sena_bots, sena_config_tokens
5
+ */
6
+ export declare const TABLE_PREFIX = "";
7
+ export declare const bots: import("drizzle-orm/mysql-core").MySqlTableWithColumns<{
8
+ name: "bots";
9
+ schema: undefined;
10
+ columns: {
11
+ id: import("drizzle-orm/mysql-core").MySqlColumn<{
12
+ name: "id";
13
+ tableName: "bots";
14
+ dataType: "string";
15
+ columnType: "MySqlVarChar";
16
+ data: string;
17
+ driverParam: string | number;
18
+ notNull: true;
19
+ hasDefault: false;
20
+ isPrimaryKey: true;
21
+ isAutoincrement: false;
22
+ hasRuntimeDefault: false;
23
+ enumValues: [string, ...string[]];
24
+ baseColumn: never;
25
+ identity: undefined;
26
+ generated: undefined;
27
+ }, {}, {}>;
28
+ name: import("drizzle-orm/mysql-core").MySqlColumn<{
29
+ name: "name";
30
+ tableName: "bots";
31
+ dataType: "string";
32
+ columnType: "MySqlVarChar";
33
+ data: string;
34
+ driverParam: string | number;
35
+ notNull: true;
36
+ hasDefault: false;
37
+ isPrimaryKey: false;
38
+ isAutoincrement: false;
39
+ hasRuntimeDefault: false;
40
+ enumValues: [string, ...string[]];
41
+ baseColumn: never;
42
+ identity: undefined;
43
+ generated: undefined;
44
+ }, {}, {}>;
45
+ botUsername: import("drizzle-orm/mysql-core").MySqlColumn<{
46
+ name: "bot_username";
47
+ tableName: "bots";
48
+ dataType: "string";
49
+ columnType: "MySqlVarChar";
50
+ data: string;
51
+ driverParam: string | number;
52
+ notNull: true;
53
+ hasDefault: true;
54
+ isPrimaryKey: false;
55
+ isAutoincrement: false;
56
+ hasRuntimeDefault: false;
57
+ enumValues: [string, ...string[]];
58
+ baseColumn: never;
59
+ identity: undefined;
60
+ generated: undefined;
61
+ }, {}, {}>;
62
+ profileImageUrl: import("drizzle-orm/mysql-core").MySqlColumn<{
63
+ name: "profile_image_url";
64
+ tableName: "bots";
65
+ dataType: "string";
66
+ columnType: "MySqlText";
67
+ data: string;
68
+ driverParam: string;
69
+ notNull: false;
70
+ hasDefault: false;
71
+ isPrimaryKey: false;
72
+ isAutoincrement: false;
73
+ hasRuntimeDefault: false;
74
+ enumValues: [string, ...string[]];
75
+ baseColumn: never;
76
+ identity: undefined;
77
+ generated: undefined;
78
+ }, {}, {}>;
79
+ connectKey: import("drizzle-orm/mysql-core").MySqlColumn<{
80
+ name: "connect_key";
81
+ tableName: "bots";
82
+ dataType: "string";
83
+ columnType: "MySqlVarChar";
84
+ data: string;
85
+ driverParam: string | number;
86
+ notNull: true;
87
+ hasDefault: false;
88
+ isPrimaryKey: false;
89
+ isAutoincrement: false;
90
+ hasRuntimeDefault: false;
91
+ enumValues: [string, ...string[]];
92
+ baseColumn: never;
93
+ identity: undefined;
94
+ generated: undefined;
95
+ }, {}, {}>;
96
+ slackAppId: import("drizzle-orm/mysql-core").MySqlColumn<{
97
+ name: "slack_app_id";
98
+ tableName: "bots";
99
+ dataType: "string";
100
+ columnType: "MySqlVarChar";
101
+ data: string;
102
+ driverParam: string | number;
103
+ notNull: false;
104
+ hasDefault: false;
105
+ isPrimaryKey: false;
106
+ isAutoincrement: false;
107
+ hasRuntimeDefault: false;
108
+ enumValues: [string, ...string[]];
109
+ baseColumn: never;
110
+ identity: undefined;
111
+ generated: undefined;
112
+ }, {}, {}>;
113
+ slackTeamId: import("drizzle-orm/mysql-core").MySqlColumn<{
114
+ name: "slack_team_id";
115
+ tableName: "bots";
116
+ dataType: "string";
117
+ columnType: "MySqlVarChar";
118
+ data: string;
119
+ driverParam: string | number;
120
+ notNull: false;
121
+ hasDefault: false;
122
+ isPrimaryKey: false;
123
+ isAutoincrement: false;
124
+ hasRuntimeDefault: false;
125
+ enumValues: [string, ...string[]];
126
+ baseColumn: never;
127
+ identity: undefined;
128
+ generated: undefined;
129
+ }, {}, {}>;
130
+ botTokenEnc: import("drizzle-orm/mysql-core").MySqlColumn<{
131
+ name: "bot_token_enc";
132
+ tableName: "bots";
133
+ dataType: "string";
134
+ columnType: "MySqlText";
135
+ data: string;
136
+ driverParam: string;
137
+ notNull: false;
138
+ hasDefault: false;
139
+ isPrimaryKey: false;
140
+ isAutoincrement: false;
141
+ hasRuntimeDefault: false;
142
+ enumValues: [string, ...string[]];
143
+ baseColumn: never;
144
+ identity: undefined;
145
+ generated: undefined;
146
+ }, {}, {}>;
147
+ signingSecretEnc: import("drizzle-orm/mysql-core").MySqlColumn<{
148
+ name: "signing_secret_enc";
149
+ tableName: "bots";
150
+ dataType: "string";
151
+ columnType: "MySqlText";
152
+ data: string;
153
+ driverParam: string;
154
+ notNull: false;
155
+ hasDefault: false;
156
+ isPrimaryKey: false;
157
+ isAutoincrement: false;
158
+ hasRuntimeDefault: false;
159
+ enumValues: [string, ...string[]];
160
+ baseColumn: never;
161
+ identity: undefined;
162
+ generated: undefined;
163
+ }, {}, {}>;
164
+ clientId: import("drizzle-orm/mysql-core").MySqlColumn<{
165
+ name: "client_id";
166
+ tableName: "bots";
167
+ dataType: "string";
168
+ columnType: "MySqlVarChar";
169
+ data: string;
170
+ driverParam: string | number;
171
+ notNull: false;
172
+ hasDefault: false;
173
+ isPrimaryKey: false;
174
+ isAutoincrement: false;
175
+ hasRuntimeDefault: false;
176
+ enumValues: [string, ...string[]];
177
+ baseColumn: never;
178
+ identity: undefined;
179
+ generated: undefined;
180
+ }, {}, {}>;
181
+ clientSecretEnc: import("drizzle-orm/mysql-core").MySqlColumn<{
182
+ name: "client_secret_enc";
183
+ tableName: "bots";
184
+ dataType: "string";
185
+ columnType: "MySqlText";
186
+ data: string;
187
+ driverParam: string;
188
+ notNull: false;
189
+ hasDefault: false;
190
+ isPrimaryKey: false;
191
+ isAutoincrement: false;
192
+ hasRuntimeDefault: false;
193
+ enumValues: [string, ...string[]];
194
+ baseColumn: never;
195
+ identity: undefined;
196
+ generated: undefined;
197
+ }, {}, {}>;
198
+ manifestJson: import("drizzle-orm/mysql-core").MySqlColumn<{
199
+ name: "manifest_json";
200
+ tableName: "bots";
201
+ dataType: "string";
202
+ columnType: "MySqlText";
203
+ data: string;
204
+ driverParam: string;
205
+ notNull: false;
206
+ hasDefault: false;
207
+ isPrimaryKey: false;
208
+ isAutoincrement: false;
209
+ hasRuntimeDefault: false;
210
+ enumValues: [string, ...string[]];
211
+ baseColumn: never;
212
+ identity: undefined;
213
+ generated: undefined;
214
+ }, {}, {}>;
215
+ status: import("drizzle-orm/mysql-core").MySqlColumn<{
216
+ name: "status";
217
+ tableName: "bots";
218
+ dataType: "string";
219
+ columnType: "MySqlEnumColumn";
220
+ data: "pending" | "active" | "disabled";
221
+ driverParam: string;
222
+ notNull: true;
223
+ hasDefault: true;
224
+ isPrimaryKey: false;
225
+ isAutoincrement: false;
226
+ hasRuntimeDefault: false;
227
+ enumValues: ["pending", "active", "disabled"];
228
+ baseColumn: never;
229
+ identity: undefined;
230
+ generated: undefined;
231
+ }, {}, {}>;
232
+ createdAt: import("drizzle-orm/mysql-core").MySqlColumn<{
233
+ name: "created_at";
234
+ tableName: "bots";
235
+ dataType: "date";
236
+ columnType: "MySqlDateTime";
237
+ data: Date;
238
+ driverParam: string | number;
239
+ notNull: true;
240
+ hasDefault: true;
241
+ isPrimaryKey: false;
242
+ isAutoincrement: false;
243
+ hasRuntimeDefault: true;
244
+ enumValues: undefined;
245
+ baseColumn: never;
246
+ identity: undefined;
247
+ generated: undefined;
248
+ }, {}, {}>;
249
+ updatedAt: import("drizzle-orm/mysql-core").MySqlColumn<{
250
+ name: "updated_at";
251
+ tableName: "bots";
252
+ dataType: "date";
253
+ columnType: "MySqlDateTime";
254
+ data: Date;
255
+ driverParam: string | number;
256
+ notNull: true;
257
+ hasDefault: true;
258
+ isPrimaryKey: false;
259
+ isAutoincrement: false;
260
+ hasRuntimeDefault: true;
261
+ enumValues: undefined;
262
+ baseColumn: never;
263
+ identity: undefined;
264
+ generated: undefined;
265
+ }, {}, {}>;
266
+ };
267
+ dialect: "mysql";
268
+ }>;
269
+ export declare const configTokens: import("drizzle-orm/mysql-core").MySqlTableWithColumns<{
270
+ name: "config_tokens";
271
+ schema: undefined;
272
+ columns: {
273
+ workspaceId: import("drizzle-orm/mysql-core").MySqlColumn<{
274
+ name: "workspace_id";
275
+ tableName: "config_tokens";
276
+ dataType: "string";
277
+ columnType: "MySqlVarChar";
278
+ data: string;
279
+ driverParam: string | number;
280
+ notNull: true;
281
+ hasDefault: false;
282
+ isPrimaryKey: true;
283
+ isAutoincrement: false;
284
+ hasRuntimeDefault: false;
285
+ enumValues: [string, ...string[]];
286
+ baseColumn: never;
287
+ identity: undefined;
288
+ generated: undefined;
289
+ }, {}, {}>;
290
+ accessTokenEnc: import("drizzle-orm/mysql-core").MySqlColumn<{
291
+ name: "access_token_enc";
292
+ tableName: "config_tokens";
293
+ dataType: "string";
294
+ columnType: "MySqlText";
295
+ data: string;
296
+ driverParam: string;
297
+ notNull: true;
298
+ hasDefault: false;
299
+ isPrimaryKey: false;
300
+ isAutoincrement: false;
301
+ hasRuntimeDefault: false;
302
+ enumValues: [string, ...string[]];
303
+ baseColumn: never;
304
+ identity: undefined;
305
+ generated: undefined;
306
+ }, {}, {}>;
307
+ refreshTokenEnc: import("drizzle-orm/mysql-core").MySqlColumn<{
308
+ name: "refresh_token_enc";
309
+ tableName: "config_tokens";
310
+ dataType: "string";
311
+ columnType: "MySqlText";
312
+ data: string;
313
+ driverParam: string;
314
+ notNull: true;
315
+ hasDefault: false;
316
+ isPrimaryKey: false;
317
+ isAutoincrement: false;
318
+ hasRuntimeDefault: false;
319
+ enumValues: [string, ...string[]];
320
+ baseColumn: never;
321
+ identity: undefined;
322
+ generated: undefined;
323
+ }, {}, {}>;
324
+ expiresAt: import("drizzle-orm/mysql-core").MySqlColumn<{
325
+ name: "expires_at";
326
+ tableName: "config_tokens";
327
+ dataType: "date";
328
+ columnType: "MySqlDateTime";
329
+ data: Date;
330
+ driverParam: string | number;
331
+ notNull: true;
332
+ hasDefault: false;
333
+ isPrimaryKey: false;
334
+ isAutoincrement: false;
335
+ hasRuntimeDefault: false;
336
+ enumValues: undefined;
337
+ baseColumn: never;
338
+ identity: undefined;
339
+ generated: undefined;
340
+ }, {}, {}>;
341
+ updatedAt: import("drizzle-orm/mysql-core").MySqlColumn<{
342
+ name: "updated_at";
343
+ tableName: "config_tokens";
344
+ dataType: "date";
345
+ columnType: "MySqlDateTime";
346
+ data: Date;
347
+ driverParam: string | number;
348
+ notNull: true;
349
+ hasDefault: true;
350
+ isPrimaryKey: false;
351
+ isAutoincrement: false;
352
+ hasRuntimeDefault: true;
353
+ enumValues: undefined;
354
+ baseColumn: never;
355
+ identity: undefined;
356
+ generated: undefined;
357
+ }, {}, {}>;
358
+ };
359
+ dialect: "mysql";
360
+ }>;
361
+ export declare const oauthStates: import("drizzle-orm/mysql-core").MySqlTableWithColumns<{
362
+ name: "oauth_states";
363
+ schema: undefined;
364
+ columns: {
365
+ state: import("drizzle-orm/mysql-core").MySqlColumn<{
366
+ name: "state";
367
+ tableName: "oauth_states";
368
+ dataType: "string";
369
+ columnType: "MySqlVarChar";
370
+ data: string;
371
+ driverParam: string | number;
372
+ notNull: true;
373
+ hasDefault: false;
374
+ isPrimaryKey: true;
375
+ isAutoincrement: false;
376
+ hasRuntimeDefault: false;
377
+ enumValues: [string, ...string[]];
378
+ baseColumn: never;
379
+ identity: undefined;
380
+ generated: undefined;
381
+ }, {}, {}>;
382
+ botId: import("drizzle-orm/mysql-core").MySqlColumn<{
383
+ name: "bot_id";
384
+ tableName: "oauth_states";
385
+ dataType: "string";
386
+ columnType: "MySqlVarChar";
387
+ data: string;
388
+ driverParam: string | number;
389
+ notNull: true;
390
+ hasDefault: false;
391
+ isPrimaryKey: false;
392
+ isAutoincrement: false;
393
+ hasRuntimeDefault: false;
394
+ enumValues: [string, ...string[]];
395
+ baseColumn: never;
396
+ identity: undefined;
397
+ generated: undefined;
398
+ }, {}, {}>;
399
+ expiresAt: import("drizzle-orm/mysql-core").MySqlColumn<{
400
+ name: "expires_at";
401
+ tableName: "oauth_states";
402
+ dataType: "date";
403
+ columnType: "MySqlDateTime";
404
+ data: Date;
405
+ driverParam: string | number;
406
+ notNull: true;
407
+ hasDefault: false;
408
+ isPrimaryKey: false;
409
+ isAutoincrement: false;
410
+ hasRuntimeDefault: false;
411
+ enumValues: undefined;
412
+ baseColumn: never;
413
+ identity: undefined;
414
+ generated: undefined;
415
+ }, {}, {}>;
416
+ };
417
+ dialect: "mysql";
418
+ }>;
419
+ export declare const workspaceAdminConfig: import("drizzle-orm/mysql-core").MySqlTableWithColumns<{
420
+ name: "workspace_admin_config";
421
+ schema: undefined;
422
+ columns: {
423
+ workspaceId: import("drizzle-orm/mysql-core").MySqlColumn<{
424
+ name: "workspace_id";
425
+ tableName: "workspace_admin_config";
426
+ dataType: "string";
427
+ columnType: "MySqlVarChar";
428
+ data: string;
429
+ driverParam: string | number;
430
+ notNull: true;
431
+ hasDefault: false;
432
+ isPrimaryKey: true;
433
+ isAutoincrement: false;
434
+ hasRuntimeDefault: false;
435
+ enumValues: [string, ...string[]];
436
+ baseColumn: never;
437
+ identity: undefined;
438
+ generated: undefined;
439
+ }, {}, {}>;
440
+ slackClientId: import("drizzle-orm/mysql-core").MySqlColumn<{
441
+ name: "slack_client_id";
442
+ tableName: "workspace_admin_config";
443
+ dataType: "string";
444
+ columnType: "MySqlVarChar";
445
+ data: string;
446
+ driverParam: string | number;
447
+ notNull: false;
448
+ hasDefault: false;
449
+ isPrimaryKey: false;
450
+ isAutoincrement: false;
451
+ hasRuntimeDefault: false;
452
+ enumValues: [string, ...string[]];
453
+ baseColumn: never;
454
+ identity: undefined;
455
+ generated: undefined;
456
+ }, {}, {}>;
457
+ slackClientSecretEnc: import("drizzle-orm/mysql-core").MySqlColumn<{
458
+ name: "slack_client_secret_enc";
459
+ tableName: "workspace_admin_config";
460
+ dataType: "string";
461
+ columnType: "MySqlText";
462
+ data: string;
463
+ driverParam: string;
464
+ notNull: false;
465
+ hasDefault: false;
466
+ isPrimaryKey: false;
467
+ isAutoincrement: false;
468
+ hasRuntimeDefault: false;
469
+ enumValues: [string, ...string[]];
470
+ baseColumn: never;
471
+ identity: undefined;
472
+ generated: undefined;
473
+ }, {}, {}>;
474
+ dCookieEnc: import("drizzle-orm/mysql-core").MySqlColumn<{
475
+ name: "d_cookie_enc";
476
+ tableName: "workspace_admin_config";
477
+ dataType: "string";
478
+ columnType: "MySqlText";
479
+ data: string;
480
+ driverParam: string;
481
+ notNull: false;
482
+ hasDefault: false;
483
+ isPrimaryKey: false;
484
+ isAutoincrement: false;
485
+ hasRuntimeDefault: false;
486
+ enumValues: [string, ...string[]];
487
+ baseColumn: never;
488
+ identity: undefined;
489
+ generated: undefined;
490
+ }, {}, {}>;
491
+ xoxcTokenEnc: import("drizzle-orm/mysql-core").MySqlColumn<{
492
+ name: "xoxc_token_enc";
493
+ tableName: "workspace_admin_config";
494
+ dataType: "string";
495
+ columnType: "MySqlText";
496
+ data: string;
497
+ driverParam: string;
498
+ notNull: false;
499
+ hasDefault: false;
500
+ isPrimaryKey: false;
501
+ isAutoincrement: false;
502
+ hasRuntimeDefault: false;
503
+ enumValues: [string, ...string[]];
504
+ baseColumn: never;
505
+ identity: undefined;
506
+ generated: undefined;
507
+ }, {}, {}>;
508
+ workspaceDomain: import("drizzle-orm/mysql-core").MySqlColumn<{
509
+ name: "workspace_domain";
510
+ tableName: "workspace_admin_config";
511
+ dataType: "string";
512
+ columnType: "MySqlVarChar";
513
+ data: string;
514
+ driverParam: string | number;
515
+ notNull: false;
516
+ hasDefault: false;
517
+ isPrimaryKey: false;
518
+ isAutoincrement: false;
519
+ hasRuntimeDefault: false;
520
+ enumValues: [string, ...string[]];
521
+ baseColumn: never;
522
+ identity: undefined;
523
+ generated: undefined;
524
+ }, {}, {}>;
525
+ updatedAt: import("drizzle-orm/mysql-core").MySqlColumn<{
526
+ name: "updated_at";
527
+ tableName: "workspace_admin_config";
528
+ dataType: "date";
529
+ columnType: "MySqlDateTime";
530
+ data: Date;
531
+ driverParam: string | number;
532
+ notNull: true;
533
+ hasDefault: true;
534
+ isPrimaryKey: false;
535
+ isAutoincrement: false;
536
+ hasRuntimeDefault: true;
537
+ enumValues: undefined;
538
+ baseColumn: never;
539
+ identity: undefined;
540
+ generated: undefined;
541
+ }, {}, {}>;
542
+ updatedByUserId: import("drizzle-orm/mysql-core").MySqlColumn<{
543
+ name: "updated_by_user_id";
544
+ tableName: "workspace_admin_config";
545
+ dataType: "string";
546
+ columnType: "MySqlVarChar";
547
+ data: string;
548
+ driverParam: string | number;
549
+ notNull: false;
550
+ hasDefault: false;
551
+ isPrimaryKey: false;
552
+ isAutoincrement: false;
553
+ hasRuntimeDefault: false;
554
+ enumValues: [string, ...string[]];
555
+ baseColumn: never;
556
+ identity: undefined;
557
+ generated: undefined;
558
+ }, {}, {}>;
559
+ };
560
+ dialect: "mysql";
561
+ }>;
562
+ //# sourceMappingURL=schema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../src/db/mysql/schema.ts"],"names":[],"mappings":"AASA;;;;GAIG;AACH,eAAO,MAAM,YAAY,KAAK,CAAA;AAK9B,eAAO,MAAM,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA2BhB,CAAA;AAED,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EASvB,CAAA;AAEF,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAItB,CAAA;AAEF,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAY/B,CAAA"}
@@ -0,0 +1,61 @@
1
+ import { mysqlTableCreator, varchar, text, mysqlEnum, datetime, uniqueIndex, } from 'drizzle-orm/mysql-core';
2
+ /**
3
+ * Table prefix.
4
+ * When set, all tables get a `{prefix}_` prefix.
5
+ * E.g.: 'sena' -> sena_bots, sena_config_tokens
6
+ */
7
+ export const TABLE_PREFIX = '';
8
+ const mysqlTable = mysqlTableCreator((name) => TABLE_PREFIX ? `${TABLE_PREFIX}_${name}` : name);
9
+ export const bots = mysqlTable('bots', {
10
+ id: varchar('id', { length: 36 }).primaryKey(),
11
+ name: varchar('name', { length: 255 }).notNull(),
12
+ botUsername: varchar('bot_username', { length: 80 }).notNull().default(''),
13
+ profileImageUrl: text('profile_image_url'),
14
+ connectKey: varchar('connect_key', { length: 255 }).notNull(),
15
+ slackAppId: varchar('slack_app_id', { length: 64 }),
16
+ slackTeamId: varchar('slack_team_id', { length: 64 }),
17
+ botTokenEnc: text('bot_token_enc'),
18
+ signingSecretEnc: text('signing_secret_enc'),
19
+ clientId: varchar('client_id', { length: 128 }),
20
+ clientSecretEnc: text('client_secret_enc'),
21
+ manifestJson: text('manifest_json'),
22
+ status: mysqlEnum('status', ['pending', 'active', 'disabled'])
23
+ .notNull()
24
+ .default('pending'),
25
+ createdAt: datetime('created_at')
26
+ .notNull()
27
+ .$defaultFn(() => new Date()),
28
+ updatedAt: datetime('updated_at')
29
+ .notNull()
30
+ .$defaultFn(() => new Date())
31
+ .$onUpdateFn(() => new Date()),
32
+ }, (table) => [uniqueIndex('idx_bots_connect_key').on(table.connectKey)]);
33
+ export const configTokens = mysqlTable('config_tokens', {
34
+ workspaceId: varchar('workspace_id', { length: 64 }).primaryKey(),
35
+ accessTokenEnc: text('access_token_enc').notNull(),
36
+ refreshTokenEnc: text('refresh_token_enc').notNull(),
37
+ expiresAt: datetime('expires_at').notNull(),
38
+ updatedAt: datetime('updated_at')
39
+ .notNull()
40
+ .$defaultFn(() => new Date())
41
+ .$onUpdateFn(() => new Date()),
42
+ });
43
+ export const oauthStates = mysqlTable('oauth_states', {
44
+ state: varchar('state', { length: 64 }).primaryKey(),
45
+ botId: varchar('bot_id', { length: 36 }).notNull(),
46
+ expiresAt: datetime('expires_at').notNull(),
47
+ });
48
+ export const workspaceAdminConfig = mysqlTable('workspace_admin_config', {
49
+ workspaceId: varchar('workspace_id', { length: 64 }).primaryKey(),
50
+ slackClientId: varchar('slack_client_id', { length: 128 }),
51
+ slackClientSecretEnc: text('slack_client_secret_enc'),
52
+ dCookieEnc: text('d_cookie_enc'),
53
+ xoxcTokenEnc: text('xoxc_token_enc'),
54
+ workspaceDomain: varchar('workspace_domain', { length: 255 }),
55
+ updatedAt: datetime('updated_at')
56
+ .notNull()
57
+ .$defaultFn(() => new Date())
58
+ .$onUpdateFn(() => new Date()),
59
+ updatedByUserId: varchar('updated_by_user_id', { length: 36 }),
60
+ });
61
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../src/db/mysql/schema.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import { type PostgresJsDatabase } from 'drizzle-orm/postgres-js';
2
+ import type { BotRepository, ConfigTokenRepository, OAuthStateRepository, WorkspaceAdminConfigRepository } from '../../types/repository.js';
3
+ import * as schema from './schema.js';
4
+ export type PostgreSQLDatabase = PostgresJsDatabase<typeof schema>;
5
+ export declare function initPostgreSQLDb(databaseUrl: string): PostgreSQLDatabase;
6
+ export interface PostgreSQLRepositories {
7
+ bots: BotRepository;
8
+ configTokens: ConfigTokenRepository;
9
+ oauthStates: OAuthStateRepository;
10
+ workspaceAdminConfig: WorkspaceAdminConfigRepository;
11
+ }
12
+ export declare function createPostgreSQLRepositories(db: PostgreSQLDatabase): PostgreSQLRepositories;
13
+ export { TABLE_PREFIX, botStatusEnum, bots, configTokens, oauthStates, workspaceAdminConfig, } from './schema.js';
14
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/db/postgresql/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,KAAK,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAG1E,OAAO,KAAK,EAIV,aAAa,EACb,qBAAqB,EACrB,oBAAoB,EACpB,8BAA8B,EAC/B,MAAM,2BAA2B,CAAA;AAClC,OAAO,KAAK,MAAM,MAAM,aAAa,CAAA;AAErC,MAAM,MAAM,kBAAkB,GAAG,kBAAkB,CAAC,OAAO,MAAM,CAAC,CAAA;AAElE,wBAAgB,gBAAgB,CAAC,WAAW,EAAE,MAAM,GAAG,kBAAkB,CAGxE;AAqCD,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,aAAa,CAAA;IACnB,YAAY,EAAE,qBAAqB,CAAA;IACnC,WAAW,EAAE,oBAAoB,CAAA;IACjC,oBAAoB,EAAE,8BAA8B,CAAA;CACrD;AAED,wBAAgB,4BAA4B,CAC1C,EAAE,EAAE,kBAAkB,GACrB,sBAAsB,CAOxB;AAuOD,OAAO,EACL,YAAY,EACZ,aAAa,EACb,IAAI,EACJ,YAAY,EACZ,WAAW,EACX,oBAAoB,GACrB,MAAM,aAAa,CAAA"}