@vivantel/virage-core 0.2.19 → 0.2.22

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 (59) hide show
  1. package/dist/config-loader.d.ts.map +1 -1
  2. package/dist/config-loader.js +1 -0
  3. package/dist/config-loader.js.map +1 -1
  4. package/dist/core/embedder.d.ts +4 -4
  5. package/dist/core/embedder.d.ts.map +1 -1
  6. package/dist/core/embedder.js.map +1 -1
  7. package/dist/core/orchestrator.d.ts +2 -0
  8. package/dist/core/orchestrator.d.ts.map +1 -1
  9. package/dist/core/orchestrator.js +5 -7
  10. package/dist/core/orchestrator.js.map +1 -1
  11. package/dist/core/telemetry.d.ts +4 -3
  12. package/dist/core/telemetry.d.ts.map +1 -1
  13. package/dist/core/telemetry.js +3 -6
  14. package/dist/core/telemetry.js.map +1 -1
  15. package/dist/core/uploader.d.ts +6 -6
  16. package/dist/core/uploader.d.ts.map +1 -1
  17. package/dist/core/uploader.js.map +1 -1
  18. package/dist/core/{embeddings-db.d.ts → virage-db.d.ts} +34 -2
  19. package/dist/core/virage-db.d.ts.map +1 -0
  20. package/dist/core/virage-db.js +722 -0
  21. package/dist/core/virage-db.js.map +1 -0
  22. package/dist/core/virage-defaults.d.ts +1 -1
  23. package/dist/core/virage-defaults.d.ts.map +1 -1
  24. package/dist/core/virage-defaults.js +2 -2
  25. package/dist/core/virage-defaults.js.map +1 -1
  26. package/dist/eval/experiment-store.d.ts +4 -3
  27. package/dist/eval/experiment-store.d.ts.map +1 -1
  28. package/dist/eval/experiment-store.js +14 -54
  29. package/dist/eval/experiment-store.js.map +1 -1
  30. package/dist/index.d.ts +5 -2
  31. package/dist/index.d.ts.map +1 -1
  32. package/dist/index.js +3 -2
  33. package/dist/index.js.map +1 -1
  34. package/dist/interfaces/embedder.d.ts +1 -1
  35. package/dist/interfaces/embedder.d.ts.map +1 -1
  36. package/dist/telemetry/flusher.d.ts +58 -0
  37. package/dist/telemetry/flusher.d.ts.map +1 -0
  38. package/dist/telemetry/flusher.js +173 -0
  39. package/dist/telemetry/flusher.js.map +1 -0
  40. package/dist/telemetry/index.d.ts +7 -0
  41. package/dist/telemetry/index.d.ts.map +1 -0
  42. package/dist/telemetry/index.js +5 -0
  43. package/dist/telemetry/index.js.map +1 -0
  44. package/dist/telemetry/manager.d.ts +13 -0
  45. package/dist/telemetry/manager.d.ts.map +1 -0
  46. package/dist/telemetry/manager.js +36 -0
  47. package/dist/telemetry/manager.js.map +1 -0
  48. package/dist/telemetry/session.d.ts +30 -0
  49. package/dist/telemetry/session.d.ts.map +1 -0
  50. package/dist/telemetry/session.js +158 -0
  51. package/dist/telemetry/session.js.map +1 -0
  52. package/dist/telemetry/types.d.ts +97 -0
  53. package/dist/telemetry/types.d.ts.map +1 -0
  54. package/dist/telemetry/types.js +46 -0
  55. package/dist/telemetry/types.js.map +1 -0
  56. package/package.json +6 -5
  57. package/dist/core/embeddings-db.d.ts.map +0 -1
  58. package/dist/core/embeddings-db.js +0 -327
  59. package/dist/core/embeddings-db.js.map +0 -1
