@vorionsys/contracts 0.1.0 → 0.1.2

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/CHANGELOG.md +44 -0
  2. package/LICENSE +190 -0
  3. package/README.md +435 -0
  4. package/dist/aci/index.d.ts +6 -62
  5. package/dist/aci/index.d.ts.map +1 -1
  6. package/dist/aci/index.js +22 -152
  7. package/dist/aci/index.js.map +1 -1
  8. package/dist/canonical/agent.d.ts +2 -2
  9. package/dist/canonical/agent.d.ts.map +1 -1
  10. package/dist/canonical/agent.js +146 -130
  11. package/dist/canonical/agent.js.map +1 -1
  12. package/dist/canonical/governance.d.ts +1 -1
  13. package/dist/canonical/governance.js +134 -120
  14. package/dist/canonical/governance.js.map +1 -1
  15. package/dist/canonical/index.d.ts +1 -0
  16. package/dist/canonical/index.d.ts.map +1 -1
  17. package/dist/canonical/index.js +26 -8
  18. package/dist/canonical/index.js.map +1 -1
  19. package/dist/canonical/intent.d.ts +8 -15
  20. package/dist/canonical/intent.d.ts.map +1 -1
  21. package/dist/canonical/intent.js +91 -82
  22. package/dist/canonical/intent.js.map +1 -1
  23. package/dist/canonical/middleware.d.ts +513 -0
  24. package/dist/canonical/middleware.d.ts.map +1 -0
  25. package/dist/canonical/middleware.js +218 -0
  26. package/dist/canonical/middleware.js.map +1 -0
  27. package/dist/canonical/risk-level.d.ts +1 -1
  28. package/dist/canonical/risk-level.js +66 -46
  29. package/dist/canonical/risk-level.js.map +1 -1
  30. package/dist/canonical/trust-band.d.ts +1 -1
  31. package/dist/canonical/trust-band.js +39 -28
  32. package/dist/canonical/trust-band.js.map +1 -1
  33. package/dist/canonical/trust-score.d.ts +1 -1
  34. package/dist/canonical/trust-score.js +46 -29
  35. package/dist/canonical/trust-score.js.map +1 -1
  36. package/dist/canonical/trust-signal.d.ts +13 -13
  37. package/dist/canonical/trust-signal.js +91 -78
  38. package/dist/canonical/trust-signal.js.map +1 -1
  39. package/dist/canonical/validation.js +148 -102
  40. package/dist/canonical/validation.js.map +1 -1
  41. package/dist/{aci → car}/attestation.d.ts +73 -73
  42. package/dist/{aci → car}/attestation.d.ts.map +1 -1
  43. package/dist/{aci → car}/attestation.js +69 -59
  44. package/dist/car/attestation.js.map +1 -0
  45. package/dist/car/car-string.d.ts +846 -0
  46. package/dist/car/car-string.d.ts.map +1 -0
  47. package/dist/car/car-string.js +734 -0
  48. package/dist/car/car-string.js.map +1 -0
  49. package/dist/{aci → car}/domains.d.ts +3 -3
  50. package/dist/{aci → car}/domains.d.ts.map +1 -1
  51. package/dist/{aci → car}/domains.js +57 -39
  52. package/dist/car/domains.js.map +1 -0
  53. package/dist/{aci → car}/effective-permission.d.ts +8 -8
  54. package/dist/{aci → car}/effective-permission.d.ts.map +1 -1
  55. package/dist/{aci → car}/effective-permission.js +59 -46
  56. package/dist/car/effective-permission.js.map +1 -0
  57. package/dist/{aci → car}/identity.d.ts +235 -129
  58. package/dist/car/identity.d.ts.map +1 -0
  59. package/dist/{aci → car}/identity.js +125 -105
  60. package/dist/car/identity.js.map +1 -0
  61. package/dist/car/index.d.ts +104 -0
  62. package/dist/car/index.d.ts.map +1 -0
  63. package/dist/car/index.js +401 -0
  64. package/dist/car/index.js.map +1 -0
  65. package/dist/car/jwt-claims.d.ts +1364 -0
  66. package/dist/car/jwt-claims.d.ts.map +1 -0
  67. package/dist/car/jwt-claims.js +388 -0
  68. package/dist/car/jwt-claims.js.map +1 -0
  69. package/dist/{aci → car}/levels.d.ts +5 -5
  70. package/dist/{aci → car}/levels.d.ts.map +1 -1
  71. package/dist/{aci → car}/levels.js +81 -62
  72. package/dist/car/levels.js.map +1 -0
  73. package/dist/{aci → car}/mapping.d.ts +5 -5
  74. package/dist/{aci → car}/mapping.d.ts.map +1 -1
  75. package/dist/{aci → car}/mapping.js +96 -76
  76. package/dist/car/mapping.js.map +1 -0
  77. package/dist/{aci → car}/skills.d.ts +4 -4
  78. package/dist/{aci → car}/skills.d.ts.map +1 -1
  79. package/dist/{aci → car}/skills.js +72 -50
  80. package/dist/car/skills.js.map +1 -0
  81. package/dist/{aci → car}/tiers.d.ts +3 -3
  82. package/dist/{aci → car}/tiers.d.ts.map +1 -1
  83. package/dist/{aci → car}/tiers.js +140 -113
  84. package/dist/car/tiers.js.map +1 -0
  85. package/dist/common/index.d.ts +1 -0
  86. package/dist/common/index.d.ts.map +1 -1
  87. package/dist/common/index.js +18 -1
  88. package/dist/common/index.js.map +1 -1
  89. package/dist/common/primitives.d.ts +9 -7
  90. package/dist/common/primitives.d.ts.map +1 -1
  91. package/dist/common/primitives.js +30 -25
  92. package/dist/common/primitives.js.map +1 -1
  93. package/dist/common/types.d.ts +328 -0
  94. package/dist/common/types.d.ts.map +1 -0
  95. package/dist/common/types.js +61 -0
  96. package/dist/common/types.js.map +1 -0
  97. package/dist/db/agents.d.ts +1914 -0
  98. package/dist/db/agents.d.ts.map +1 -0
  99. package/dist/db/agents.js +283 -0
  100. package/dist/db/agents.js.map +1 -0
  101. package/dist/db/api-keys.d.ts +506 -0
  102. package/dist/db/api-keys.d.ts.map +1 -0
  103. package/dist/db/api-keys.js +101 -0
  104. package/dist/db/api-keys.js.map +1 -0
  105. package/dist/db/escalations.d.ts +554 -0
  106. package/dist/db/escalations.d.ts.map +1 -0
  107. package/dist/db/escalations.js +100 -0
  108. package/dist/db/escalations.js.map +1 -0
  109. package/dist/db/index.d.ts +20 -0
  110. package/dist/db/index.d.ts.map +1 -0
  111. package/dist/db/index.js +47 -0
  112. package/dist/db/index.js.map +1 -0
  113. package/dist/db/intents.d.ts +535 -0
  114. package/dist/db/intents.d.ts.map +1 -0
  115. package/dist/db/intents.js +93 -0
  116. package/dist/db/intents.js.map +1 -0
  117. package/dist/db/merkle.d.ts +475 -0
  118. package/dist/db/merkle.d.ts.map +1 -0
  119. package/dist/db/merkle.js +103 -0
  120. package/dist/db/merkle.js.map +1 -0
  121. package/dist/db/operations.d.ts +256 -0
  122. package/dist/db/operations.d.ts.map +1 -0
  123. package/dist/db/operations.js +68 -0
  124. package/dist/db/operations.js.map +1 -0
  125. package/dist/db/policy-versions.d.ts +149 -0
  126. package/dist/db/policy-versions.d.ts.map +1 -0
  127. package/dist/db/policy-versions.js +44 -0
  128. package/dist/db/policy-versions.js.map +1 -0
  129. package/dist/db/proofs.d.ts +412 -0
  130. package/dist/db/proofs.d.ts.map +1 -0
  131. package/dist/db/proofs.js +66 -0
  132. package/dist/db/proofs.js.map +1 -0
  133. package/dist/db/rbac.d.ts +882 -0
  134. package/dist/db/rbac.d.ts.map +1 -0
  135. package/dist/db/rbac.js +189 -0
  136. package/dist/db/rbac.js.map +1 -0
  137. package/dist/db/service-accounts.d.ts +783 -0
  138. package/dist/db/service-accounts.d.ts.map +1 -0
  139. package/dist/db/service-accounts.js +179 -0
  140. package/dist/db/service-accounts.js.map +1 -0
  141. package/dist/db/trust.d.ts +603 -0
  142. package/dist/db/trust.d.ts.map +1 -0
  143. package/dist/db/trust.js +111 -0
  144. package/dist/db/trust.js.map +1 -0
  145. package/dist/db/webhooks.d.ts +382 -0
  146. package/dist/db/webhooks.d.ts.map +1 -0
  147. package/dist/db/webhooks.js +94 -0
  148. package/dist/db/webhooks.js.map +1 -0
  149. package/dist/flags.d.ts +214 -0
  150. package/dist/flags.d.ts.map +1 -0
  151. package/dist/flags.js +443 -0
  152. package/dist/flags.js.map +1 -0
  153. package/dist/index.d.ts +3 -1
  154. package/dist/index.d.ts.map +1 -1
  155. package/dist/index.js +47 -4
  156. package/dist/index.js.map +1 -1
  157. package/dist/v2/canary-probe.js +10 -7
  158. package/dist/v2/canary-probe.js.map +1 -1
  159. package/dist/v2/component.js +2 -1
  160. package/dist/v2/component.js.map +1 -1
  161. package/dist/v2/decision.js +5 -2
  162. package/dist/v2/decision.js.map +1 -1
  163. package/dist/v2/enums.js +28 -25
  164. package/dist/v2/enums.js.map +1 -1
  165. package/dist/v2/evidence.js +75 -72
  166. package/dist/v2/evidence.js.map +1 -1
  167. package/dist/v2/execution.js +2 -1
  168. package/dist/v2/execution.js.map +1 -1
  169. package/dist/v2/index.js +29 -13
  170. package/dist/v2/index.js.map +1 -1
  171. package/dist/v2/intent.js +2 -1
  172. package/dist/v2/intent.js.map +1 -1
  173. package/dist/v2/policy-bundle.js +5 -2
  174. package/dist/v2/policy-bundle.js.map +1 -1
  175. package/dist/v2/pre-action-gate.js +10 -7
  176. package/dist/v2/pre-action-gate.js.map +1 -1
  177. package/dist/v2/proof-event.d.ts +3 -1
  178. package/dist/v2/proof-event.d.ts.map +1 -1
  179. package/dist/v2/proof-event.js +2 -1
  180. package/dist/v2/proof-event.js.map +1 -1
  181. package/dist/v2/retention.js +104 -101
  182. package/dist/v2/retention.js.map +1 -1
  183. package/dist/v2/trust-delta.js +5 -2
  184. package/dist/v2/trust-delta.js.map +1 -1
  185. package/dist/v2/trust-profile.js +12 -9
  186. package/dist/v2/trust-profile.js.map +1 -1
  187. package/dist/validators/decision.d.ts +2 -2
  188. package/dist/validators/decision.js +49 -46
  189. package/dist/validators/decision.js.map +1 -1
  190. package/dist/validators/enums.js +14 -11
  191. package/dist/validators/enums.js.map +1 -1
  192. package/dist/validators/index.js +30 -9
  193. package/dist/validators/index.js.map +1 -1
  194. package/dist/validators/intent.js +40 -37
  195. package/dist/validators/intent.js.map +1 -1
  196. package/dist/validators/proof-event.d.ts +3 -0
  197. package/dist/validators/proof-event.d.ts.map +1 -1
  198. package/dist/validators/proof-event.js +103 -99
  199. package/dist/validators/proof-event.js.map +1 -1
  200. package/dist/validators/trust-profile.js +40 -37
  201. package/dist/validators/trust-profile.js.map +1 -1
  202. package/package.json +81 -15
  203. package/dist/aci/aci-string.d.ts +0 -539
  204. package/dist/aci/aci-string.d.ts.map +0 -1
  205. package/dist/aci/aci-string.js +0 -563
  206. package/dist/aci/aci-string.js.map +0 -1
  207. package/dist/aci/attestation.js.map +0 -1
  208. package/dist/aci/domains.js.map +0 -1
  209. package/dist/aci/effective-permission.js.map +0 -1
  210. package/dist/aci/identity.d.ts.map +0 -1
  211. package/dist/aci/identity.js.map +0 -1
  212. package/dist/aci/jwt-claims.d.ts +0 -756
  213. package/dist/aci/jwt-claims.d.ts.map +0 -1
  214. package/dist/aci/jwt-claims.js +0 -335
  215. package/dist/aci/jwt-claims.js.map +0 -1
  216. package/dist/aci/levels.js.map +0 -1
  217. package/dist/aci/mapping.js.map +0 -1
  218. package/dist/aci/skills.js.map +0 -1
  219. package/dist/aci/tiers.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service-accounts.d.ts","sourceRoot":"","sources":["../../src/db/service-accounts.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,179 @@
