@minion-stack/db 0.2.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 (206) hide show
  1. package/dist/index.d.ts +4 -0
  2. package/dist/index.d.ts.map +1 -0
  3. package/dist/index.js +8 -0
  4. package/dist/index.js.map +1 -0
  5. package/dist/relations.d.ts +126 -0
  6. package/dist/relations.d.ts.map +1 -0
  7. package/dist/relations.js +178 -0
  8. package/dist/relations.js.map +1 -0
  9. package/dist/schema/activity-bins.d.ts +118 -0
  10. package/dist/schema/activity-bins.d.ts.map +1 -0
  11. package/dist/schema/activity-bins.js +19 -0
  12. package/dist/schema/activity-bins.js.map +1 -0
  13. package/dist/schema/agent-groups.d.ts +180 -0
  14. package/dist/schema/agent-groups.d.ts.map +1 -0
  15. package/dist/schema/agent-groups.js +22 -0
  16. package/dist/schema/agent-groups.js.map +1 -0
  17. package/dist/schema/agents.d.ts +196 -0
  18. package/dist/schema/agents.d.ts.map +1 -0
  19. package/dist/schema/agents.js +20 -0
  20. package/dist/schema/agents.js.map +1 -0
  21. package/dist/schema/auth/index.d.ts +1713 -0
  22. package/dist/schema/auth/index.d.ts.map +1 -0
  23. package/dist/schema/auth/index.js +152 -0
  24. package/dist/schema/auth/index.js.map +1 -0
  25. package/dist/schema/backup-configs.d.ts +207 -0
  26. package/dist/schema/backup-configs.d.ts.map +1 -0
  27. package/dist/schema/backup-configs.js +18 -0
  28. package/dist/schema/backup-configs.js.map +1 -0
  29. package/dist/schema/bugs.d.ts +232 -0
  30. package/dist/schema/bugs.d.ts.map +1 -0
  31. package/dist/schema/bugs.js +26 -0
  32. package/dist/schema/bugs.js.map +1 -0
  33. package/dist/schema/builder.d.ts +1546 -0
  34. package/dist/schema/builder.d.ts.map +1 -0
  35. package/dist/schema/builder.js +143 -0
  36. package/dist/schema/builder.js.map +1 -0
  37. package/dist/schema/channel-assignments.d.ts +120 -0
  38. package/dist/schema/channel-assignments.d.ts.map +1 -0
  39. package/dist/schema/channel-assignments.js +19 -0
  40. package/dist/schema/channel-assignments.js.map +1 -0
  41. package/dist/schema/channel-identities.d.ts +141 -0
  42. package/dist/schema/channel-identities.d.ts.map +1 -0
  43. package/dist/schema/channel-identities.js +21 -0
  44. package/dist/schema/channel-identities.js.map +1 -0
  45. package/dist/schema/channels.d.ts +213 -0
  46. package/dist/schema/channels.d.ts.map +1 -0
  47. package/dist/schema/channels.js +26 -0
  48. package/dist/schema/channels.js.map +1 -0
  49. package/dist/schema/chat-messages.d.ts +192 -0
  50. package/dist/schema/chat-messages.d.ts.map +1 -0
  51. package/dist/schema/chat-messages.js +23 -0
  52. package/dist/schema/chat-messages.js.map +1 -0
  53. package/dist/schema/config-snapshots.d.ts +120 -0
  54. package/dist/schema/config-snapshots.d.ts.map +1 -0
  55. package/dist/schema/config-snapshots.js +16 -0
  56. package/dist/schema/config-snapshots.js.map +1 -0
  57. package/dist/schema/connection-events.d.ts +173 -0
  58. package/dist/schema/connection-events.d.ts.map +1 -0
  59. package/dist/schema/connection-events.js +22 -0
  60. package/dist/schema/connection-events.js.map +1 -0
  61. package/dist/schema/credential-health.d.ts +116 -0
  62. package/dist/schema/credential-health.d.ts.map +1 -0
  63. package/dist/schema/credential-health.js +19 -0
  64. package/dist/schema/credential-health.js.map +1 -0
  65. package/dist/schema/device-identities.d.ts +120 -0
  66. package/dist/schema/device-identities.d.ts.map +1 -0
  67. package/dist/schema/device-identities.js +14 -0
  68. package/dist/schema/device-identities.js.map +1 -0
  69. package/dist/schema/files.d.ts +175 -0
  70. package/dist/schema/files.d.ts.map +1 -0
  71. package/dist/schema/files.js +16 -0
  72. package/dist/schema/files.js.map +1 -0
  73. package/dist/schema/flows.d.ts +156 -0
  74. package/dist/schema/flows.d.ts.map +1 -0
  75. package/dist/schema/flows.js +12 -0
  76. package/dist/schema/flows.js.map +1 -0
  77. package/dist/schema/gateway-heartbeats.d.ts +186 -0
  78. package/dist/schema/gateway-heartbeats.d.ts.map +1 -0
  79. package/dist/schema/gateway-heartbeats.js +23 -0
  80. package/dist/schema/gateway-heartbeats.js.map +1 -0
  81. package/dist/schema/index.d.ts +37 -0
  82. package/dist/schema/index.d.ts.map +1 -0
  83. package/dist/schema/index.js +38 -0
  84. package/dist/schema/index.js.map +1 -0
  85. package/dist/schema/marketplace-agents.d.ts +397 -0
  86. package/dist/schema/marketplace-agents.d.ts.map +1 -0
  87. package/dist/schema/marketplace-agents.js +25 -0
  88. package/dist/schema/marketplace-agents.js.map +1 -0
  89. package/dist/schema/marketplace-installs.d.ts +101 -0
  90. package/dist/schema/marketplace-installs.d.ts.map +1 -0
  91. package/dist/schema/marketplace-installs.js +21 -0
  92. package/dist/schema/marketplace-installs.js.map +1 -0
  93. package/dist/schema/missions.d.ts +194 -0
  94. package/dist/schema/missions.d.ts.map +1 -0
  95. package/dist/schema/missions.js +29 -0
  96. package/dist/schema/missions.js.map +1 -0
  97. package/dist/schema/personal-agents.d.ts +302 -0
  98. package/dist/schema/personal-agents.d.ts.map +1 -0
  99. package/dist/schema/personal-agents.js +37 -0
  100. package/dist/schema/personal-agents.js.map +1 -0
  101. package/dist/schema/reliability-events.d.ts +211 -0
  102. package/dist/schema/reliability-events.d.ts.map +1 -0
  103. package/dist/schema/reliability-events.js +28 -0
  104. package/dist/schema/reliability-events.js.map +1 -0
  105. package/dist/schema/server-backups.d.ts +154 -0
  106. package/dist/schema/server-backups.d.ts.map +1 -0
  107. package/dist/schema/server-backups.js +23 -0
  108. package/dist/schema/server-backups.js.map +1 -0
  109. package/dist/schema/server-provision-configs.d.ts +410 -0
  110. package/dist/schema/server-provision-configs.d.ts.map +1 -0
  111. package/dist/schema/server-provision-configs.js +43 -0
  112. package/dist/schema/server-provision-configs.js.map +1 -0
  113. package/dist/schema/servers.d.ts +192 -0
  114. package/dist/schema/servers.d.ts.map +1 -0
  115. package/dist/schema/servers.js +22 -0
  116. package/dist/schema/servers.js.map +1 -0
  117. package/dist/schema/session-tasks.d.ts +211 -0
  118. package/dist/schema/session-tasks.d.ts.map +1 -0
  119. package/dist/schema/session-tasks.js +26 -0
  120. package/dist/schema/session-tasks.js.map +1 -0
  121. package/dist/schema/sessions.d.ts +209 -0
  122. package/dist/schema/sessions.d.ts.map +1 -0
  123. package/dist/schema/sessions.js +27 -0
  124. package/dist/schema/sessions.js.map +1 -0
  125. package/dist/schema/settings.d.ts +118 -0
  126. package/dist/schema/settings.d.ts.map +1 -0
  127. package/dist/schema/settings.js +19 -0
  128. package/dist/schema/settings.js.map +1 -0
  129. package/dist/schema/skill-execution-stats.d.ts +209 -0
  130. package/dist/schema/skill-execution-stats.d.ts.map +1 -0
  131. package/dist/schema/skill-execution-stats.js +24 -0
  132. package/dist/schema/skill-execution-stats.js.map +1 -0
  133. package/dist/schema/skills.d.ts +209 -0
  134. package/dist/schema/skills.d.ts.map +1 -0
  135. package/dist/schema/skills.js +24 -0
  136. package/dist/schema/skills.js.map +1 -0
  137. package/dist/schema/tasks.d.ts +192 -0
  138. package/dist/schema/tasks.d.ts.map +1 -0
  139. package/dist/schema/tasks.js +22 -0
  140. package/dist/schema/tasks.js.map +1 -0
  141. package/dist/schema/unified-events.d.ts +247 -0
  142. package/dist/schema/unified-events.d.ts.map +1 -0
  143. package/dist/schema/unified-events.js +29 -0
  144. package/dist/schema/unified-events.js.map +1 -0
  145. package/dist/schema/user-agents.d.ts +82 -0
  146. package/dist/schema/user-agents.d.ts.map +1 -0
  147. package/dist/schema/user-agents.js +17 -0
  148. package/dist/schema/user-agents.js.map +1 -0
  149. package/dist/schema/user-preferences.d.ts +99 -0
  150. package/dist/schema/user-preferences.d.ts.map +1 -0
  151. package/dist/schema/user-preferences.js +15 -0
  152. package/dist/schema/user-preferences.js.map +1 -0
  153. package/dist/schema/user-servers.d.ts +63 -0
  154. package/dist/schema/user-servers.d.ts.map +1 -0
  155. package/dist/schema/user-servers.js +16 -0
  156. package/dist/schema/user-servers.js.map +1 -0
  157. package/dist/schema/workshop-saves.d.ts +156 -0
  158. package/dist/schema/workshop-saves.d.ts.map +1 -0
  159. package/dist/schema/workshop-saves.js +12 -0
  160. package/dist/schema/workshop-saves.js.map +1 -0
  161. package/dist/utils.d.ts +3 -0
  162. package/dist/utils.d.ts.map +1 -0
  163. package/dist/utils.js +9 -0
  164. package/dist/utils.js.map +1 -0
  165. package/package.json +58 -0
  166. package/src/index.ts +7 -0
  167. package/src/relations.ts +258 -0
  168. package/src/schema/activity-bins.ts +23 -0
  169. package/src/schema/agent-groups.ts +31 -0
  170. package/src/schema/agents.ts +24 -0
  171. package/src/schema/auth/index.ts +190 -0
  172. package/src/schema/backup-configs.ts +22 -0
  173. package/src/schema/bugs.ts +30 -0
  174. package/src/schema/builder.ts +151 -0
  175. package/src/schema/channel-assignments.ts +23 -0
  176. package/src/schema/channel-identities.ts +25 -0
  177. package/src/schema/channels.ts +30 -0
  178. package/src/schema/chat-messages.ts +27 -0
  179. package/src/schema/config-snapshots.ts +20 -0
  180. package/src/schema/connection-events.ts +26 -0
  181. package/src/schema/credential-health.ts +23 -0
  182. package/src/schema/device-identities.ts +14 -0
  183. package/src/schema/files.ts +20 -0
  184. package/src/schema/flows.ts +12 -0
  185. package/src/schema/gateway-heartbeats.ts +27 -0
  186. package/src/schema/index.ts +59 -0
  187. package/src/schema/marketplace-agents.ts +25 -0
  188. package/src/schema/marketplace-installs.ts +25 -0
  189. package/src/schema/missions.ts +33 -0
  190. package/src/schema/personal-agents.ts +41 -0
  191. package/src/schema/reliability-events.ts +32 -0
  192. package/src/schema/server-backups.ts +27 -0
  193. package/src/schema/server-provision-configs.ts +57 -0
  194. package/src/schema/servers.ts +26 -0
  195. package/src/schema/session-tasks.ts +30 -0
  196. package/src/schema/sessions.ts +31 -0
  197. package/src/schema/settings.ts +23 -0
  198. package/src/schema/skill-execution-stats.ts +28 -0
  199. package/src/schema/skills.ts +28 -0
  200. package/src/schema/tasks.ts +26 -0
  201. package/src/schema/unified-events.ts +33 -0
  202. package/src/schema/user-agents.ts +21 -0
  203. package/src/schema/user-preferences.ts +19 -0
  204. package/src/schema/user-servers.ts +20 -0
  205. package/src/schema/workshop-saves.ts +12 -0
  206. package/src/utils.ts +11 -0