@@ -0,0 +1,30 @@
1
+ import type { VirageDb } from "../core/virage-db.js";
2
+ import { type TelemetryConfig, type SessionMetadata } from "./types.js";
3
+ export interface FeedbackPayload {
4
+ wasUseful: boolean;
5
+ contextRelevance?: number;
6
+ contextCompleteness?: number;
7
+ noiseRatio?: number;
8
+ missingCategory?: string;
9
+ }
10
+ export declare class TelemetrySession {
11
+ private readonly db;
12
+ private readonly config;
13
+ readonly id: string;
14
+ private searchCount;
15
+ private feedbackCallCount;
16
+ private recentEmbeddings;
17
+ private static readonly REDUNDANCY_WINDOW_MS;
18
+ private static readonly REDUNDANCY_THRESHOLD;
19
+ private static readonly MAX_FEEDBACK_CALLS;
20
+ constructor(db: VirageDb, config: TelemetryConfig, sessionId: string, metadata: SessionMetadata);
21
+ recordSearch(searchId: string, resultCount: number, queryEmbedding: number[]): void;
22
+ recordLatency(phase: string, durationMs: number): void;
23
+ recordError(errorType: string, retryCount: number, recovered: boolean): void;
24
+ recordFeedback(searchId: string, payload: FeedbackPayload): void;
25
+ recordCacheStats(fileHitRate: number, semanticHitRate: number): void;
26
+ shouldSampleFeedback(resultCount: number): boolean;
27
+ end(): void;
28
+ private isRedundant;
29
+ }
30
+ //# sourceMappingURL=session.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../src/telemetry/session.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,eAAe,EAGrB,MAAM,YAAY,CAAC;AAEpB,MAAM,WAAW,eAAe;IAC9B,SAAS,EAAE,OAAO,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAgBD,qBAAa,gBAAgB;IAazB,OAAO,CAAC,QAAQ,CAAC,EAAE;IACnB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAbzB,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IAEpB,OAAO,CAAC,WAAW,CAAK;IACxB,OAAO,CAAC,iBAAiB,CAAK;IAC9B,OAAO,CAAC,gBAAgB,CACnB;IAEL,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,oBAAoB,CAAiB;IAC7D,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,oBAAoB,CAAO;IACnD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,kBAAkB,CAAM;gBAG7B,EAAE,EAAE,QAAQ,EACZ,MAAM,EAAE,eAAe,EACxC,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,eAAe;IAoB3B,YAAY,CACV,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,cAAc,EAAE,MAAM,EAAE,GACvB,IAAI;IAsCP,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI;IAWtD,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,GAAG,IAAI;IAY5E,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,eAAe,GAAG,IAAI;IAkBhE,gBAAgB,CAAC,WAAW,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,GAAG,IAAI;IAWpE,oBAAoB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO;IAclD,GAAG,IAAI,IAAI;IAOX,OAAO,CAAC,WAAW;CAUpB"}
@@ -0,0 +1,158 @@
1
+ import { createHash } from "crypto";
2
+ import { resultCountBucket, normalizeMissingCategory, } from "./types.js";
3
+ function cosineSimilarity(a, b) {
4
+ let dot = 0;
5
+ let normA = 0;
6
+ let normB = 0;
7
+ const len = Math.min(a.length, b.length);
8
+ for (let i = 0; i < len; i++) {
9
+ dot += a[i] * b[i];
10
+ normA += a[i] * a[i];
11
+ normB += b[i] * b[i];
12
+ }
13
+ const denom = Math.sqrt(normA) * Math.sqrt(normB);
14
+ return denom === 0 ? 0 : dot / denom;
15
+ }
16
+ export class TelemetrySession {
17
+ db;
18
+ config;
19
+ id;
20
+ searchCount = 0;
21
+ feedbackCallCount = 0;
22
+ recentEmbeddings = [];
23
+ static REDUNDANCY_WINDOW_MS = 5 * 60 * 1000;
24
+ static REDUNDANCY_THRESHOLD = 0.8;
25
+ static MAX_FEEDBACK_CALLS = 20;
26
+ constructor(db, config, sessionId, metadata) {
27
+ this.db = db;
28
+ this.config = config;
29
+ this.id = sessionId;
30
+ if (config.enabled) {
31
+ db.insertTelemetrySession({
32
+ id: sessionId,
33
+ started_at: new Date().toISOString(),
34
+ embedding_model: metadata.embeddingModel,
35
+ chunking_strategy: metadata.chunkingStrategy,
36
+ store_type: metadata.storeType,
37
+ node_version: metadata.nodeVersion,
38
+ os: metadata.os,
39
+ total_searches: 0,
40
+ total_tool_calls: 0,
41
+ tools_used_json: "[]",
42
+ flushed: 0,
43
+ });
44
+ }
45
+ }
46
+ recordSearch(searchId, resultCount, queryEmbedding) {
47
+ if (!this.config.enabled || !this.config.tiers.implicit)
48
+ return;
49
+ const now = Date.now();
50
+ const redundant = this.isRedundant(queryEmbedding, now);
51
+ this.recentEmbeddings.push({ embedding: queryEmbedding, timestamp: now });
52
+ const cutoff = now - TelemetrySession.REDUNDANCY_WINDOW_MS;
53
+ this.recentEmbeddings = this.recentEmbeddings.filter((e) => e.timestamp >= cutoff);
54
+ const queryHash = resultCount === 0
55
+ ? createHash("sha256")
56
+ .update(Buffer.from(new Float32Array(queryEmbedding).buffer))
57
+ .digest("hex")
58
+ .slice(0, 16)
59
+ : undefined;
60
+ this.db.insertTelemetrySearch({
61
+ id: searchId,
62
+ session_id: this.id,
63
+ occurred_at: new Date(now).toISOString(),
64
+ result_count: resultCount,
65
+ result_count_bucket: resultCountBucket(resultCount),
66
+ empty: resultCount === 0 ? 1 : 0,
67
+ query_hash: queryHash,
68
+ redundancy_detected: redundant ? 1 : 0,
69
+ flushed: 0,
70
+ });
71
+ this.searchCount++;
72
+ this.db.updateTelemetrySession(this.id, {
73
+ total_searches: this.searchCount,
74
+ });
75
+ }
76
+ recordLatency(phase, durationMs) {
77
+ if (!this.config.enabled || !this.config.tiers.implicit)
78
+ return;
79
+ this.db.insertTelemetryLatency({
80
+ session_id: this.id,
81
+ occurred_at: new Date().toISOString(),
82
+ phase,
83
+ duration_ms: durationMs,
84
+ flushed: 0,
85
+ });
86
+ }
87
+ recordError(errorType, retryCount, recovered) {
88
+ if (!this.config.enabled || !this.config.tiers.implicit)
89
+ return;
90
+ this.db.insertTelemetryError({
91
+ session_id: this.id,
92
+ occurred_at: new Date().toISOString(),
93
+ error_type: errorType,
94
+ retry_count: retryCount,
95
+ recovered: recovered ? 1 : 0,
96
+ flushed: 0,
97
+ });
98
+ }
99
+ recordFeedback(searchId, payload) {
100
+ if (!this.config.enabled)
101
+ return;
102
+ if (!this.config.tiers.explicit_feedback.enabled)
103
+ return;
104
+ if (this.feedbackCallCount >= TelemetrySession.MAX_FEEDBACK_CALLS)
105
+ return;
106
+ this.feedbackCallCount++;
107
+ this.db.insertTelemetryFeedback({
108
+ session_id: this.id,
109
+ search_id: searchId,
110
+ occurred_at: new Date().toISOString(),
111
+ was_useful: payload.wasUseful ? 1 : 0,
112
+ context_relevance: payload.contextRelevance,
113
+ context_completeness: payload.contextCompleteness,
114
+ noise_ratio: payload.noiseRatio,
115
+ missing_category: normalizeMissingCategory(payload.missingCategory),
116
+ flushed: 0,
117
+ });
118
+ }
119
+ recordCacheStats(fileHitRate, semanticHitRate) {
120
+ if (!this.config.enabled || !this.config.tiers.implicit)
121
+ return;
122
+ this.db.insertTelemetryCacheStats({
123
+ session_id: this.id,
124
+ recorded_at: new Date().toISOString(),
125
+ file_hit_rate: fileHitRate,
126
+ semantic_hit_rate: semanticHitRate,
127
+ flushed: 0,
128
+ });
129
+ }
130
+ shouldSampleFeedback(resultCount) {
131
+ if (!this.config.enabled)
132
+ return false;
133
+ if (!this.config.tiers.explicit_feedback.enabled)
134
+ return false;
135
+ if (this.feedbackCallCount >= TelemetrySession.MAX_FEEDBACK_CALLS)
136
+ return false;
137
+ if (this.config.tiers.explicit_feedback.always_on_anomaly &&
138
+ (resultCount === 0 || resultCount > 10)) {
139
+ return true;
140
+ }
141
+ return Math.random() < this.config.tiers.explicit_feedback.sampling_rate;
142
+ }
143
+ end() {
144
+ if (!this.config.enabled)
145
+ return;
146
+ this.db.updateTelemetrySession(this.id, {
147
+ ended_at: new Date().toISOString(),
148
+ });
149
+ }
150
+ isRedundant(embedding, now) {
151
+ const cutoff = now - TelemetrySession.REDUNDANCY_WINDOW_MS;
152
+ return this.recentEmbeddings
153
+ .filter((e) => e.timestamp >= cutoff)
154
+ .some((e) => cosineSimilarity(e.embedding, embedding) >
155
+ TelemetrySession.REDUNDANCY_THRESHOLD);
156
+ }
157
+ }
158
+ //# sourceMappingURL=session.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.js","sourceRoot":"","sources":["../../src/telemetry/session.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,97 @@
1
+ export interface TelemetryConfig {
2
+ enabled: boolean;
3
+ endpoint?: string;
4
+ api_key?: string;
5
+ tiers: {
6
+ implicit: boolean;
7
+ explicit_feedback: {
8
+ enabled: boolean;
9
+ sampling_rate: number;
10
+ always_on_anomaly: boolean;
11
+ max_token_budget_percent: number;
12
+ };
13
+ };
14
+ privacy: {
15
+ query_hashing: boolean;
16
+ file_path_anonymization: boolean;
17
+ aggregation_window_minutes: number;
18
+ max_local_buffer_mb: number;
19
+ max_retry_hours: number;
20
+ };
21
+ }
22
+ export declare const DEFAULT_TELEMETRY_CONFIG: TelemetryConfig;
23
+ export interface SessionMetadata {
24
+ embeddingModel?: string;
25
+ chunkingStrategy?: string;
26
+ storeType?: string;
27
+ nodeVersion: string;
28
+ os: string;
29
+ }
30
+ export interface TelemetrySessionRow {
31
+ id: string;
32
+ started_at: string;
33
+ ended_at?: string;
34
+ embedding_model?: string;
35
+ chunking_strategy?: string;
36
+ store_type?: string;
37
+ node_version: string;
38
+ os: string;
39
+ total_searches: number;
40
+ total_tool_calls: number;
41
+ tools_used_json: string;
42
+ flushed: number;
43
+ }
44
+ export interface TelemetrySearchRow {
45
+ id: string;
46
+ session_id: string;
47
+ occurred_at: string;
48
+ result_count: number;
49
+ result_count_bucket: string;
50
+ empty: number;
51
+ query_hash?: string;
52
+ redundancy_detected: number;
53
+ flushed: number;
54
+ }
55
+ export interface TelemetryLatencyRow {
56
+ id?: number;
57
+ session_id: string;
58
+ occurred_at: string;
59
+ phase: string;
60
+ duration_ms: number;
61
+ flushed: number;
62
+ }
63
+ export interface TelemetryErrorRow {
64
+ id?: number;
65
+ session_id: string;
66
+ occurred_at: string;
67
+ error_type: string;
68
+ retry_count: number;
69
+ recovered: number;
70
+ flushed: number;
71
+ }
72
+ export interface TelemetryFeedbackRow {
73
+ id?: number;
74
+ session_id: string;
75
+ search_id: string;
76
+ occurred_at: string;
77
+ was_useful: number;
78
+ context_relevance?: number;
79
+ context_completeness?: number;
80
+ noise_ratio?: number;
81
+ missing_category?: string;
82
+ flushed: number;
83
+ }
84
+ export interface TelemetryCacheStatsRow {
85
+ id?: number;
86
+ session_id: string;
87
+ recorded_at: string;
88
+ file_hit_rate?: number;
89
+ semantic_hit_rate?: number;
90
+ flushed: number;
91
+ }
92
+ export type ResultCountBucket = "0" | "1-3" | "4-10" | "11-20" | "20+";
93
+ export declare function resultCountBucket(n: number): ResultCountBucket;
94
+ export declare const MISSING_CATEGORY_VALUES: readonly ["missing_error_handling", "missing_config_example", "missing_api_reference", "missing_type_signature", "missing_test_coverage", "other"];
95
+ export type MissingCategory = (typeof MISSING_CATEGORY_VALUES)[number];
96
+ export declare function normalizeMissingCategory(value: string | undefined): MissingCategory | undefined;
97
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/telemetry/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,46 @@
1
+ export const DEFAULT_TELEMETRY_CONFIG = {
2
+ enabled: true,
3
+ tiers: {
4
+ implicit: true,
5
+ explicit_feedback: {
6
+ enabled: false,
7
+ sampling_rate: 0.2,
8
+ always_on_anomaly: true,
9
+ max_token_budget_percent: 3,
10
+ },
11
+ },
12
+ privacy: {
13
+ query_hashing: true,
14
+ file_path_anonymization: true,
15
+ aggregation_window_minutes: 60,
16
+ max_local_buffer_mb: 10,
17
+ max_retry_hours: 48,
18
+ },
19
+ };
20
+ export function resultCountBucket(n) {
21
+ if (n === 0)
22
+ return "0";
23
+ if (n <= 3)
24
+ return "1-3";
25
+ if (n <= 10)
26
+ return "4-10";
27
+ if (n <= 20)
28
+ return "11-20";
29
+ return "20+";
30
+ }
31
+ export const MISSING_CATEGORY_VALUES = [
32
+ "missing_error_handling",
33
+ "missing_config_example",
34
+ "missing_api_reference",
35
+ "missing_type_signature",
36
+ "missing_test_coverage",
37
+ "other",
38
+ ];
39
+ export function normalizeMissingCategory(value) {
40
+ if (!value)
41
+ return undefined;
42
+ return MISSING_CATEGORY_VALUES.includes(value)
43
+ ? value
44
+ : "other";
45
+ }
46
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/telemetry/types.ts"],"names":[],"mappings":"AAsBA,MAAM,CAAC,MAAM,wBAAwB,GAAoB;IACvD,OAAO,EAAE,IAAI;IACb,KAAK,EAAE;QACL,QAAQ,EAAE,IAAI;QACd,iBAAiB,EAAE;YACjB,OAAO,EAAE,KAAK;YACd,aAAa,EAAE,GAAG;YAClB,iBAAiB,EAAE,IAAI;YACvB,wBAAwB,EAAE,CAAC;SAC5B;KACF;IACD,OAAO,EAAE;QACP,aAAa,EAAE,IAAI;QACnB,uBAAuB,EAAE,IAAI;QAC7B,0BAA0B,EAAE,EAAE;QAC9B,mBAAmB,EAAE,EAAE;QACvB,eAAe,EAAE,EAAE;KACpB;CACF,CAAC;AAgFF,MAAM,UAAU,iBAAiB,CAAC,CAAS;IACzC,IAAI,CAAC,KAAK,CAAC;QAAE,OAAO,GAAG,CAAC;IACxB,IAAI,CAAC,IAAI,CAAC;QAAE,OAAO,KAAK,CAAC;IACzB,IAAI,CAAC,IAAI,EAAE;QAAE,OAAO,MAAM,CAAC;IAC3B,IAAI,CAAC,IAAI,EAAE;QAAE,OAAO,OAAO,CAAC;IAC5B,OAAO,KAAK,CAAC;AACf,CAAC;AAED,MAAM,CAAC,MAAM,uBAAuB,GAAG;IACrC,wBAAwB;IACxB,wBAAwB;IACxB,uBAAuB;IACvB,wBAAwB;IACxB,uBAAuB;IACvB,OAAO;CACC,CAAC;AAIX,MAAM,UAAU,wBAAwB,CACtC,KAAyB;IAEzB,IAAI,CAAC,KAAK;QAAE,OAAO,SAAS,CAAC;IAC7B,OAAQ,uBAA6C,CAAC,QAAQ,CAAC,KAAK,CAAC;QACnE,CAAC,CAAE,KAAyB;QAC5B,CAAC,CAAC,OAAO,CAAC;AACd,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vivantel/virage-core",
3
- "version": "0.2.19",
3
+ "version": "0.2.22",
4
4
  "type": "module",