1
+ "use strict";
2
+ /**
3
+ * Service Accounts Schema
4
+ *
5
+ * Database schema for service-to-service authentication accounts
6
+ * using Drizzle ORM.
7
+ *
8
+ * @packageDocumentation
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ exports.serviceTokens = exports.serviceAccountAuditLog = exports.serviceAccountAuditEventEnum = exports.serviceAccounts = exports.serviceAccountStatusEnum = void 0;
12
+ const pg_core_1 = require("drizzle-orm/pg-core");
13
+ // =============================================================================
14
+ // ENUMS
15
+ // =============================================================================
16
+ /**
17
+ * Service account status enum
18
+ */
19
+ exports.serviceAccountStatusEnum = (0, pg_core_1.pgEnum)('service_account_status', [
20
+ 'active',
21
+ 'revoked',
22
+ 'suspended',
23
+ ]);
24
+ // =============================================================================
25
+ // SERVICE ACCOUNTS TABLE
26
+ // =============================================================================
27
+ /**
28
+ * Service accounts table - stores service account credentials and metadata
29
+ */
30
+ exports.serviceAccounts = (0, pg_core_1.pgTable)('service_accounts', {
31
+ // Primary key
32
+ id: (0, pg_core_1.uuid)('id').primaryKey().defaultRandom(),
33
+ // Unique client identifier (e.g., svc_abc123...)
34
+ clientId: (0, pg_core_1.text)('client_id').notNull().unique(),
35
+ // Hashed client secret (SHA-256)
36
+ clientSecret: (0, pg_core_1.text)('client_secret').notNull(),
37
+ // Human-readable name
38
+ name: (0, pg_core_1.text)('name').notNull(),
39
+ // Description of the service
40
+ description: (0, pg_core_1.text)('description'),
41
+ // Tenant ownership
42
+ tenantId: (0, pg_core_1.uuid)('tenant_id').notNull(),
43
+ // Permissions granted to this service
44
+ permissions: (0, pg_core_1.jsonb)('permissions').$type().notNull().default([]),
45
+ // Optional IP whitelist for additional security
46
+ ipWhitelist: (0, pg_core_1.jsonb)('ip_whitelist').$type(),
47
+ // Status
48
+ status: (0, exports.serviceAccountStatusEnum)('status').notNull().default('active'),
49
+ // Timestamps
50
+ createdAt: (0, pg_core_1.timestamp)('created_at', { withTimezone: true }).notNull().defaultNow(),
51
+ lastUsedAt: (0, pg_core_1.timestamp)('last_used_at', { withTimezone: true }),
52
+ secretRotatedAt: (0, pg_core_1.timestamp)('secret_rotated_at', { withTimezone: true }),
53
+ // User who created the account
54
+ createdBy: (0, pg_core_1.text)('created_by'),
55
+ // Additional metadata
56
+ metadata: (0, pg_core_1.jsonb)('metadata').$type().default({}),
57
+ }, (table) => ({
58
+ // Unique constraint on client ID for fast lookup
59
+ clientIdUniqueIdx: (0, pg_core_1.uniqueIndex)('service_accounts_client_id_unique_idx').on(table.clientId),
60
+ // Index by tenant for listing
61
+ tenantIdIdx: (0, pg_core_1.index)('service_accounts_tenant_id_idx').on(table.tenantId),
62
+ // Composite index for listing with status filter
63
+ tenantStatusIdx: (0, pg_core_1.index)('service_accounts_tenant_status_idx').on(table.tenantId, table.status),
64
+ // Index for status-based queries
65
+ statusIdx: (0, pg_core_1.index)('service_accounts_status_idx').on(table.status),
66
+ // Index for finding accounts by name within tenant
67
+ tenantNameIdx: (0, pg_core_1.index)('service_accounts_tenant_name_idx').on(table.tenantId, table.name),
68
+ // Index for audit: recently used accounts
69
+ lastUsedAtIdx: (0, pg_core_1.index)('service_accounts_last_used_at_idx').on(table.lastUsedAt),
70
+ }));
71
+ // =============================================================================
72
+ // SERVICE ACCOUNT AUDIT LOG TABLE
73
+ // =============================================================================
74
+ /**
75
+ * Service account audit event types
76
+ */
77
+ exports.serviceAccountAuditEventEnum = (0, pg_core_1.pgEnum)('service_account_audit_event', [
78
+ 'created',
79
+ 'updated',
80
+ 'revoked',
81
+ 'suspended',
82
+ 'reactivated',
83
+ 'deleted',
84
+ 'secret_rotated',
85
+ 'auth_success',
86
+ 'auth_failure',
87
+ 'permission_denied',
88
+ 'ip_blocked',
89
+ ]);
90
+ /**
91
+ * Service account audit log table - tracks all changes to service accounts
92
+ */
93
+ exports.serviceAccountAuditLog = (0, pg_core_1.pgTable)('service_account_audit_log', {
94
+ // Primary key
95
+ id: (0, pg_core_1.uuid)('id').primaryKey().defaultRandom(),
96
+ // Reference to service account
97
+ serviceAccountId: (0, pg_core_1.uuid)('service_account_id').notNull(),
98
+ // Client ID (stored separately for audit even if account deleted)
99
+ clientId: (0, pg_core_1.text)('client_id').notNull(),
100
+ // Tenant ID (stored separately for audit)
101
+ tenantId: (0, pg_core_1.uuid)('tenant_id').notNull(),
102
+ // Event type
103
+ event: (0, exports.serviceAccountAuditEventEnum)('event').notNull(),
104
+ // Actor who performed the action (user ID or system)
105
+ actorId: (0, pg_core_1.text)('actor_id'),
106
+ actorType: (0, pg_core_1.text)('actor_type').notNull().default('user'), // 'user', 'system', 'service'
107
+ // Request context
108
+ ipAddress: (0, pg_core_1.text)('ip_address'),
109
+ userAgent: (0, pg_core_1.text)('user_agent'),
110
+ requestId: (0, pg_core_1.text)('request_id'),
111
+ // Event details
112
+ details: (0, pg_core_1.jsonb)('details').$type().default({}),
113
+ // Previous state (for updates)
114
+ previousState: (0, pg_core_1.jsonb)('previous_state').$type(),
115
+ // New state (for updates)
116
+ newState: (0, pg_core_1.jsonb)('new_state').$type(),
117
+ // Timestamp
118
+ timestamp: (0, pg_core_1.timestamp)('timestamp', { withTimezone: true }).notNull().defaultNow(),
119
+ }, (table) => ({
120
+ // Index for looking up audit by service account
121
+ serviceAccountIdIdx: (0, pg_core_1.index)('service_account_audit_service_account_id_idx').on(table.serviceAccountId),
122
+ // Index for looking up audit by client ID (even after deletion)
123
+ clientIdIdx: (0, pg_core_1.index)('service_account_audit_client_id_idx').on(table.clientId),
124
+ // Index for tenant-wide audit queries
125
+ tenantIdIdx: (0, pg_core_1.index)('service_account_audit_tenant_id_idx').on(table.tenantId),
126
+ // Index for filtering by event type
127
+ eventIdx: (0, pg_core_1.index)('service_account_audit_event_idx').on(table.event),
128
+ // Index for time-based queries
129
+ timestampIdx: (0, pg_core_1.index)('service_account_audit_timestamp_idx').on(table.timestamp),
130
+ // Composite for tenant + time range queries
131
+ tenantTimestampIdx: (0, pg_core_1.index)('service_account_audit_tenant_timestamp_idx').on(table.tenantId, table.timestamp),
132
+ // Composite for service account + event queries
133
+ serviceAccountEventIdx: (0, pg_core_1.index)('service_account_audit_sa_event_idx').on(table.serviceAccountId, table.event),
134
+ }));
135
+ // =============================================================================
136
+ // SERVICE TOKENS TABLE (Optional - for token tracking/revocation)
137
+ // =============================================================================
138
+ /**
139
+ * Service tokens table - tracks issued service tokens for revocation support
140
+ * Optional: Only needed if you want to track and revoke individual tokens
141
+ */
142
+ exports.serviceTokens = (0, pg_core_1.pgTable)('service_tokens', {
143
+ // Primary key - the JWT ID (jti)
144
+ id: (0, pg_core_1.uuid)('id').primaryKey().defaultRandom(),
145
+ // JWT ID for lookup
146
+ jti: (0, pg_core_1.text)('jti').notNull().unique(),
147
+ // Reference to service account
148
+ serviceAccountId: (0, pg_core_1.uuid)('service_account_id')
149
+ .notNull()
150
+ .references(() => exports.serviceAccounts.id, { onDelete: 'cascade' }),
151
+ // Client ID (for queries after account deletion)
152
+ clientId: (0, pg_core_1.text)('client_id').notNull(),
153
+ // Tenant ID
154
+ tenantId: (0, pg_core_1.uuid)('tenant_id').notNull(),
155
+ // Token metadata
156
+ issuedAt: (0, pg_core_1.timestamp)('issued_at', { withTimezone: true }).notNull(),
157
+ expiresAt: (0, pg_core_1.timestamp)('expires_at', { withTimezone: true }).notNull(),
158
+ // Revocation status
159
+ revokedAt: (0, pg_core_1.timestamp)('revoked_at', { withTimezone: true }),
160
+ revokedBy: (0, pg_core_1.text)('revoked_by'),
161
+ revokedReason: (0, pg_core_1.text)('revoked_reason'),
162
+ // Request context at issuance
163
+ issuedIp: (0, pg_core_1.text)('issued_ip'),
164
+ issuedUserAgent: (0, pg_core_1.text)('issued_user_agent'),
165
+ }, (table) => ({
166
+ // Unique index on JTI for fast lookup
167
+ jtiUniqueIdx: (0, pg_core_1.uniqueIndex)('service_tokens_jti_unique_idx').on(table.jti),
168
+ // Index for service account token queries
169
+ serviceAccountIdIdx: (0, pg_core_1.index)('service_tokens_service_account_id_idx').on(table.serviceAccountId),
170
+ // Index for tenant queries
171
+ tenantIdIdx: (0, pg_core_1.index)('service_tokens_tenant_id_idx').on(table.tenantId),
172
+ // Index for expiration cleanup
173
+ expiresAtIdx: (0, pg_core_1.index)('service_tokens_expires_at_idx').on(table.expiresAt),
174
+ // Index for revocation queries
175
+ revokedAtIdx: (0, pg_core_1.index)('service_tokens_revoked_at_idx').on(table.revokedAt),
176
+ // Composite for finding active tokens
177
+ activeTokensIdx: (0, pg_core_1.index)('service_tokens_active_idx').on(table.serviceAccountId, table.expiresAt, table.revokedAt),
178
+ }));
179
+ //# sourceMappingURL=service-accounts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service-accounts.js","sourceRoot":"","sources":["../../src/db/service-accounts.ts"],"names":[],"mappings":";AAAA;;;;;;;GAOG;;;AAEH,iDAS6B;AAE7B,gFAAgF;AAChF,QAAQ;AACR,gFAAgF;AAEhF;;GAEG;AACU,QAAA,wBAAwB,GAAG,IAAA,gBAAM,EAAC,wBAAwB,EAAE;IACvE,QAAQ;IACR,SAAS;IACT,WAAW;CACZ,CAAC,CAAC;AAEH,gFAAgF;AAChF,yBAAyB;AACzB,gFAAgF;AAEhF;;GAEG;AACU,QAAA,eAAe,GAAG,IAAA,iBAAO,EACpC,kBAAkB,EAClB;IACE,cAAc;IACd,EAAE,EAAE,IAAA,cAAI,EAAC,IAAI,CAAC,CAAC,UAAU,EAAE,CAAC,aAAa,EAAE;IAE3C,iDAAiD;IACjD,QAAQ,EAAE,IAAA,cAAI,EAAC,WAAW,CAAC,CAAC,OAAO,EAAE,CAAC,MAAM,EAAE;IAE9C,iCAAiC;IACjC,YAAY,EAAE,IAAA,cAAI,EAAC,eAAe,CAAC,CAAC,OAAO,EAAE;IAE7C,sBAAsB;IACtB,IAAI,EAAE,IAAA,cAAI,EAAC,MAAM,CAAC,CAAC,OAAO,EAAE;IAE5B,6BAA6B;IAC7B,WAAW,EAAE,IAAA,cAAI,EAAC,aAAa,CAAC;IAEhC,mBAAmB;IACnB,QAAQ,EAAE,IAAA,cAAI,EAAC,WAAW,CAAC,CAAC,OAAO,EAAE;IAErC,sCAAsC;IACtC,WAAW,EAAE,IAAA,eAAK,EAAC,aAAa,CAAC,CAAC,KAAK,EAAY,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;IAEzE,gDAAgD;IAChD,WAAW,EAAE,IAAA,eAAK,EAAC,cAAc,CAAC,CAAC,KAAK,EAAY;IAEpD,SAAS;IACT,MAAM,EAAE,IAAA,gCAAwB,EAAC,QAAQ,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC;IAEtE,aAAa;IACb,SAAS,EAAE,IAAA,mBAAS,EAAC,YAAY,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,UAAU,EAAE;IACjF,UAAU,EAAE,IAAA,mBAAS,EAAC,cAAc,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC;IAC7D,eAAe,EAAE,IAAA,mBAAS,EAAC,mBAAmB,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC;IAEvE,+BAA+B;IAC/B,SAAS,EAAE,IAAA,cAAI,EAAC,YAAY,CAAC;IAE7B,sBAAsB;IACtB,QAAQ,EAAE,IAAA,eAAK,EAAC,UAAU,CAAC,CAAC,KAAK,EAA2B,CAAC,OAAO,CAAC,EAAE,CAAC;CACzE,EACD,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IACV,iDAAiD;IACjD,iBAAiB,EAAE,IAAA,qBAAW,EAAC,uCAAuC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC;IAE1F,8BAA8B;IAC9B,WAAW,EAAE,IAAA,eAAK,EAAC,gCAAgC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC;IAEvE,iDAAiD;IACjD,eAAe,EAAE,IAAA,eAAK,EAAC,oCAAoC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC;IAE7F,iCAAiC;IACjC,SAAS,EAAE,IAAA,eAAK,EAAC,6BAA6B,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC;IAEhE,mDAAmD;IACnD,aAAa,EAAE,IAAA,eAAK,EAAC,kCAAkC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC;IAEvF,0CAA0C;IAC1C,aAAa,EAAE,IAAA,eAAK,EAAC,mCAAmC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC;CAC/E,CAAC,CACH,CAAC;AAEF,gFAAgF;AAChF,kCAAkC;AAClC,gFAAgF;AAEhF;;GAEG;AACU,QAAA,4BAA4B,GAAG,IAAA,gBAAM,EAAC,6BAA6B,EAAE;IAChF,SAAS;IACT,SAAS;IACT,SAAS;IACT,WAAW;IACX,aAAa;IACb,SAAS;IACT,gBAAgB;IAChB,cAAc;IACd,cAAc;IACd,mBAAmB;IACnB,YAAY;CACb,CAAC,CAAC;AAEH;;GAEG;AACU,QAAA,sBAAsB,GAAG,IAAA,iBAAO,EAC3C,2BAA2B,EAC3B;IACE,cAAc;IACd,EAAE,EAAE,IAAA,cAAI,EAAC,IAAI,CAAC,CAAC,UAAU,EAAE,CAAC,aAAa,EAAE;IAE3C,+BAA+B;IAC/B,gBAAgB,EAAE,IAAA,cAAI,EAAC,oBAAoB,CAAC,CAAC,OAAO,EAAE;IAEtD,kEAAkE;IAClE,QAAQ,EAAE,IAAA,cAAI,EAAC,WAAW,CAAC,CAAC,OAAO,EAAE;IAErC,0CAA0C;IAC1C,QAAQ,EAAE,IAAA,cAAI,EAAC,WAAW,CAAC,CAAC,OAAO,EAAE;IAErC,aAAa;IACb,KAAK,EAAE,IAAA,oCAA4B,EAAC,OAAO,CAAC,CAAC,OAAO,EAAE;IAEtD,qDAAqD;IACrD,OAAO,EAAE,IAAA,cAAI,EAAC,UAAU,CAAC;IACzB,SAAS,EAAE,IAAA,cAAI,EAAC,YAAY,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,8BAA8B;IAEvF,kBAAkB;IAClB,SAAS,EAAE,IAAA,cAAI,EAAC,YAAY,CAAC;IAC7B,SAAS,EAAE,IAAA,cAAI,EAAC,YAAY,CAAC;IAC7B,SAAS,EAAE,IAAA,cAAI,EAAC,YAAY,CAAC;IAE7B,gBAAgB;IAChB,OAAO,EAAE,IAAA,eAAK,EAAC,SAAS,CAAC,CAAC,KAAK,EAA2B,CAAC,OAAO,CAAC,EAAE,CAAC;IAEtE,+BAA+B;IAC/B,aAAa,EAAE,IAAA,eAAK,EAAC,gBAAgB,CAAC,CAAC,KAAK,EAA2B;IAEvE,0BAA0B;IAC1B,QAAQ,EAAE,IAAA,eAAK,EAAC,WAAW,CAAC,CAAC,KAAK,EAA2B;IAE7D,YAAY;IACZ,SAAS,EAAE,IAAA,mBAAS,EAAC,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,UAAU,EAAE;CACjF,EACD,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IACV,gDAAgD;IAChD,mBAAmB,EAAE,IAAA,eAAK,EAAC,8CAA8C,CAAC,CAAC,EAAE,CAC3E,KAAK,CAAC,gBAAgB,CACvB;IAED,gEAAgE;IAChE,WAAW,EAAE,IAAA,eAAK,EAAC,qCAAqC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC;IAE5E,sCAAsC;IACtC,WAAW,EAAE,IAAA,eAAK,EAAC,qCAAqC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC;IAE5E,oCAAoC;IACpC,QAAQ,EAAE,IAAA,eAAK,EAAC,iCAAiC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC;IAElE,+BAA+B;IAC/B,YAAY,EAAE,IAAA,eAAK,EAAC,qCAAqC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC;IAE9E,4CAA4C;IAC5C,kBAAkB,EAAE,IAAA,eAAK,EAAC,4CAA4C,CAAC,CAAC,EAAE,CACxE,KAAK,CAAC,QAAQ,EACd,KAAK,CAAC,SAAS,CAChB;IAED,gDAAgD;IAChD,sBAAsB,EAAE,IAAA,eAAK,EAAC,oCAAoC,CAAC,CAAC,EAAE,CACpE,KAAK,CAAC,gBAAgB,EACtB,KAAK,CAAC,KAAK,CACZ;CACF,CAAC,CACH,CAAC;AAEF,gFAAgF;AAChF,kEAAkE;AAClE,gFAAgF;AAEhF;;;GAGG;AACU,QAAA,aAAa,GAAG,IAAA,iBAAO,EAClC,gBAAgB,EAChB;IACE,iCAAiC;IACjC,EAAE,EAAE,IAAA,cAAI,EAAC,IAAI,CAAC,CAAC,UAAU,EAAE,CAAC,aAAa,EAAE;IAE3C,oBAAoB;IACpB,GAAG,EAAE,IAAA,cAAI,EAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC,MAAM,EAAE;IAEnC,+BAA+B;IAC/B,gBAAgB,EAAE,IAAA,cAAI,EAAC,oBAAoB,CAAC;SACzC,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAe,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAEhE,iDAAiD;IACjD,QAAQ,EAAE,IAAA,cAAI,EAAC,WAAW,CAAC,CAAC,OAAO,EAAE;IAErC,YAAY;IACZ,QAAQ,EAAE,IAAA,cAAI,EAAC,WAAW,CAAC,CAAC,OAAO,EAAE;IAErC,iBAAiB;IACjB,QAAQ,EAAE,IAAA,mBAAS,EAAC,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE;IAClE,SAAS,EAAE,IAAA,mBAAS,EAAC,YAAY,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE;IAEpE,oBAAoB;IACpB,SAAS,EAAE,IAAA,mBAAS,EAAC,YAAY,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC;IAC1D,SAAS,EAAE,IAAA,cAAI,EAAC,YAAY,CAAC;IAC7B,aAAa,EAAE,IAAA,cAAI,EAAC,gBAAgB,CAAC;IAErC,8BAA8B;IAC9B,QAAQ,EAAE,IAAA,cAAI,EAAC,WAAW,CAAC;IAC3B,eAAe,EAAE,IAAA,cAAI,EAAC,mBAAmB,CAAC;CAC3C,EACD,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IACV,sCAAsC;IACtC,YAAY,EAAE,IAAA,qBAAW,EAAC,+BAA+B,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC;IAExE,0CAA0C;IAC1C,mBAAmB,EAAE,IAAA,eAAK,EAAC,uCAAuC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,gBAAgB,CAAC;IAE9F,2BAA2B;IAC3B,WAAW,EAAE,IAAA,eAAK,EAAC,8BAA8B,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC;IAErE,+BAA+B;IAC/B,YAAY,EAAE,IAAA,eAAK,EAAC,+BAA+B,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC;IAExE,+BAA+B;IAC/B,YAAY,EAAE,IAAA,eAAK,EAAC,+BAA+B,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC;IAExE,sCAAsC;IACtC,eAAe,EAAE,IAAA,eAAK,EAAC,2BAA2B,CAAC,CAAC,EAAE,CACpD,KAAK,CAAC,gBAAgB,EACtB,KAAK,CAAC,SAAS,EACf,KAAK,CAAC,SAAS,CAChB;CACF,CAAC,CACH,CAAC"}