@@ -0,0 +1,22 @@
1
+ import { sqliteTable, text, integer, index } from 'drizzle-orm/sqlite-core';
2
+ import { organization } from './auth/index.js';
3
+ import { missions } from './missions.js';
4
+ export const tasks = sqliteTable('tasks', {
5
+ id: text('id').primaryKey(),
6
+ tenantId: text('tenant_id')
7
+ .notNull()
8
+ .references(() => organization.id, { onDelete: 'cascade' }),
9
+ missionId: text('mission_id')
10
+ .notNull()
11
+ .references(() => missions.id, { onDelete: 'cascade' }),
12
+ title: text('title').notNull(),
13
+ description: text('description'),
14
+ status: text('status', { enum: ['backlog', 'todo', 'in_progress', 'done'] })
15
+ .notNull()
16
+ .default('backlog'),
17
+ sortOrder: integer('sort_order').notNull().default(0),
18
+ metadata: text('metadata'),
19
+ createdAt: integer('created_at').notNull(),
20
+ updatedAt: integer('updated_at').notNull(),
21
+ }, (t) => [index('idx_tasks_tenant').on(t.tenantId), index('idx_tasks_mission').on(t.missionId)]);
22
+ //# sourceMappingURL=tasks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tasks.js","sourceRoot":"","sources":["../../src/schema/tasks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAC;AAC5E,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAEzC,MAAM,CAAC,MAAM,KAAK,GAAG,WAAW,CAC9B,OAAO,EACP;IACE,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE;IAC3B,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC;SACxB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAC7D,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC;SAC1B,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACzD,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE;IAC9B,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC;IAChC,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,CAAC,EAAE,CAAC;SACzE,OAAO,EAAE;SACT,OAAO,CAAC,SAAS,CAAC;IACrB,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IACrD,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC;IAC1B,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE;IAC1C,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE;CAC3C,EACD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC,mBAAmB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAC9F,CAAC"}
@@ -0,0 +1,247 @@
1
+ export declare const unifiedEvents: import("drizzle-orm/sqlite-core").SQLiteTableWithColumns<{
2
+ name: "unified_events";
3
+ schema: undefined;
4
+ columns: {
5
+ id: import("drizzle-orm/sqlite-core").SQLiteColumn<{
6
+ name: "id";
7
+ tableName: "unified_events";
8
+ dataType: "number";
9
+ columnType: "SQLiteInteger";
10
+ data: number;
11
+ driverParam: number;
12
+ notNull: true;
13
+ hasDefault: true;
14
+ isPrimaryKey: true;
15
+ isAutoincrement: false;
16
+ hasRuntimeDefault: false;
17
+ enumValues: undefined;
18
+ baseColumn: never;
19
+ identity: undefined;
20
+ generated: undefined;
21
+ }, {}, {}>;
22
+ tenantId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
23
+ name: "tenant_id";
24
+ tableName: "unified_events";
25
+ dataType: "string";
26
+ columnType: "SQLiteText";
27
+ data: string;
28
+ driverParam: string;
29
+ notNull: true;
30
+ hasDefault: false;
31
+ isPrimaryKey: false;
32
+ isAutoincrement: false;
33
+ hasRuntimeDefault: false;
34
+ enumValues: [string, ...string[]];
35
+ baseColumn: never;
36
+ identity: undefined;
37
+ generated: undefined;
38
+ }, {}, {
39
+ length: number | undefined;
40
+ }>;
41
+ serverId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
42
+ name: "server_id";
43
+ tableName: "unified_events";
44
+ dataType: "string";
45
+ columnType: "SQLiteText";
46
+ data: string;
47
+ driverParam: string;
48
+ notNull: true;
49
+ hasDefault: false;
50
+ isPrimaryKey: false;
51
+ isAutoincrement: false;
52
+ hasRuntimeDefault: false;
53
+ enumValues: [string, ...string[]];
54
+ baseColumn: never;
55
+ identity: undefined;
56
+ generated: undefined;
57
+ }, {}, {
58
+ length: number | undefined;
59
+ }>;
60
+ localEventId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
61
+ name: "local_event_id";
62
+ tableName: "unified_events";
63
+ dataType: "number";
64
+ columnType: "SQLiteInteger";
65
+ data: number;
66
+ driverParam: number;
67
+ notNull: true;
68
+ hasDefault: false;
69
+ isPrimaryKey: false;
70
+ isAutoincrement: false;
71
+ hasRuntimeDefault: false;
72
+ enumValues: undefined;
73
+ baseColumn: never;
74
+ identity: undefined;
75
+ generated: undefined;
76
+ }, {}, {}>;
77
+ category: import("drizzle-orm/sqlite-core").SQLiteColumn<{
78
+ name: "category";
79
+ tableName: "unified_events";
80
+ dataType: "string";
81
+ columnType: "SQLiteText";
82
+ data: string;
83
+ driverParam: string;
84
+ notNull: true;
85
+ hasDefault: false;
86
+ isPrimaryKey: false;
87
+ isAutoincrement: false;
88
+ hasRuntimeDefault: false;
89
+ enumValues: [string, ...string[]];
90
+ baseColumn: never;
91
+ identity: undefined;
92
+ generated: undefined;
93
+ }, {}, {
94
+ length: number | undefined;
95
+ }>;
96
+ severity: import("drizzle-orm/sqlite-core").SQLiteColumn<{
97
+ name: "severity";
98
+ tableName: "unified_events";
99
+ dataType: "string";
100
+ columnType: "SQLiteText";
101
+ data: "critical" | "high" | "medium" | "low" | "info";
102
+ driverParam: string;
103
+ notNull: true;
104
+ hasDefault: false;
105
+ isPrimaryKey: false;
106
+ isAutoincrement: false;
107
+ hasRuntimeDefault: false;
108
+ enumValues: ["critical", "high", "medium", "low", "info"];
109
+ baseColumn: never;
110
+ identity: undefined;
111
+ generated: undefined;
112
+ }, {}, {
113
+ length: number | undefined;
114
+ }>;
115
+ event: import("drizzle-orm/sqlite-core").SQLiteColumn<{
116
+ name: "event";
117
+ tableName: "unified_events";
118
+ dataType: "string";
119
+ columnType: "SQLiteText";
120
+ data: string;
121
+ driverParam: string;
122
+ notNull: true;
123
+ hasDefault: false;
124
+ isPrimaryKey: false;
125
+ isAutoincrement: false;
126
+ hasRuntimeDefault: false;
127
+ enumValues: [string, ...string[]];
128
+ baseColumn: never;
129
+ identity: undefined;
130
+ generated: undefined;
131
+ }, {}, {
132
+ length: number | undefined;
133
+ }>;
134
+ message: import("drizzle-orm/sqlite-core").SQLiteColumn<{
135
+ name: "message";
136
+ tableName: "unified_events";
137
+ dataType: "string";
138
+ columnType: "SQLiteText";
139
+ data: string;
140
+ driverParam: string;
141
+ notNull: true;
142
+ hasDefault: false;
143
+ isPrimaryKey: false;
144
+ isAutoincrement: false;
145
+ hasRuntimeDefault: false;
146
+ enumValues: [string, ...string[]];
147
+ baseColumn: never;
148
+ identity: undefined;
149
+ generated: undefined;
150
+ }, {}, {
151
+ length: number | undefined;
152
+ }>;
153
+ agentId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
154
+ name: "agent_id";
155
+ tableName: "unified_events";
156
+ dataType: "string";
157
+ columnType: "SQLiteText";
158
+ data: string;
159
+ driverParam: string;
160
+ notNull: false;
161
+ hasDefault: false;
162
+ isPrimaryKey: false;
163
+ isAutoincrement: false;
164
+ hasRuntimeDefault: false;
165
+ enumValues: [string, ...string[]];
166
+ baseColumn: never;
167
+ identity: undefined;
168
+ generated: undefined;
169
+ }, {}, {
170
+ length: number | undefined;
171
+ }>;
172
+ correlationId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
173
+ name: "correlation_id";
174
+ tableName: "unified_events";
175
+ dataType: "string";
176
+ columnType: "SQLiteText";
177
+ data: string;
178
+ driverParam: string;
179
+ notNull: false;
180
+ hasDefault: false;
181
+ isPrimaryKey: false;
182
+ isAutoincrement: false;
183
+ hasRuntimeDefault: false;
184
+ enumValues: [string, ...string[]];
185
+ baseColumn: never;
186
+ identity: undefined;
187
+ generated: undefined;
188
+ }, {}, {
189
+ length: number | undefined;
190
+ }>;
191
+ metadata: import("drizzle-orm/sqlite-core").SQLiteColumn<{
192
+ name: "metadata";
193
+ tableName: "unified_events";
194
+ dataType: "string";
195
+ columnType: "SQLiteText";
196
+ data: string;
197
+ driverParam: string;
198
+ notNull: false;
199
+ hasDefault: false;
200
+ isPrimaryKey: false;
201
+ isAutoincrement: false;
202
+ hasRuntimeDefault: false;
203
+ enumValues: [string, ...string[]];
204
+ baseColumn: never;
205
+ identity: undefined;
206
+ generated: undefined;
207
+ }, {}, {
208
+ length: number | undefined;
209
+ }>;
210
+ occurredAt: import("drizzle-orm/sqlite-core").SQLiteColumn<{
211
+ name: "occurred_at";
212
+ tableName: "unified_events";
213
+ dataType: "number";
214
+ columnType: "SQLiteInteger";
215
+ data: number;
216
+ driverParam: number;
217
+ notNull: true;
218
+ hasDefault: false;
219
+ isPrimaryKey: false;
220
+ isAutoincrement: false;
221
+ hasRuntimeDefault: false;
222
+ enumValues: undefined;
223
+ baseColumn: never;
224
+ identity: undefined;
225
+ generated: undefined;
226
+ }, {}, {}>;
227
+ createdAt: import("drizzle-orm/sqlite-core").SQLiteColumn<{
228
+ name: "created_at";
229
+ tableName: "unified_events";
230
+ dataType: "number";
231
+ columnType: "SQLiteInteger";
232
+ data: number;
233
+ driverParam: number;
234
+ notNull: true;
235
+ hasDefault: false;
236
+ isPrimaryKey: false;
237
+ isAutoincrement: false;
238
+ hasRuntimeDefault: false;
239
+ enumValues: undefined;
240
+ baseColumn: never;
241
+ identity: undefined;
242
+ generated: undefined;
243
+ }, {}, {}>;
244
+ };
245
+ dialect: "sqlite";
246
+ }>;
247
+ //# sourceMappingURL=unified-events.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unified-events.d.ts","sourceRoot":"","sources":["../../src/schema/unified-events.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA4BzB,CAAC"}
@@ -0,0 +1,29 @@
1
+ import { sqliteTable, text, integer, index, uniqueIndex } from 'drizzle-orm/sqlite-core';
2
+ import { organization } from './auth/index.js';
3
+ import { servers } from './servers.js';
4
+ export const unifiedEvents = sqliteTable('unified_events', {
5
+ id: integer('id').primaryKey({ autoIncrement: true }),
6
+ tenantId: text('tenant_id')
7
+ .notNull()
8
+ .references(() => organization.id, { onDelete: 'cascade' }),
9
+ serverId: text('server_id')
10
+ .notNull()
11
+ .references(() => servers.id, { onDelete: 'cascade' }),
12
+ localEventId: integer('local_event_id').notNull(),
13
+ category: text('category').notNull(),
14
+ severity: text('severity', { enum: ['critical', 'high', 'medium', 'low', 'info'] }).notNull(),
15
+ event: text('event').notNull(),
16
+ message: text('message').notNull(),
17
+ agentId: text('agent_id'),
18
+ correlationId: text('correlation_id'),
19
+ metadata: text('metadata'),
20
+ occurredAt: integer('occurred_at').notNull(),
21
+ createdAt: integer('created_at').notNull(),
22
+ }, (t) => [
23
+ index('idx_unified_events_tenant').on(t.tenantId),
24
+ index('idx_unified_events_server_cat_time').on(t.serverId, t.category, t.occurredAt),
25
+ index('idx_unified_events_server_time').on(t.serverId, t.occurredAt),
26
+ index('idx_unified_events_correlation').on(t.correlationId),
27
+ uniqueIndex('idx_unified_events_dedup').on(t.tenantId, t.serverId, t.localEventId),
28
+ ]);
29
+ //# sourceMappingURL=unified-events.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unified-events.js","sourceRoot":"","sources":["../../src/schema/unified-events.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,CAAC,MAAM,aAAa,GAAG,WAAW,CACtC,gBAAgB,EAChB;IACE,EAAE,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;IACrD,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC;SACxB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAC7D,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC;SACxB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACxD,YAAY,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC,OAAO,EAAE;IACjD,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,EAAE;IACpC,QAAQ,EAAE,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE;IAC7F,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE;IAC9B,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE;IAClC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC;IACzB,aAAa,EAAE,IAAI,CAAC,gBAAgB,CAAC;IACrC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC;IAC1B,UAAU,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC,OAAO,EAAE;IAC5C,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE;CAC3C,EACD,CAAC,CAAC,EAAE,EAAE,CAAC;IACL,KAAK,CAAC,2BAA2B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;IACjD,KAAK,CAAC,oCAAoC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,UAAU,CAAC;IACpF,KAAK,CAAC,gCAAgC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,UAAU,CAAC;IACpE,KAAK,CAAC,gCAAgC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC;IAC3D,WAAW,CAAC,0BAA0B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,YAAY,CAAC;CACnF,CACF,CAAC"}
@@ -0,0 +1,82 @@
1
+ export declare const userAgents: import("drizzle-orm/sqlite-core").SQLiteTableWithColumns<{
2
+ name: "user_agents";
3
+ schema: undefined;
4
+ columns: {
5
+ userId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
6
+ name: "user_id";
7
+ tableName: "user_agents";
8
+ dataType: "string";
9
+ columnType: "SQLiteText";
10
+ data: string;
11
+ driverParam: string;
12
+ notNull: true;
13
+ hasDefault: false;
14
+ isPrimaryKey: false;
15
+ isAutoincrement: false;
16
+ hasRuntimeDefault: false;
17
+ enumValues: [string, ...string[]];
18
+ baseColumn: never;
19
+ identity: undefined;
20
+ generated: undefined;
21
+ }, {}, {
22
+ length: number | undefined;
23
+ }>;
24
+ agentId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
25
+ name: "agent_id";
26
+ tableName: "user_agents";
27
+ dataType: "string";
28
+ columnType: "SQLiteText";
29
+ data: string;
30
+ driverParam: string;
31
+ notNull: true;
32
+ hasDefault: false;
33
+ isPrimaryKey: false;
34
+ isAutoincrement: false;
35
+ hasRuntimeDefault: false;
36
+ enumValues: [string, ...string[]];
37
+ baseColumn: never;
38
+ identity: undefined;
39
+ generated: undefined;
40
+ }, {}, {
41
+ length: number | undefined;
42
+ }>;
43
+ serverId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
44
+ name: "server_id";
45
+ tableName: "user_agents";
46
+ dataType: "string";
47
+ columnType: "SQLiteText";
48
+ data: string;
49
+ driverParam: string;
50
+ notNull: true;
51
+ hasDefault: false;
52
+ isPrimaryKey: false;
53
+ isAutoincrement: false;
54
+ hasRuntimeDefault: false;
55
+ enumValues: [string, ...string[]];
56
+ baseColumn: never;
57
+ identity: undefined;
58
+ generated: undefined;
59
+ }, {}, {
60
+ length: number | undefined;
61
+ }>;
62
+ createdAt: import("drizzle-orm/sqlite-core").SQLiteColumn<{
63
+ name: "created_at";
64
+ tableName: "user_agents";
65
+ dataType: "number";
66
+ columnType: "SQLiteInteger";
67
+ data: number;
68
+ driverParam: number;
69
+ notNull: true;
70
+ hasDefault: false;
71
+ isPrimaryKey: false;
72
+ isAutoincrement: false;
73
+ hasRuntimeDefault: false;
74
+ enumValues: undefined;
75
+ baseColumn: never;
76
+ identity: undefined;
77
+ generated: undefined;
78
+ }, {}, {}>;
79
+ };
80
+ dialect: "sqlite";
81
+ }>;
82
+ //# sourceMappingURL=user-agents.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-agents.d.ts","sourceRoot":"","sources":["../../src/schema/user-agents.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAgBtB,CAAC"}
@@ -0,0 +1,17 @@
1
+ import { sqliteTable, text, integer, primaryKey, index } from 'drizzle-orm/sqlite-core';
2
+ import { user } from './auth/index.js';
3
+ import { servers } from './servers.js';
4
+ export const userAgents = sqliteTable('user_agents', {
5
+ userId: text('user_id')
6
+ .notNull()
7
+ .references(() => user.id, { onDelete: 'cascade' }),
8
+ agentId: text('agent_id').notNull(),
9
+ serverId: text('server_id')
10
+ .notNull()
11
+ .references(() => servers.id, { onDelete: 'cascade' }),
12
+ createdAt: integer('created_at').notNull(),
13
+ }, (t) => [
14
+ primaryKey({ columns: [t.userId, t.agentId, t.serverId] }),
15
+ index('idx_user_agents_server').on(t.serverId),
16
+ ]);
17
+ //# sourceMappingURL=user-agents.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-agents.js","sourceRoot":"","sources":["../../src/schema/user-agents.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAC;AACxF,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,CAAC,MAAM,UAAU,GAAG,WAAW,CACnC,aAAa,EACb;IACE,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC;SACpB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACrD,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,EAAE;IACnC,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC;SACxB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACxD,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE;CAC3C,EACD,CAAC,CAAC,EAAE,EAAE,CAAC;IACL,UAAU,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;IAC1D,KAAK,CAAC,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;CAC/C,CACF,CAAC"}
@@ -0,0 +1,99 @@
1
+ export declare const userPreferences: import("drizzle-orm/sqlite-core").SQLiteTableWithColumns<{
2
+ name: "user_preferences";
3
+ schema: undefined;
4
+ columns: {
5
+ id: import("drizzle-orm/sqlite-core").SQLiteColumn<{
6
+ name: "id";
7
+ tableName: "user_preferences";
8
+ dataType: "number";
9
+ columnType: "SQLiteInteger";
10
+ data: number;
11
+ driverParam: number;
12
+ notNull: true;
13
+ hasDefault: true;
14
+ isPrimaryKey: true;
15
+ isAutoincrement: false;
16
+ hasRuntimeDefault: false;
17
+ enumValues: undefined;
18
+ baseColumn: never;
19
+ identity: undefined;
20
+ generated: undefined;
21
+ }, {}, {}>;
22
+ userId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
23
+ name: "user_id";
24
+ tableName: "user_preferences";
25
+ dataType: "string";
26
+ columnType: "SQLiteText";
27
+ data: string;
28
+ driverParam: string;
29
+ notNull: true;
30
+ hasDefault: false;
31
+ isPrimaryKey: false;
32
+ isAutoincrement: false;
33
+ hasRuntimeDefault: false;
34
+ enumValues: [string, ...string[]];
35
+ baseColumn: never;
36
+ identity: undefined;
37
+ generated: undefined;
38
+ }, {}, {
39
+ length: number | undefined;
40
+ }>;
41
+ section: import("drizzle-orm/sqlite-core").SQLiteColumn<{
42
+ name: "section";
43
+ tableName: "user_preferences";
44
+ dataType: "string";
45
+ columnType: "SQLiteText";
46
+ data: string;
47
+ driverParam: string;
48
+ notNull: true;
49
+ hasDefault: false;
50
+ isPrimaryKey: false;
51
+ isAutoincrement: false;
52
+ hasRuntimeDefault: false;
53
+ enumValues: [string, ...string[]];
54
+ baseColumn: never;
55
+ identity: undefined;
56
+ generated: undefined;
57
+ }, {}, {
58
+ length: number | undefined;
59
+ }>;
60
+ value: import("drizzle-orm/sqlite-core").SQLiteColumn<{
61
+ name: "value";
62
+ tableName: "user_preferences";
63
+ dataType: "string";
64
+ columnType: "SQLiteText";
65
+ data: string;
66
+ driverParam: string;
67
+ notNull: true;
68
+ hasDefault: false;
69
+ isPrimaryKey: false;
70
+ isAutoincrement: false;
71
+ hasRuntimeDefault: false;
72
+ enumValues: [string, ...string[]];
73
+ baseColumn: never;
74
+ identity: undefined;
75
+ generated: undefined;
76
+ }, {}, {
77
+ length: number | undefined;
78
+ }>;
79
+ updatedAt: import("drizzle-orm/sqlite-core").SQLiteColumn<{
80
+ name: "updated_at";
81
+ tableName: "user_preferences";
82
+ dataType: "number";
83
+ columnType: "SQLiteInteger";
84
+ data: number;
85
+ driverParam: number;
86
+ notNull: true;
87
+ hasDefault: false;
88
+ isPrimaryKey: false;
89
+ isAutoincrement: false;
90
+ hasRuntimeDefault: false;
91
+ enumValues: undefined;
92
+ baseColumn: never;
93
+ identity: undefined;
94
+ generated: undefined;
95
+ }, {}, {}>;
96
+ };
97
+ dialect: "sqlite";
98
+ }>;
99
+ //# sourceMappingURL=user-preferences.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-preferences.d.ts","sourceRoot":"","sources":["../../src/schema/user-preferences.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAe3B,CAAC"}
@@ -0,0 +1,15 @@
1
+ import { sqliteTable, text, integer, uniqueIndex, index } from 'drizzle-orm/sqlite-core';
2
+ import { user } from './auth/index.js';
3
+ export const userPreferences = sqliteTable('user_preferences', {
4
+ id: integer('id').primaryKey({ autoIncrement: true }),
5
+ userId: text('user_id')
6
+ .notNull()
7
+ .references(() => user.id, { onDelete: 'cascade' }),
8
+ section: text('section').notNull(),
9
+ value: text('value').notNull(),
10
+ updatedAt: integer('updated_at').notNull(),
11
+ }, (t) => [
12
+ uniqueIndex('uq_user_prefs_user_section').on(t.userId, t.section),
13
+ index('idx_user_prefs_user').on(t.userId),
14
+ ]);
15
+ //# sourceMappingURL=user-preferences.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-preferences.js","sourceRoot":"","sources":["../../src/schema/user-preferences.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAC;AACzF,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAEvC,MAAM,CAAC,MAAM,eAAe,GAAG,WAAW,CACxC,kBAAkB,EAClB;IACE,EAAE,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;IACrD,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC;SACpB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACrD,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE;IAClC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE;IAC9B,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE;CAC3C,EACD,CAAC,CAAC,EAAE,EAAE,CAAC;IACL,WAAW,CAAC,4BAA4B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC;IACjE,KAAK,CAAC,qBAAqB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;CAC1C,CACF,CAAC"}
@@ -0,0 +1,63 @@
1
+ export declare const userServers: import("drizzle-orm/sqlite-core").SQLiteTableWithColumns<{
2
+ name: "user_servers";
3
+ schema: undefined;
4
+ columns: {
5
+ userId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
6
+ name: "user_id";
7
+ tableName: "user_servers";
8
+ dataType: "string";
9
+ columnType: "SQLiteText";
10
+ data: string;
11
+ driverParam: string;
12
+ notNull: true;
13
+ hasDefault: false;
14
+ isPrimaryKey: false;
15
+ isAutoincrement: false;
16
+ hasRuntimeDefault: false;
17
+ enumValues: [string, ...string[]];
18
+ baseColumn: never;
19
+ identity: undefined;
20
+ generated: undefined;
21
+ }, {}, {
22
+ length: number | undefined;
23
+ }>;
24
+ serverId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
25
+ name: "server_id";
26
+ tableName: "user_servers";
27
+ dataType: "string";
28
+ columnType: "SQLiteText";
29
+ data: string;
30
+ driverParam: string;
31
+ notNull: true;
32
+ hasDefault: false;
33
+ isPrimaryKey: false;
34
+ isAutoincrement: false;
35
+ hasRuntimeDefault: false;
36
+ enumValues: [string, ...string[]];
37
+ baseColumn: never;
38
+ identity: undefined;
39
+ generated: undefined;
40
+ }, {}, {
41
+ length: number | undefined;
42
+ }>;
43
+ createdAt: import("drizzle-orm/sqlite-core").SQLiteColumn<{
44
+ name: "created_at";
45
+ tableName: "user_servers";
46
+ dataType: "number";
47
+ columnType: "SQLiteInteger";
48
+ data: number;
49
+ driverParam: number;
50
+ notNull: true;
51
+ hasDefault: false;
52
+ isPrimaryKey: false;
53
+ isAutoincrement: false;
54
+ hasRuntimeDefault: false;
55
+ enumValues: undefined;
56
+ baseColumn: never;
57
+ identity: undefined;
58
+ generated: undefined;
59
+ }, {}, {}>;
60
+ };
61
+ dialect: "sqlite";
62
+ }>;
63
+ //# sourceMappingURL=user-servers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-servers.d.ts","sourceRoot":"","sources":["../../src/schema/user-servers.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAevB,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { sqliteTable, text, integer, primaryKey, index } from 'drizzle-orm/sqlite-core';
2
+ import { user } from './auth/index.js';
3
+ import { servers } from './servers.js';
4
+ export const userServers = sqliteTable('user_servers', {
5
+ userId: text('user_id')
6
+ .notNull()
7
+ .references(() => user.id, { onDelete: 'cascade' }),
8
+ serverId: text('server_id')
9
+ .notNull()
10
+ .references(() => servers.id, { onDelete: 'cascade' }),
11
+ createdAt: integer('created_at').notNull(),
12
+ }, (t) => [
13
+ primaryKey({ columns: [t.userId, t.serverId] }),
14
+ index('idx_user_servers_server').on(t.serverId),
15
+ ]);
16
+ //# sourceMappingURL=user-servers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-servers.js","sourceRoot":"","sources":["../../src/schema/user-servers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAC;AACxF,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,CAAC,MAAM,WAAW,GAAG,WAAW,CACpC,cAAc,EACd;IACE,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC;SACpB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACrD,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC;SACxB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACxD,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE;CAC3C,EACD,CAAC,CAAC,EAAE,EAAE,CAAC;IACL,UAAU,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;IAC/C,KAAK,CAAC,yBAAyB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;CAChD,CACF,CAAC"}