5
5
  "description": "Core RAG pipeline tools - universal chunking, embedding, vector store interfaces",
6
6
  "repository": {
@@ -26,7 +26,7 @@
26
26
  "access": "public"
27
27
  },
28
28
  "scripts": {
29
- "build": "rm -rf dist && tsc && echo \"✅ Build completed successfully\"",
29
+ "build": "rimraf dist && tsc && echo \"✅ Build completed successfully\"",
30
30
  "dev": "tsx watch src/index.ts",
31
31
  "type-check": "tsc --noEmit",
32
32
  "lint": "eslint src/",
@@ -59,14 +59,15 @@
59
59
  },
60
60
  "devDependencies": {
61
61
  "@eslint/js": "^10.0.1",
62
- "@supabase/supabase-js": "^2.106.2",
62
+ "@supabase/supabase-js": "^2.107.0",
63
63
  "@types/better-sqlite3": "^7.6.0",
64
- "@types/node": "^25.9.1",
64
+ "@types/node": "^25.9.2",
65
65
  "eslint": "^10.4.1",
66
66
  "prettier": "^3.8.3",
67
+ "rimraf": "^6.0.1",
67
68
  "tsx": "^4.22.4",
68
69
  "typedoc": "^0.28.19",
69
- "typedoc-plugin-markdown": "^4.11.0",
70
+ "typedoc-plugin-markdown": "^4.12.0",
70
71
  "typescript": "^6.0.3",
71
72
  "typescript-eslint": "^8.60.1",
72
73
  "vitest": "^4.1.8"
@@ -1 +0,0 @@
1
- {"version":3,"file":"embeddings-db.d.ts","sourceRoot":"","sources":["../../src/core/embeddings-db.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAmD5E,qBAAa,YAAY;IACvB,OAAO,CAAC,EAAE,CAAoB;gBAElB,MAAM,EAAE,MAAM;IAuB1B,OAAO,CAAC,OAAO;IAOf,OAAO,CAAC,0BAA0B;IAkElC,OAAO,IAAI,cAAc,GAAG,IAAI;IAYhC,OAAO,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAQnC,wFAAwF;IACxF,WAAW,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IAgB/B,2DAA2D;IAC3D,YAAY,CAAC,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI;IAoBnC,2DAA2D;IAC3D,eAAe,CACb,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,MAAM,EAAE,EACnB,UAAU,EAAE,MAAM,GACjB,IAAI;IAQP,4DAA4D;IAC5D,cAAc,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAQzC,sFAAsF;IACtF,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAI5C;;;OAGG;IACH,aAAa,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI;IAsBxD,6EAA6E;IAC7E,qBAAqB,IAAI,KAAK,EAAE;IAsBhC,2EAA2E;IAC3E,sBAAsB,IAAI,aAAa,EAAE;IAMzC,yFAAyF;IACzF,YAAY,IAAI,KAAK,EAAE;IAsBvB,uEAAuE;IACvE,aAAa,IAAI,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC;IAYpC,2EAA2E;IAC3E,MAAM,CAAC,MAAM,EAAE,aAAa,EAAE,GAAG,IAAI;IAsBrC,GAAG,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO;IAOjC,6EAA6E;IAC7E,MAAM,IAAI,aAAa,EAAE;IAMzB,sEAAsE;IACtE,UAAU,IAAI,aAAa,EAAE;IAI7B,YAAY,CAAC,aAAa,EAAE,MAAM,EAAE,GAAG,IAAI;IAU3C,iDAAiD;IACjD,YAAY,IAAI,MAAM;IAStB,QAAQ,IAAI,IAAI;IAKhB,aAAa,IAAI,IAAI;IAIrB,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAuDvC,KAAK,IAAI,IAAI;IAIb,OAAO,CAAC,oBAAoB;CAqB7B"}