@evolith/smart-cli 1.1.2 → 1.1.3
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.
- package/dist/app.module.d.ts +2 -0
- package/dist/app.module.js +134 -0
- package/dist/app.module.js.map +1 -0
- package/dist/commands/adr/adr.command.d.ts +34 -0
- package/dist/commands/adr/adr.command.js +351 -0
- package/dist/commands/adr/adr.command.js.map +1 -0
- package/dist/commands/agents/agents.command.d.ts +14 -0
- package/dist/commands/agents/agents.command.js +61 -0
- package/dist/commands/agents/agents.command.js.map +1 -0
- package/dist/commands/agents/index.d.ts +1 -0
- package/dist/commands/agents/index.js +6 -0
- package/dist/commands/agents/index.js.map +1 -0
- package/dist/commands/alias/alias.command.d.ts +16 -0
- package/dist/commands/alias/alias.command.js +95 -0
- package/dist/commands/alias/alias.command.js.map +1 -0
- package/dist/commands/api/api.catalog.d.ts +38 -0
- package/dist/commands/api/api.catalog.js +167 -0
- package/dist/commands/api/api.catalog.js.map +1 -0
- package/dist/commands/api/api.command.d.ts +21 -0
- package/dist/commands/api/api.command.js +162 -0
- package/dist/commands/api/api.command.js.map +1 -0
- package/dist/commands/architecture/scaffold/index.d.ts +2 -0
- package/dist/commands/architecture/scaffold/index.js +6 -0
- package/dist/commands/architecture/scaffold/index.js.map +1 -0
- package/dist/commands/architecture/scaffold/scaffold-strategy.d.ts +15 -0
- package/dist/commands/architecture/scaffold/scaffold-strategy.js +20 -0
- package/dist/commands/architecture/scaffold/scaffold-strategy.js.map +1 -0
- package/dist/commands/architecture/scaffold.command.d.ts +16 -0
- package/dist/commands/architecture/scaffold.command.js +321 -0
- package/dist/commands/architecture/scaffold.command.js.map +1 -0
- package/dist/commands/completion/completion.command.d.ts +28 -0
- package/dist/commands/completion/completion.command.js +321 -0
- package/dist/commands/completion/completion.command.js.map +1 -0
- package/dist/commands/docs/docs.command.d.ts +17 -0
- package/dist/commands/docs/docs.command.js +292 -0
- package/dist/commands/docs/docs.command.js.map +1 -0
- package/dist/commands/drift/drift.command.d.ts +28 -0
- package/dist/commands/drift/drift.command.js +283 -0
- package/dist/commands/drift/drift.command.js.map +1 -0
- package/dist/commands/fixtures/fixtures.command.d.ts +21 -0
- package/dist/commands/fixtures/fixtures.command.js +310 -0
- package/dist/commands/fixtures/fixtures.command.js.map +1 -0
- package/dist/commands/gate/gate.command.d.ts +29 -0
- package/dist/commands/gate/gate.command.js +193 -0
- package/dist/commands/gate/gate.command.js.map +1 -0
- package/dist/commands/history/history.command.d.ts +29 -0
- package/dist/commands/history/history.command.js +237 -0
- package/dist/commands/history/history.command.js.map +1 -0
- package/dist/commands/init/agents.command.d.ts +24 -0
- package/dist/commands/init/agents.command.js +330 -0
- package/dist/commands/init/agents.command.js.map +1 -0
- package/dist/commands/init/init.command.d.ts +26 -0
- package/dist/commands/init/init.command.js +170 -0
- package/dist/commands/init/init.command.js.map +1 -0
- package/dist/commands/init/init.wizard.d.ts +19 -0
- package/dist/commands/init/init.wizard.js +181 -0
- package/dist/commands/init/init.wizard.js.map +1 -0
- package/dist/commands/init/upgrade.command.d.ts +22 -0
- package/dist/commands/init/upgrade.command.js +178 -0
- package/dist/commands/init/upgrade.command.js.map +1 -0
- package/dist/commands/mcp/mcp-serve.command.d.ts +17 -0
- package/dist/commands/mcp/mcp-serve.command.js +153 -0
- package/dist/commands/mcp/mcp-serve.command.js.map +1 -0
- package/dist/commands/phase/phase-advance.command.d.ts +30 -0
- package/dist/commands/phase/phase-advance.command.js +206 -0
- package/dist/commands/phase/phase-advance.command.js.map +1 -0
- package/dist/commands/profile/profile.command.d.ts +18 -0
- package/dist/commands/profile/profile.command.js +198 -0
- package/dist/commands/profile/profile.command.js.map +1 -0
- package/dist/commands/sdlc/gate-status.command.d.ts +10 -0
- package/dist/commands/sdlc/gate-status.command.js +162 -0
- package/dist/commands/sdlc/gate-status.command.js.map +1 -0
- package/dist/commands/sdlc/generate-domain.command.d.ts +8 -0
- package/dist/commands/sdlc/generate-domain.command.js +165 -0
- package/dist/commands/sdlc/generate-domain.command.js.map +1 -0
- package/dist/commands/sdlc/handoff.command.d.ts +27 -0
- package/dist/commands/sdlc/handoff.command.js +275 -0
- package/dist/commands/sdlc/handoff.command.js.map +1 -0
- package/dist/commands/sdlc/sdlc.command.d.ts +5 -0
- package/dist/commands/sdlc/sdlc.command.js +44 -0
- package/dist/commands/sdlc/sdlc.command.js.map +1 -0
- package/dist/commands/standards/standards.command.d.ts +30 -0
- package/dist/commands/standards/standards.command.js +283 -0
- package/dist/commands/standards/standards.command.js.map +1 -0
- package/dist/commands/update/update.command.d.ts +21 -0
- package/dist/commands/update/update.command.js +214 -0
- package/dist/commands/update/update.command.js.map +1 -0
- package/dist/commands/upgrade/index.d.ts +1 -0
- package/dist/commands/upgrade/index.js +6 -0
- package/dist/commands/upgrade/index.js.map +1 -0
- package/dist/commands/upgrade/upgrade.command.d.ts +14 -0
- package/dist/commands/upgrade/upgrade.command.js +58 -0
- package/dist/commands/upgrade/upgrade.command.js.map +1 -0
- package/dist/commands/validate/validate.command.d.ts +43 -0
- package/dist/commands/validate/validate.command.js +514 -0
- package/dist/commands/validate/validate.command.js.map +1 -0
- package/dist/config/alias.service.d.ts +14 -0
- package/dist/config/alias.service.js +103 -0
- package/dist/config/alias.service.js.map +1 -0
- package/dist/contributions/contribution-validator.d.ts +16 -0
- package/dist/contributions/contribution-validator.js +34 -0
- package/dist/contributions/contribution-validator.js.map +1 -0
- package/dist/contributions/index.d.ts +1 -0
- package/dist/contributions/index.js +6 -0
- package/dist/contributions/index.js.map +1 -0
- package/dist/infrastructure/adapters/agent-registry.service.d.ts +30 -0
- package/dist/infrastructure/adapters/agent-registry.service.js +175 -0
- package/dist/infrastructure/adapters/agent-registry.service.js.map +1 -0
- package/dist/infrastructure/architecture/nx-workspace.strategy.d.ts +19 -0
- package/dist/infrastructure/architecture/nx-workspace.strategy.js +125 -0
- package/dist/infrastructure/architecture/nx-workspace.strategy.js.map +1 -0
- package/dist/infrastructure/catalog/catalog-loader.d.ts +21 -0
- package/dist/infrastructure/catalog/catalog-loader.js +144 -0
- package/dist/infrastructure/catalog/catalog-loader.js.map +1 -0
- package/dist/infrastructure/cli/base-command.d.ts +14 -0
- package/dist/infrastructure/cli/base-command.js +41 -0
- package/dist/infrastructure/cli/base-command.js.map +1 -0
- package/dist/infrastructure/cli/command-executor.d.ts +20 -0
- package/dist/infrastructure/cli/command-executor.js +110 -0
- package/dist/infrastructure/cli/command-executor.js.map +1 -0
- package/dist/infrastructure/cli/providers/index.d.ts +52 -0
- package/dist/infrastructure/cli/providers/index.js +175 -0
- package/dist/infrastructure/cli/providers/index.js.map +1 -0
- package/dist/infrastructure/config/config.service.d.ts +34 -0
- package/dist/infrastructure/config/config.service.js +126 -0
- package/dist/infrastructure/config/config.service.js.map +1 -0
- package/dist/infrastructure/filesystem/file-manager.service.d.ts +12 -0
- package/dist/infrastructure/filesystem/file-manager.service.js +79 -0
- package/dist/infrastructure/filesystem/file-manager.service.js.map +1 -0
- package/dist/infrastructure/formatters/output-formatter.service.d.ts +28 -0
- package/dist/infrastructure/formatters/output-formatter.service.js +199 -0
- package/dist/infrastructure/formatters/output-formatter.service.js.map +1 -0
- package/dist/infrastructure/observability/command-watcher.d.ts +45 -0
- package/dist/infrastructure/observability/command-watcher.js +199 -0
- package/dist/infrastructure/observability/command-watcher.js.map +1 -0
- package/dist/infrastructure/observability/error-reporter.d.ts +47 -0
- package/dist/infrastructure/observability/error-reporter.js +163 -0
- package/dist/infrastructure/observability/error-reporter.js.map +1 -0
- package/dist/infrastructure/observability/index.d.ts +11 -0
- package/dist/infrastructure/observability/index.js +31 -0
- package/dist/infrastructure/observability/index.js.map +1 -0
- package/dist/infrastructure/observability/otel-tracing.d.ts +4 -0
- package/dist/infrastructure/observability/otel-tracing.js +34 -0
- package/dist/infrastructure/observability/otel-tracing.js.map +1 -0
- package/dist/infrastructure/observability/structured-logger.d.ts +53 -0
- package/dist/infrastructure/observability/structured-logger.js +123 -0
- package/dist/infrastructure/observability/structured-logger.js.map +1 -0
- package/dist/infrastructure/observability/timing.d.ts +23 -0
- package/dist/infrastructure/observability/timing.js +140 -0
- package/dist/infrastructure/observability/timing.js.map +1 -0
- package/dist/infrastructure/observability/tool-usage-telemetry.service.d.ts +46 -0
- package/dist/infrastructure/observability/tool-usage-telemetry.service.js +181 -0
- package/dist/infrastructure/observability/tool-usage-telemetry.service.js.map +1 -0
- package/dist/infrastructure/plugins/plugin-loader.d.ts +10 -0
- package/dist/infrastructure/plugins/plugin-loader.js +145 -0
- package/dist/infrastructure/plugins/plugin-loader.js.map +1 -0
- package/dist/infrastructure/plugins/plugin.module.d.ts +4 -0
- package/dist/infrastructure/plugins/plugin.module.js +28 -0
- package/dist/infrastructure/plugins/plugin.module.js.map +1 -0
- package/dist/infrastructure/prompts/init-prompt-group.d.ts +3 -0
- package/dist/infrastructure/prompts/init-prompt-group.js +115 -0
- package/dist/infrastructure/prompts/init-prompt-group.js.map +1 -0
- package/dist/infrastructure/prompts/init-prompt-options.d.ts +10 -0
- package/dist/infrastructure/prompts/init-prompt-options.js +40 -0
- package/dist/infrastructure/prompts/init-prompt-options.js.map +1 -0
- package/dist/infrastructure/prompts/progress.service.d.ts +24 -0
- package/dist/infrastructure/prompts/progress.service.js +180 -0
- package/dist/infrastructure/prompts/progress.service.js.map +1 -0
- package/dist/infrastructure/prompts/prompt.service.d.ts +42 -0
- package/dist/infrastructure/prompts/prompt.service.js +142 -0
- package/dist/infrastructure/prompts/prompt.service.js.map +1 -0
- package/dist/infrastructure/prompts/wizard.service.d.ts +27 -0
- package/dist/infrastructure/prompts/wizard.service.js +163 -0
- package/dist/infrastructure/prompts/wizard.service.js.map +1 -0
- package/dist/infrastructure/providers/config-parser.provider.d.ts +15 -0
- package/dist/infrastructure/providers/config-parser.provider.js +68 -0
- package/dist/infrastructure/providers/config-parser.provider.js.map +1 -0
- package/dist/infrastructure/providers/logger.provider.d.ts +10 -0
- package/dist/infrastructure/providers/logger.provider.js +84 -0
- package/dist/infrastructure/providers/logger.provider.js.map +1 -0
- package/dist/infrastructure/providers/mock-filesystem.provider.d.ts +34 -0
- package/dist/infrastructure/providers/mock-filesystem.provider.js +129 -0
- package/dist/infrastructure/providers/mock-filesystem.provider.js.map +1 -0
- package/dist/infrastructure/providers/node-filesystem.provider.d.ts +23 -0
- package/dist/infrastructure/providers/node-filesystem.provider.js +117 -0
- package/dist/infrastructure/providers/node-filesystem.provider.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.js +27 -0
- package/dist/main.js.map +1 -0
- package/dist/plugins/index.d.ts +1 -0
- package/dist/plugins/index.js +6 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/plugin-registry.d.ts +22 -0
- package/dist/plugins/plugin-registry.js +33 -0
- package/dist/plugins/plugin-registry.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.logger = exports.StructuredLogger = exports.LogLevel = void 0;
|
|
4
|
+
var LogLevel;
|
|
5
|
+
(function (LogLevel) {
|
|
6
|
+
LogLevel[LogLevel["DEBUG"] = 0] = "DEBUG";
|
|
7
|
+
LogLevel[LogLevel["INFO"] = 1] = "INFO";
|
|
8
|
+
LogLevel[LogLevel["WARN"] = 2] = "WARN";
|
|
9
|
+
LogLevel[LogLevel["ERROR"] = 3] = "ERROR";
|
|
10
|
+
LogLevel[LogLevel["FATAL"] = 4] = "FATAL";
|
|
11
|
+
})(LogLevel || (exports.LogLevel = LogLevel = {}));
|
|
12
|
+
const defaultConfig = {
|
|
13
|
+
level: LogLevel.INFO,
|
|
14
|
+
enableColors: true,
|
|
15
|
+
enableTimestamp: true,
|
|
16
|
+
enableContext: true,
|
|
17
|
+
output: 'console',
|
|
18
|
+
};
|
|
19
|
+
class StructuredLogger {
|
|
20
|
+
constructor(config = {}) {
|
|
21
|
+
this.buffer = [];
|
|
22
|
+
this.operationStack = [];
|
|
23
|
+
this.config = { ...defaultConfig, ...config };
|
|
24
|
+
}
|
|
25
|
+
debug(message, context) {
|
|
26
|
+
this.log(LogLevel.DEBUG, message, context);
|
|
27
|
+
}
|
|
28
|
+
info(message, context) {
|
|
29
|
+
this.log(LogLevel.INFO, message, context);
|
|
30
|
+
}
|
|
31
|
+
warn(message, context) {
|
|
32
|
+
this.log(LogLevel.WARN, message, context);
|
|
33
|
+
}
|
|
34
|
+
error(message, context) {
|
|
35
|
+
this.log(LogLevel.ERROR, message, context);
|
|
36
|
+
}
|
|
37
|
+
fatal(message, context) {
|
|
38
|
+
this.log(LogLevel.FATAL, message, context);
|
|
39
|
+
}
|
|
40
|
+
log(level, message, context) {
|
|
41
|
+
if (level < this.config.level)
|
|
42
|
+
return;
|
|
43
|
+
const entry = {
|
|
44
|
+
timestamp: new Date().toISOString(),
|
|
45
|
+
level,
|
|
46
|
+
levelName: LogLevel[level],
|
|
47
|
+
message,
|
|
48
|
+
context,
|
|
49
|
+
operation: this.operationStack[this.operationStack.length - 1],
|
|
50
|
+
};
|
|
51
|
+
this.buffer.push(entry);
|
|
52
|
+
this.emit(entry);
|
|
53
|
+
}
|
|
54
|
+
emit(entry) {
|
|
55
|
+
const parts = [];
|
|
56
|
+
if (this.config.enableTimestamp) {
|
|
57
|
+
parts.push(`[${entry.timestamp}]`);
|
|
58
|
+
}
|
|
59
|
+
parts.push(`[${entry.levelName.padEnd(5)}]`);
|
|
60
|
+
if (entry.operation) {
|
|
61
|
+
parts.push(`{${entry.operation}}`);
|
|
62
|
+
}
|
|
63
|
+
parts.push(entry.message);
|
|
64
|
+
if (this.config.enableContext && entry.context) {
|
|
65
|
+
parts.push(JSON.stringify(entry.context));
|
|
66
|
+
}
|
|
67
|
+
if (entry.error) {
|
|
68
|
+
parts.push(`ERROR: ${entry.error.name}: ${entry.error.message}`);
|
|
69
|
+
if (entry.error.stack) {
|
|
70
|
+
parts.push(entry.error.stack);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
const output = parts.join(' ');
|
|
74
|
+
switch (entry.level) {
|
|
75
|
+
case LogLevel.DEBUG:
|
|
76
|
+
console.debug(output);
|
|
77
|
+
break;
|
|
78
|
+
case LogLevel.INFO:
|
|
79
|
+
console.info(output);
|
|
80
|
+
break;
|
|
81
|
+
case LogLevel.WARN:
|
|
82
|
+
console.warn(output);
|
|
83
|
+
break;
|
|
84
|
+
case LogLevel.ERROR:
|
|
85
|
+
case LogLevel.FATAL:
|
|
86
|
+
console.error(output);
|
|
87
|
+
break;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
startOperation(name) {
|
|
91
|
+
this.operationStack.push(name);
|
|
92
|
+
this.info(`Started: ${name}`, { operation: name, depth: this.operationStack.length });
|
|
93
|
+
}
|
|
94
|
+
endOperation(name, duration) {
|
|
95
|
+
const currentOp = this.operationStack.pop();
|
|
96
|
+
if (currentOp !== name) {
|
|
97
|
+
this.warn(`Operation mismatch: expected ${name}, got ${currentOp}`);
|
|
98
|
+
}
|
|
99
|
+
this.info(`Completed: ${name}`, { operation: name, durationMs: duration });
|
|
100
|
+
}
|
|
101
|
+
getBuffer() {
|
|
102
|
+
return [...this.buffer];
|
|
103
|
+
}
|
|
104
|
+
clearBuffer() {
|
|
105
|
+
this.buffer = [];
|
|
106
|
+
}
|
|
107
|
+
setLevel(level) {
|
|
108
|
+
this.config.level = level;
|
|
109
|
+
}
|
|
110
|
+
getLastError() {
|
|
111
|
+
const errorEntries = this.buffer.filter(e => e.level >= LogLevel.ERROR);
|
|
112
|
+
return errorEntries[errorEntries.length - 1]?.error;
|
|
113
|
+
}
|
|
114
|
+
getErrorCount() {
|
|
115
|
+
return this.buffer.filter(e => e.level >= LogLevel.ERROR).length;
|
|
116
|
+
}
|
|
117
|
+
getWarningCount() {
|
|
118
|
+
return this.buffer.filter(e => e.level === LogLevel.WARN).length;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
exports.StructuredLogger = StructuredLogger;
|
|
122
|
+
exports.logger = new StructuredLogger({ level: LogLevel.INFO });
|
|
123
|
+
//# sourceMappingURL=structured-logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structured-logger.js","sourceRoot":"","sources":["../../../src/infrastructure/observability/structured-logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export interface TimingResult {
|
|
2
|
+
duration: number;
|
|
3
|
+
success: boolean;
|
|
4
|
+
error?: Error;
|
|
5
|
+
}
|
|
6
|
+
export declare function Timed(operationName?: string): (target: unknown, propertyKey: string | symbol, descriptor: PropertyDescriptor) => PropertyDescriptor;
|
|
7
|
+
export declare function TimedSync(operationName?: string): (target: unknown, propertyKey: string | symbol, descriptor: PropertyDescriptor) => PropertyDescriptor;
|
|
8
|
+
export declare function measureTime<T>(operation: () => Promise<T>, operationName?: string): Promise<{
|
|
9
|
+
result: T;
|
|
10
|
+
duration: number;
|
|
11
|
+
}>;
|
|
12
|
+
export declare function measureTimeSync<T>(operation: () => T, operationName?: string): {
|
|
13
|
+
result: T;
|
|
14
|
+
duration: number;
|
|
15
|
+
};
|
|
16
|
+
export declare class OperationTimer {
|
|
17
|
+
private startTime;
|
|
18
|
+
private operationName;
|
|
19
|
+
start(operationName: string): void;
|
|
20
|
+
end(): number;
|
|
21
|
+
getDuration(): number;
|
|
22
|
+
}
|
|
23
|
+
export declare function profile<T extends (...args: unknown[]) => unknown>(fn: T, operationName?: string): T;
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.OperationTimer = void 0;
|
|
4
|
+
exports.Timed = Timed;
|
|
5
|
+
exports.TimedSync = TimedSync;
|
|
6
|
+
exports.measureTime = measureTime;
|
|
7
|
+
exports.measureTimeSync = measureTimeSync;
|
|
8
|
+
exports.profile = profile;
|
|
9
|
+
const structured_logger_1 = require("./structured-logger");
|
|
10
|
+
function Timed(operationName) {
|
|
11
|
+
return function (target, propertyKey, descriptor) {
|
|
12
|
+
const originalMethod = descriptor.value;
|
|
13
|
+
descriptor.value = async function (...args) {
|
|
14
|
+
const opName = operationName || `${target.constructor.name}.${String(propertyKey)}`;
|
|
15
|
+
const startTime = performance.now();
|
|
16
|
+
structured_logger_1.logger.startOperation(opName);
|
|
17
|
+
try {
|
|
18
|
+
const result = await originalMethod.apply(this, args);
|
|
19
|
+
const duration = performance.now() - startTime;
|
|
20
|
+
structured_logger_1.logger.endOperation(opName, duration);
|
|
21
|
+
return result;
|
|
22
|
+
}
|
|
23
|
+
catch (error) {
|
|
24
|
+
const duration = performance.now() - startTime;
|
|
25
|
+
const err = error;
|
|
26
|
+
structured_logger_1.logger.error(`Operation failed: ${opName}`, {
|
|
27
|
+
durationMs: duration,
|
|
28
|
+
error: err.message,
|
|
29
|
+
stack: err.stack,
|
|
30
|
+
});
|
|
31
|
+
throw error;
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
return descriptor;
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
function TimedSync(operationName) {
|
|
38
|
+
return function (target, propertyKey, descriptor) {
|
|
39
|
+
const originalMethod = descriptor.value;
|
|
40
|
+
descriptor.value = function (...args) {
|
|
41
|
+
const opName = operationName || `${target.constructor.name}.${String(propertyKey)}`;
|
|
42
|
+
const startTime = performance.now();
|
|
43
|
+
structured_logger_1.logger.startOperation(opName);
|
|
44
|
+
try {
|
|
45
|
+
const result = originalMethod.apply(this, args);
|
|
46
|
+
const duration = performance.now() - startTime;
|
|
47
|
+
structured_logger_1.logger.endOperation(opName, duration);
|
|
48
|
+
return result;
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
const duration = performance.now() - startTime;
|
|
52
|
+
const err = error;
|
|
53
|
+
structured_logger_1.logger.error(`Operation failed: ${opName}`, {
|
|
54
|
+
durationMs: duration,
|
|
55
|
+
error: err.message,
|
|
56
|
+
stack: err.stack,
|
|
57
|
+
});
|
|
58
|
+
throw error;
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
return descriptor;
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
async function measureTime(operation, operationName) {
|
|
65
|
+
const name = operationName || 'anonymous-operation';
|
|
66
|
+
const startTime = performance.now();
|
|
67
|
+
structured_logger_1.logger.startOperation(name);
|
|
68
|
+
try {
|
|
69
|
+
const result = await operation();
|
|
70
|
+
const duration = performance.now() - startTime;
|
|
71
|
+
structured_logger_1.logger.endOperation(name, duration);
|
|
72
|
+
return { result, duration };
|
|
73
|
+
}
|
|
74
|
+
catch (error) {
|
|
75
|
+
const duration = performance.now() - startTime;
|
|
76
|
+
const err = error;
|
|
77
|
+
structured_logger_1.logger.error(`Operation failed: ${name}`, {
|
|
78
|
+
durationMs: duration,
|
|
79
|
+
error: err.message,
|
|
80
|
+
});
|
|
81
|
+
throw error;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
function measureTimeSync(operation, operationName) {
|
|
85
|
+
const name = operationName || 'anonymous-operation';
|
|
86
|
+
const startTime = performance.now();
|
|
87
|
+
structured_logger_1.logger.startOperation(name);
|
|
88
|
+
try {
|
|
89
|
+
const result = operation();
|
|
90
|
+
const duration = performance.now() - startTime;
|
|
91
|
+
structured_logger_1.logger.endOperation(name, duration);
|
|
92
|
+
return { result, duration };
|
|
93
|
+
}
|
|
94
|
+
catch (error) {
|
|
95
|
+
const duration = performance.now() - startTime;
|
|
96
|
+
const err = error;
|
|
97
|
+
structured_logger_1.logger.error(`Operation failed: ${name}`, {
|
|
98
|
+
durationMs: duration,
|
|
99
|
+
error: err.message,
|
|
100
|
+
});
|
|
101
|
+
throw error;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
class OperationTimer {
|
|
105
|
+
constructor() {
|
|
106
|
+
this.startTime = 0;
|
|
107
|
+
this.operationName = '';
|
|
108
|
+
}
|
|
109
|
+
start(operationName) {
|
|
110
|
+
this.operationName = operationName;
|
|
111
|
+
this.startTime = performance.now();
|
|
112
|
+
structured_logger_1.logger.startOperation(operationName);
|
|
113
|
+
}
|
|
114
|
+
end() {
|
|
115
|
+
const duration = performance.now() - this.startTime;
|
|
116
|
+
structured_logger_1.logger.endOperation(this.operationName, duration);
|
|
117
|
+
return duration;
|
|
118
|
+
}
|
|
119
|
+
getDuration() {
|
|
120
|
+
return performance.now() - this.startTime;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
exports.OperationTimer = OperationTimer;
|
|
124
|
+
function profile(fn, operationName) {
|
|
125
|
+
const name = operationName || fn.name;
|
|
126
|
+
return (async (...args) => {
|
|
127
|
+
const timer = new OperationTimer();
|
|
128
|
+
timer.start(name);
|
|
129
|
+
try {
|
|
130
|
+
const result = await fn(...args);
|
|
131
|
+
timer.end();
|
|
132
|
+
return result;
|
|
133
|
+
}
|
|
134
|
+
catch (error) {
|
|
135
|
+
timer.end();
|
|
136
|
+
throw error;
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
//# sourceMappingURL=timing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timing.js","sourceRoot":"","sources":["../../../src/infrastructure/observability/timing.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
export interface ToolUsageEvent {
|
|
2
|
+
timestamp: string;
|
|
3
|
+
toolName: string;
|
|
4
|
+
userId?: string;
|
|
5
|
+
sessionId?: string;
|
|
6
|
+
durationMs: number;
|
|
7
|
+
success: boolean;
|
|
8
|
+
errorMessage?: string;
|
|
9
|
+
context?: Record<string, unknown>;
|
|
10
|
+
}
|
|
11
|
+
export interface ToolUsageStats {
|
|
12
|
+
toolName: string;
|
|
13
|
+
totalCalls: number;
|
|
14
|
+
successCount: number;
|
|
15
|
+
errorCount: number;
|
|
16
|
+
averageDurationMs: number;
|
|
17
|
+
lastCalled: string;
|
|
18
|
+
peakHour?: string;
|
|
19
|
+
}
|
|
20
|
+
export interface TelemetryReport {
|
|
21
|
+
generatedAt: string;
|
|
22
|
+
periodStart: string;
|
|
23
|
+
periodEnd: string;
|
|
24
|
+
totalEvents: number;
|
|
25
|
+
uniqueTools: number;
|
|
26
|
+
toolStats: ToolUsageStats[];
|
|
27
|
+
topErrors: Array<{
|
|
28
|
+
tool: string;
|
|
29
|
+
error: string;
|
|
30
|
+
count: number;
|
|
31
|
+
}>;
|
|
32
|
+
usageByHour: Record<string, number>;
|
|
33
|
+
recommendation?: string;
|
|
34
|
+
}
|
|
35
|
+
export declare class ToolUsageTelemetry {
|
|
36
|
+
private readonly telemetryPath;
|
|
37
|
+
private events;
|
|
38
|
+
private initialized;
|
|
39
|
+
constructor(repoPath?: string);
|
|
40
|
+
initialize(): Promise<void>;
|
|
41
|
+
recordEvent(event: Omit<ToolUsageEvent, 'timestamp'>): Promise<void>;
|
|
42
|
+
getStats(periodDays?: number): Promise<ToolUsageStats[]>;
|
|
43
|
+
generateReport(periodDays?: number): Promise<TelemetryReport>;
|
|
44
|
+
exportCsv(): Promise<string>;
|
|
45
|
+
clear(): Promise<void>;
|
|
46
|
+
}
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.ToolUsageTelemetry = void 0;
|
|
37
|
+
const fs = __importStar(require("fs-extra"));
|
|
38
|
+
const path = __importStar(require("path"));
|
|
39
|
+
class ToolUsageTelemetry {
|
|
40
|
+
constructor(repoPath) {
|
|
41
|
+
this.events = [];
|
|
42
|
+
this.initialized = false;
|
|
43
|
+
const basePath = repoPath || process.cwd();
|
|
44
|
+
this.telemetryPath = path.join(basePath, '.evolith', 'telemetry', 'tool-usage.jsonl');
|
|
45
|
+
}
|
|
46
|
+
async initialize() {
|
|
47
|
+
if (this.initialized)
|
|
48
|
+
return;
|
|
49
|
+
const dir = path.dirname(this.telemetryPath);
|
|
50
|
+
await fs.ensureDir(dir);
|
|
51
|
+
if (await fs.pathExists(this.telemetryPath)) {
|
|
52
|
+
const content = await fs.readFile(this.telemetryPath, 'utf-8');
|
|
53
|
+
const lines = content.split('\n').filter(l => l.trim());
|
|
54
|
+
this.events = lines.map(l => {
|
|
55
|
+
try {
|
|
56
|
+
return JSON.parse(l);
|
|
57
|
+
}
|
|
58
|
+
catch {
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
}).filter(Boolean);
|
|
62
|
+
}
|
|
63
|
+
this.initialized = true;
|
|
64
|
+
}
|
|
65
|
+
async recordEvent(event) {
|
|
66
|
+
await this.initialize();
|
|
67
|
+
const fullEvent = {
|
|
68
|
+
...event,
|
|
69
|
+
timestamp: new Date().toISOString(),
|
|
70
|
+
};
|
|
71
|
+
this.events.push(fullEvent);
|
|
72
|
+
await fs.appendFile(this.telemetryPath, JSON.stringify(fullEvent) + '\n');
|
|
73
|
+
}
|
|
74
|
+
async getStats(periodDays = 7) {
|
|
75
|
+
await this.initialize();
|
|
76
|
+
const cutoff = new Date();
|
|
77
|
+
cutoff.setDate(cutoff.getDate() - periodDays);
|
|
78
|
+
const recentEvents = this.events.filter(e => new Date(e.timestamp) >= cutoff);
|
|
79
|
+
const toolMap = new Map();
|
|
80
|
+
for (const event of recentEvents) {
|
|
81
|
+
const list = toolMap.get(event.toolName) || [];
|
|
82
|
+
list.push(event);
|
|
83
|
+
toolMap.set(event.toolName, list);
|
|
84
|
+
}
|
|
85
|
+
const stats = [];
|
|
86
|
+
for (const [toolName, events] of toolMap) {
|
|
87
|
+
const durations = events.map(e => e.durationMs);
|
|
88
|
+
const hourCounts = {};
|
|
89
|
+
for (const event of events) {
|
|
90
|
+
const hour = new Date(event.timestamp).getHours().toString().padStart(2, '0') + ':00';
|
|
91
|
+
hourCounts[hour] = (hourCounts[hour] || 0) + 1;
|
|
92
|
+
}
|
|
93
|
+
let peakHour = '';
|
|
94
|
+
let peakCount = 0;
|
|
95
|
+
for (const [hour, count] of Object.entries(hourCounts)) {
|
|
96
|
+
if (count > peakCount) {
|
|
97
|
+
peakHour = hour;
|
|
98
|
+
peakCount = count;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
stats.push({
|
|
102
|
+
toolName,
|
|
103
|
+
totalCalls: events.length,
|
|
104
|
+
successCount: events.filter(e => e.success).length,
|
|
105
|
+
errorCount: events.filter(e => !e.success).length,
|
|
106
|
+
averageDurationMs: durations.reduce((a, b) => a + b, 0) / durations.length,
|
|
107
|
+
lastCalled: events.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime())[0].timestamp,
|
|
108
|
+
peakHour: peakHour || undefined,
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
return stats.sort((a, b) => b.totalCalls - a.totalCalls);
|
|
112
|
+
}
|
|
113
|
+
async generateReport(periodDays = 7) {
|
|
114
|
+
await this.initialize();
|
|
115
|
+
const cutoff = new Date();
|
|
116
|
+
cutoff.setDate(cutoff.getDate() - periodDays);
|
|
117
|
+
const recentEvents = this.events.filter(e => new Date(e.timestamp) >= cutoff);
|
|
118
|
+
const periodEnd = recentEvents.length > 0
|
|
119
|
+
? recentEvents.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime())[0].timestamp
|
|
120
|
+
: new Date().toISOString();
|
|
121
|
+
const stats = await this.getStats(periodDays);
|
|
122
|
+
const errorMap = new Map();
|
|
123
|
+
for (const event of recentEvents) {
|
|
124
|
+
if (!event.success && event.errorMessage) {
|
|
125
|
+
const key = `${event.toolName}:${event.errorMessage.substring(0, 50)}`;
|
|
126
|
+
errorMap.set(key, (errorMap.get(key) || 0) + 1);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
const topErrors = [];
|
|
130
|
+
for (const [key, count] of errorMap) {
|
|
131
|
+
const [tool, error] = key.split(':');
|
|
132
|
+
topErrors.push({ tool, error, count });
|
|
133
|
+
}
|
|
134
|
+
topErrors.sort((a, b) => b.count - a.count);
|
|
135
|
+
const usageByHour = {};
|
|
136
|
+
for (const event of recentEvents) {
|
|
137
|
+
const hour = new Date(event.timestamp).toISOString().substring(0, 13) + ':00';
|
|
138
|
+
usageByHour[hour] = (usageByHour[hour] || 0) + 1;
|
|
139
|
+
}
|
|
140
|
+
let recommendation;
|
|
141
|
+
if (stats.length > 0) {
|
|
142
|
+
const lowUsageTool = stats.find(s => s.totalCalls < 3);
|
|
143
|
+
if (lowUsageTool) {
|
|
144
|
+
recommendation = `Tool '${lowUsageTool.toolName}' has low usage. Consider adding training or documentation.`;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
return {
|
|
148
|
+
generatedAt: new Date().toISOString(),
|
|
149
|
+
periodStart: cutoff.toISOString(),
|
|
150
|
+
periodEnd,
|
|
151
|
+
totalEvents: recentEvents.length,
|
|
152
|
+
uniqueTools: stats.length,
|
|
153
|
+
toolStats: stats,
|
|
154
|
+
topErrors: topErrors.slice(0, 5),
|
|
155
|
+
usageByHour,
|
|
156
|
+
recommendation,
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
async exportCsv() {
|
|
160
|
+
const stats = await this.getStats();
|
|
161
|
+
const headers = ['Tool', 'Total Calls', 'Success', 'Errors', 'Avg Duration (ms)', 'Last Called', 'Peak Hour'];
|
|
162
|
+
const rows = stats.map(s => [
|
|
163
|
+
s.toolName,
|
|
164
|
+
s.totalCalls.toString(),
|
|
165
|
+
s.successCount.toString(),
|
|
166
|
+
s.errorCount.toString(),
|
|
167
|
+
Math.round(s.averageDurationMs).toString(),
|
|
168
|
+
s.lastCalled,
|
|
169
|
+
s.peakHour || 'N/A',
|
|
170
|
+
]);
|
|
171
|
+
return [headers.join(','), ...rows.map(r => r.join(','))].join('\n');
|
|
172
|
+
}
|
|
173
|
+
async clear() {
|
|
174
|
+
if (await fs.pathExists(this.telemetryPath)) {
|
|
175
|
+
await fs.remove(this.telemetryPath);
|
|
176
|
+
}
|
|
177
|
+
this.events = [];
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
exports.ToolUsageTelemetry = ToolUsageTelemetry;
|
|
181
|
+
//# sourceMappingURL=tool-usage-telemetry.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-usage-telemetry.service.js","sourceRoot":"","sources":["../../../src/infrastructure/observability/tool-usage-telemetry.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6CAA+B;AAC/B,2CAA6B;AAmC7B,MAAa,kBAAkB;IAK7B,YAAY,QAAiB;QAHrB,WAAM,GAAqB,EAAE,CAAC;QAC9B,gBAAW,GAAG,KAAK,CAAC;QAG1B,MAAM,QAAQ,GAAG,QAAQ,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;QAC3C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,kBAAkB,CAAC,CAAC;IACxF,CAAC;IAED,KAAK,CAAC,UAAU;QACd,IAAI,IAAI,CAAC,WAAW;YAAE,OAAO;QAE7B,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC7C,MAAM,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAExB,IAAI,MAAM,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;YAC5C,MAAM,OAAO,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;YAC/D,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;YACxD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;gBAC1B,IAAI,CAAC;oBACH,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAmB,CAAC;gBACzC,CAAC;gBAAC,MAAM,CAAC;oBACP,OAAO,IAAI,CAAC;gBACd,CAAC;YACH,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAqB,CAAC;QACzC,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,KAAwC;QACxD,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QAExB,MAAM,SAAS,GAAmB;YAChC,GAAG,KAAK;YACR,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACpC,CAAC;QAEF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAE5B,MAAM,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,CAAC;IAC5E,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,UAAU,GAAG,CAAC;QAC3B,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QAExB,MAAM,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QAC1B,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,UAAU,CAAC,CAAC;QAE9C,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,MAAM,CAAC,CAAC;QAE9E,MAAM,OAAO,GAAG,IAAI,GAAG,EAA4B,CAAC;QACpD,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE,CAAC;YACjC,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;YAC/C,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QACpC,CAAC;QAED,MAAM,KAAK,GAAqB,EAAE,CAAC;QACnC,KAAK,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,IAAI,OAAO,EAAE,CAAC;YACzC,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;YAChD,MAAM,UAAU,GAA2B,EAAE,CAAC;YAE9C,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;gBAC3B,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC;gBACtF,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;YACjD,CAAC;YAED,IAAI,QAAQ,GAAG,EAAE,CAAC;YAClB,IAAI,SAAS,GAAG,CAAC,CAAC;YAClB,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;gBACvD,IAAI,KAAK,GAAG,SAAS,EAAE,CAAC;oBACtB,QAAQ,GAAG,IAAI,CAAC;oBAChB,SAAS,GAAG,KAAK,CAAC;gBACpB,CAAC;YACH,CAAC;YAED,KAAK,CAAC,IAAI,CAAC;gBACT,QAAQ;gBACR,UAAU,EAAE,MAAM,CAAC,MAAM;gBACzB,YAAY,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM;gBAClD,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM;gBACjD,iBAAiB,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM;gBAC1E,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAC/B,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAClE,CAAC,CAAC,CAAC,CAAC,SAAS;gBACd,QAAQ,EAAE,QAAQ,IAAI,SAAS;aAChC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC;IAC3D,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,UAAU,GAAG,CAAC;QACjC,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QAExB,MAAM,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QAC1B,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,UAAU,CAAC,CAAC;QAE9C,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,MAAM,CAAC,CAAC;QAC9E,MAAM,SAAS,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC;YACvC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACzB,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAClE,CAAC,CAAC,CAAC,CAAC,SAAS;YAChB,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAE7B,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;QAE9C,MAAM,QAAQ,GAAG,IAAI,GAAG,EAAkB,CAAC;QAC3C,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE,CAAC;YACjC,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;gBACzC,MAAM,GAAG,GAAG,GAAG,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC;gBACvE,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YAClD,CAAC;QACH,CAAC;QAED,MAAM,SAAS,GAA0D,EAAE,CAAC;QAC5E,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,QAAQ,EAAE,CAAC;YACpC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACrC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QACzC,CAAC;QACD,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;QAE5C,MAAM,WAAW,GAA2B,EAAE,CAAC;QAC/C,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE,CAAC;YACjC,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC;YAC9E,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QACnD,CAAC;QAED,IAAI,cAAkC,CAAC;QACvC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACrB,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;YACvD,IAAI,YAAY,EAAE,CAAC;gBACjB,cAAc,GAAG,SAAS,YAAY,CAAC,QAAQ,6DAA6D,CAAC;YAC/G,CAAC;QACH,CAAC;QAED,OAAO;YACL,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACrC,WAAW,EAAE,MAAM,CAAC,WAAW,EAAE;YACjC,SAAS;YACT,WAAW,EAAE,YAAY,CAAC,MAAM;YAChC,WAAW,EAAE,KAAK,CAAC,MAAM;YACzB,SAAS,EAAE,KAAK;YAChB,SAAS,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;YAChC,WAAW;YACX,cAAc;SACf,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,SAAS;QACb,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpC,MAAM,OAAO,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,SAAS,EAAE,QAAQ,EAAE,mBAAmB,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;QAC9G,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;YAC1B,CAAC,CAAC,QAAQ;YACV,CAAC,CAAC,UAAU,CAAC,QAAQ,EAAE;YACvB,CAAC,CAAC,YAAY,CAAC,QAAQ,EAAE;YACzB,CAAC,CAAC,UAAU,CAAC,QAAQ,EAAE;YACvB,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,QAAQ,EAAE;YAC1C,CAAC,CAAC,UAAU;YACZ,CAAC,CAAC,QAAQ,IAAI,KAAK;SACpB,CAAC,CAAC;QAEH,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvE,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI,MAAM,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;YAC5C,MAAM,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;IACnB,CAAC;CACF;AA7KD,gDA6KC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Provider, Type } from '@nestjs/common';
|
|
2
|
+
export declare class PluginLoader {
|
|
3
|
+
private static readonly logger;
|
|
4
|
+
static loadPlugins(workspaceDir?: string): Promise<{
|
|
5
|
+
providers: Provider[];
|
|
6
|
+
imports: Type[];
|
|
7
|
+
}>;
|
|
8
|
+
private static loadPluginFromPath;
|
|
9
|
+
private static registerPluginContent;
|
|
10
|
+
}
|