@evolith/smart-cli 0.0.1-beta
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/ARCHITECTURE.md +121 -0
- package/README.es.md +425 -0
- package/README.md +419 -0
- package/dist/app.module.d.ts +2 -0
- package/dist/app.module.js +59 -0
- package/dist/app.module.js.map +1 -0
- package/dist/application/services/index.d.ts +54 -0
- package/dist/application/services/index.js +307 -0
- package/dist/application/services/index.js.map +1 -0
- package/dist/application/services/services.test.d.ts +1 -0
- package/dist/application/services/services.test.js +176 -0
- package/dist/application/services/services.test.js.map +1 -0
- package/dist/application/use-cases/validate-satellite.use-case.d.ts +18 -0
- package/dist/application/use-cases/validate-satellite.use-case.js +92 -0
- package/dist/application/use-cases/validate-satellite.use-case.js.map +1 -0
- package/dist/application/use-cases/validate-satellite.use-case.spec.d.ts +1 -0
- package/dist/application/use-cases/validate-satellite.use-case.spec.js +102 -0
- package/dist/application/use-cases/validate-satellite.use-case.spec.js.map +1 -0
- package/dist/commands/adr/adr.command.d.ts +28 -0
- package/dist/commands/adr/adr.command.js +357 -0
- package/dist/commands/adr/adr.command.js.map +1 -0
- package/dist/commands/architecture/scaffold.command.d.ts +7 -0
- package/dist/commands/architecture/scaffold.command.js +162 -0
- package/dist/commands/architecture/scaffold.command.js.map +1 -0
- package/dist/commands/commands.test.d.ts +1 -0
- package/dist/commands/commands.test.js +131 -0
- package/dist/commands/commands.test.js.map +1 -0
- package/dist/commands/completion/completion.command.d.ts +20 -0
- package/dist/commands/completion/completion.command.js +215 -0
- package/dist/commands/completion/completion.command.js.map +1 -0
- package/dist/commands/docs/docs.command.d.ts +9 -0
- package/dist/commands/docs/docs.command.js +77 -0
- package/dist/commands/docs/docs.command.js.map +1 -0
- package/dist/commands/history/history.command.d.ts +29 -0
- package/dist/commands/history/history.command.js +268 -0
- package/dist/commands/history/history.command.js.map +1 -0
- package/dist/commands/init/agents.command.d.ts +22 -0
- package/dist/commands/init/agents.command.js +502 -0
- package/dist/commands/init/agents.command.js.map +1 -0
- package/dist/commands/init/init.command.d.ts +20 -0
- package/dist/commands/init/init.command.js +329 -0
- package/dist/commands/init/init.command.js.map +1 -0
- package/dist/commands/init/upgrade.command.d.ts +9 -0
- package/dist/commands/init/upgrade.command.js +77 -0
- package/dist/commands/init/upgrade.command.js.map +1 -0
- package/dist/commands/mcp/mcp-serve.command.d.ts +15 -0
- package/dist/commands/mcp/mcp-serve.command.js +106 -0
- package/dist/commands/mcp/mcp-serve.command.js.map +1 -0
- package/dist/commands/sdlc/generate-domain.command.d.ts +5 -0
- package/dist/commands/sdlc/generate-domain.command.js +55 -0
- package/dist/commands/sdlc/generate-domain.command.js.map +1 -0
- package/dist/commands/sdlc/handoff.command.d.ts +22 -0
- package/dist/commands/sdlc/handoff.command.js +273 -0
- package/dist/commands/sdlc/handoff.command.js.map +1 -0
- package/dist/commands/sdlc/sdlc.command.d.ts +4 -0
- package/dist/commands/sdlc/sdlc.command.js +34 -0
- package/dist/commands/sdlc/sdlc.command.js.map +1 -0
- package/dist/commands/standards/standards.command.d.ts +27 -0
- package/dist/commands/standards/standards.command.js +308 -0
- package/dist/commands/standards/standards.command.js.map +1 -0
- package/dist/commands/validate/validate.command.d.ts +19 -0
- package/dist/commands/validate/validate.command.js +231 -0
- package/dist/commands/validate/validate.command.js.map +1 -0
- package/dist/config/runtimes.json +196 -0
- package/dist/config/tool-catalog.json +343 -0
- package/dist/core/abstractions/index.d.ts +6 -0
- package/dist/core/abstractions/index.js +23 -0
- package/dist/core/abstractions/index.js.map +1 -0
- package/dist/core/abstractions/interfaces.d.ts +60 -0
- package/dist/core/abstractions/interfaces.js +5 -0
- package/dist/core/abstractions/interfaces.js.map +1 -0
- package/dist/core/abstractions/providers/config-parser.provider.d.ts +15 -0
- package/dist/core/abstractions/providers/config-parser.provider.js +68 -0
- package/dist/core/abstractions/providers/config-parser.provider.js.map +1 -0
- package/dist/core/abstractions/providers/logger.provider.d.ts +10 -0
- package/dist/core/abstractions/providers/logger.provider.js +84 -0
- package/dist/core/abstractions/providers/logger.provider.js.map +1 -0
- package/dist/core/abstractions/providers/mock-filesystem.provider.d.ts +30 -0
- package/dist/core/abstractions/providers/mock-filesystem.provider.js +122 -0
- package/dist/core/abstractions/providers/mock-filesystem.provider.js.map +1 -0
- package/dist/core/abstractions/providers/node-filesystem.provider.d.ts +19 -0
- package/dist/core/abstractions/providers/node-filesystem.provider.js +104 -0
- package/dist/core/abstractions/providers/node-filesystem.provider.js.map +1 -0
- package/dist/core/architecture/nx-workspace.strategy.d.ts +11 -0
- package/dist/core/architecture/nx-workspace.strategy.js +107 -0
- package/dist/core/architecture/nx-workspace.strategy.js.map +1 -0
- package/dist/core/architecture/workspace-manager.strategy.d.ts +7 -0
- package/dist/core/architecture/workspace-manager.strategy.js +3 -0
- package/dist/core/architecture/workspace-manager.strategy.js.map +1 -0
- package/dist/core/config/config.service.d.ts +15 -0
- package/dist/core/config/config.service.js +55 -0
- package/dist/core/config/config.service.js.map +1 -0
- package/dist/core/config/config.service.spec.d.ts +1 -0
- package/dist/core/config/config.service.spec.js +43 -0
- package/dist/core/config/config.service.spec.js.map +1 -0
- package/dist/core/di/container.d.ts +25 -0
- package/dist/core/di/container.js +87 -0
- package/dist/core/di/container.js.map +1 -0
- package/dist/core/di/container.spec.d.ts +1 -0
- package/dist/core/di/container.spec.js +137 -0
- package/dist/core/di/container.spec.js.map +1 -0
- package/dist/core/errors/index.d.ts +26 -0
- package/dist/core/errors/index.js +67 -0
- package/dist/core/errors/index.js.map +1 -0
- package/dist/core/filesystem/file-manager.service.d.ts +4 -0
- package/dist/core/filesystem/file-manager.service.js +96 -0
- package/dist/core/filesystem/file-manager.service.js.map +1 -0
- package/dist/core/filesystem/file-manager.service.spec.d.ts +1 -0
- package/dist/core/filesystem/file-manager.service.spec.js +103 -0
- package/dist/core/filesystem/file-manager.service.spec.js.map +1 -0
- package/dist/core/mcp/mcp-server.service.d.ts +7 -0
- package/dist/core/mcp/mcp-server.service.js +31 -0
- package/dist/core/mcp/mcp-server.service.js.map +1 -0
- package/dist/core/mcp/metrics.service.d.ts +37 -0
- package/dist/core/mcp/metrics.service.js +72 -0
- package/dist/core/mcp/metrics.service.js.map +1 -0
- package/dist/core/mcp/prompts/index.d.ts +22 -0
- package/dist/core/mcp/prompts/index.js +175 -0
- package/dist/core/mcp/prompts/index.js.map +1 -0
- package/dist/core/mcp/resources/index.d.ts +11 -0
- package/dist/core/mcp/resources/index.js +193 -0
- package/dist/core/mcp/resources/index.js.map +1 -0
- package/dist/core/mcp/server.d.ts +25 -0
- package/dist/core/mcp/server.js +413 -0
- package/dist/core/mcp/server.js.map +1 -0
- package/dist/core/mcp/tools/agent.d.ts +41 -0
- package/dist/core/mcp/tools/agent.js +195 -0
- package/dist/core/mcp/tools/agent.js.map +1 -0
- package/dist/core/mcp/tools/architecture.d.ts +27 -0
- package/dist/core/mcp/tools/architecture.js +166 -0
- package/dist/core/mcp/tools/architecture.js.map +1 -0
- package/dist/core/mcp/tools/sdlc.d.ts +32 -0
- package/dist/core/mcp/tools/sdlc.js +189 -0
- package/dist/core/mcp/tools/sdlc.js.map +1 -0
- package/dist/core/mcp/tools/tool-utils.d.ts +4 -0
- package/dist/core/mcp/tools/tool-utils.js +18 -0
- package/dist/core/mcp/tools/tool-utils.js.map +1 -0
- package/dist/core/mcp/tools/validate.d.ts +18 -0
- package/dist/core/mcp/tools/validate.js +56 -0
- package/dist/core/mcp/tools/validate.js.map +1 -0
- package/dist/core/mcp/watcher.service.d.ts +8 -0
- package/dist/core/mcp/watcher.service.js +82 -0
- package/dist/core/mcp/watcher.service.js.map +1 -0
- package/dist/core/mcp/watcher.service.spec.d.ts +1 -0
- package/dist/core/mcp/watcher.service.spec.js +70 -0
- package/dist/core/mcp/watcher.service.spec.js.map +1 -0
- package/dist/core/observability/command-watcher.d.ts +45 -0
- package/dist/core/observability/command-watcher.js +168 -0
- package/dist/core/observability/command-watcher.js.map +1 -0
- package/dist/core/observability/error-reporter.d.ts +47 -0
- package/dist/core/observability/error-reporter.js +163 -0
- package/dist/core/observability/error-reporter.js.map +1 -0
- package/dist/core/observability/index.d.ts +4 -0
- package/dist/core/observability/index.js +24 -0
- package/dist/core/observability/index.js.map +1 -0
- package/dist/core/observability/observability.test.d.ts +1 -0
- package/dist/core/observability/observability.test.js +224 -0
- package/dist/core/observability/observability.test.js.map +1 -0
- package/dist/core/observability/structured-logger.d.ts +53 -0
- package/dist/core/observability/structured-logger.js +123 -0
- package/dist/core/observability/structured-logger.js.map +1 -0
- package/dist/core/observability/timing.d.ts +23 -0
- package/dist/core/observability/timing.js +140 -0
- package/dist/core/observability/timing.js.map +1 -0
- package/dist/core/services/command-executor.service.d.ts +3 -0
- package/dist/core/services/command-executor.service.js +12 -0
- package/dist/core/services/command-executor.service.js.map +1 -0
- package/dist/core/services/command-history.service.d.ts +38 -0
- package/dist/core/services/command-history.service.js +146 -0
- package/dist/core/services/command-history.service.js.map +1 -0
- package/dist/core/services/command-providers.d.ts +1 -0
- package/dist/core/services/command-providers.js +17 -0
- package/dist/core/services/command-providers.js.map +1 -0
- package/dist/core/services/runtime-catalog.service.d.ts +2 -0
- package/dist/core/services/runtime-catalog.service.js +7 -0
- package/dist/core/services/runtime-catalog.service.js.map +1 -0
- package/dist/core/sync/sync.service.d.ts +4 -0
- package/dist/core/sync/sync.service.js +81 -0
- package/dist/core/sync/sync.service.js.map +1 -0
- package/dist/core/sync/sync.service.spec.d.ts +1 -0
- package/dist/core/sync/sync.service.spec.js +63 -0
- package/dist/core/sync/sync.service.spec.js.map +1 -0
- package/dist/core/validators/ruleset-validator.service.d.ts +56 -0
- package/dist/core/validators/ruleset-validator.service.js +263 -0
- package/dist/core/validators/ruleset-validator.service.js.map +1 -0
- package/dist/core/validators/ruleset-validator.service.spec.d.ts +1 -0
- package/dist/core/validators/ruleset-validator.service.spec.js +121 -0
- package/dist/core/validators/ruleset-validator.service.spec.js.map +1 -0
- package/dist/domain/entities/index.d.ts +72 -0
- package/dist/domain/entities/index.js +119 -0
- package/dist/domain/entities/index.js.map +1 -0
- package/dist/domain/interfaces.d.ts +224 -0
- package/dist/domain/interfaces.js +3 -0
- package/dist/domain/interfaces.js.map +1 -0
- package/dist/domain/services/adr.service.d.ts +50 -0
- package/dist/domain/services/adr.service.js +125 -0
- package/dist/domain/services/adr.service.js.map +1 -0
- package/dist/domain/services/agent-registry.service.d.ts +26 -0
- package/dist/domain/services/agent-registry.service.js +152 -0
- package/dist/domain/services/agent-registry.service.js.map +1 -0
- package/dist/domain/services/index.d.ts +33 -0
- package/dist/domain/services/index.js +126 -0
- package/dist/domain/services/index.js.map +1 -0
- package/dist/domain/services/services.test.d.ts +1 -0
- package/dist/domain/services/services.test.js +236 -0
- package/dist/domain/services/services.test.js.map +1 -0
- package/dist/domain/services/standards.service.d.ts +47 -0
- package/dist/domain/services/standards.service.js +129 -0
- package/dist/domain/services/standards.service.js.map +1 -0
- package/dist/domain/services/tool-usage-telemetry.service.d.ts +46 -0
- package/dist/domain/services/tool-usage-telemetry.service.js +181 -0
- package/dist/domain/services/tool-usage-telemetry.service.js.map +1 -0
- package/dist/infrastructure/catalog/catalog-loader.d.ts +22 -0
- package/dist/infrastructure/catalog/catalog-loader.js +135 -0
- package/dist/infrastructure/catalog/catalog-loader.js.map +1 -0
- package/dist/infrastructure/catalog/catalog-loader.test.d.ts +1 -0
- package/dist/infrastructure/catalog/catalog-loader.test.js +184 -0
- package/dist/infrastructure/catalog/catalog-loader.test.js.map +1 -0
- package/dist/infrastructure/cli/command-executor.d.ts +20 -0
- package/dist/infrastructure/cli/command-executor.js +109 -0
- package/dist/infrastructure/cli/command-executor.js.map +1 -0
- package/dist/infrastructure/cli/command-executor.test.d.ts +1 -0
- package/dist/infrastructure/cli/command-executor.test.js +98 -0
- package/dist/infrastructure/cli/command-executor.test.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/formatters/output-formatter.service.d.ts +28 -0
- package/dist/infrastructure/formatters/output-formatter.service.js +198 -0
- package/dist/infrastructure/formatters/output-formatter.service.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.js +10 -0
- package/dist/main.js.map +1 -0
- package/dist/test/mocks/index.d.ts +44 -0
- package/dist/test/mocks/index.js +135 -0
- package/dist/test/mocks/index.js.map +1 -0
- package/package.json +80 -0
- package/shell/completion.bash +85 -0
- package/shell/completion.fish +72 -0
- package/shell/completion.zsh +83 -0
- package/templates/evolith.yaml.example +45 -0
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DIContainer = void 0;
|
|
4
|
+
exports.getContainer = getContainer;
|
|
5
|
+
exports.resetContainer = resetContainer;
|
|
6
|
+
exports.createChildContainer = createChildContainer;
|
|
7
|
+
const node_filesystem_provider_1 = require("../abstractions/providers/node-filesystem.provider");
|
|
8
|
+
const config_parser_provider_1 = require("../abstractions/providers/config-parser.provider");
|
|
9
|
+
const logger_provider_1 = require("../abstractions/providers/logger.provider");
|
|
10
|
+
class DIContainer {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.registrations = new Map();
|
|
13
|
+
this.configParserProviders = new Map();
|
|
14
|
+
this.registerDefaultProviders();
|
|
15
|
+
}
|
|
16
|
+
registerDefaultProviders() {
|
|
17
|
+
this.registerInstance('ILoggerProvider', new logger_provider_1.NestLoggerProvider());
|
|
18
|
+
this.registerInstance('IFileSystemProvider', new node_filesystem_provider_1.NodeFileSystemProvider());
|
|
19
|
+
this.registerInstance('yaml', new config_parser_provider_1.YamlConfigParserProvider());
|
|
20
|
+
this.registerInstance('json', new config_parser_provider_1.JsonConfigParserProvider());
|
|
21
|
+
}
|
|
22
|
+
registerInstance(id, instance) {
|
|
23
|
+
this.registrations.set(id, { instance, scope: 'singleton' });
|
|
24
|
+
}
|
|
25
|
+
registerSingleton(id, factory) {
|
|
26
|
+
this.registrations.set(id, { factory, scope: 'singleton' });
|
|
27
|
+
}
|
|
28
|
+
registerTransient(id, factory) {
|
|
29
|
+
this.registrations.set(id, { factory, scope: 'transient' });
|
|
30
|
+
}
|
|
31
|
+
resolve(id) {
|
|
32
|
+
const registration = this.registrations.get(id);
|
|
33
|
+
if (!registration) {
|
|
34
|
+
throw new Error(`Service not registered: ${String(id)}`);
|
|
35
|
+
}
|
|
36
|
+
if (registration.scope === 'singleton' && registration.instance) {
|
|
37
|
+
return registration.instance;
|
|
38
|
+
}
|
|
39
|
+
if (registration.factory) {
|
|
40
|
+
const instance = registration.factory();
|
|
41
|
+
if (registration.scope === 'singleton') {
|
|
42
|
+
registration.instance = instance;
|
|
43
|
+
}
|
|
44
|
+
return instance;
|
|
45
|
+
}
|
|
46
|
+
throw new Error(`Cannot resolve service: ${String(id)}`);
|
|
47
|
+
}
|
|
48
|
+
createLogger(context) {
|
|
49
|
+
return this.resolve('ILoggerProvider').createLogger(context);
|
|
50
|
+
}
|
|
51
|
+
createFileSystem() {
|
|
52
|
+
return this.resolve('IFileSystemProvider').createFileSystem();
|
|
53
|
+
}
|
|
54
|
+
createConfigParser(format = 'yaml') {
|
|
55
|
+
const provider = this.configParserProviders.get(format) ||
|
|
56
|
+
this.resolve(format);
|
|
57
|
+
return provider.createConfigParser(format);
|
|
58
|
+
}
|
|
59
|
+
setLoggerProvider(provider) {
|
|
60
|
+
this.registerInstance('ILoggerProvider', provider);
|
|
61
|
+
}
|
|
62
|
+
setFileSystemProvider(provider) {
|
|
63
|
+
this.registerInstance('IFileSystemProvider', provider);
|
|
64
|
+
}
|
|
65
|
+
setConfigParserProvider(format, provider) {
|
|
66
|
+
this.configParserProviders.set(format, provider);
|
|
67
|
+
this.registerInstance(format, provider);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
exports.DIContainer = DIContainer;
|
|
71
|
+
let globalContainer = null;
|
|
72
|
+
function getContainer() {
|
|
73
|
+
if (!globalContainer) {
|
|
74
|
+
globalContainer = new DIContainer();
|
|
75
|
+
}
|
|
76
|
+
return globalContainer;
|
|
77
|
+
}
|
|
78
|
+
function resetContainer() {
|
|
79
|
+
globalContainer = null;
|
|
80
|
+
}
|
|
81
|
+
function createChildContainer() {
|
|
82
|
+
const child = new DIContainer();
|
|
83
|
+
child.setLoggerProvider(getContainer().resolve('ILoggerProvider'));
|
|
84
|
+
child.setFileSystemProvider(getContainer().resolve('IFileSystemProvider'));
|
|
85
|
+
return child;
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=container.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"container.js","sourceRoot":"","sources":["../../../src/core/di/container.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const container_1 = require("./container");
|
|
4
|
+
const createMockFileSystem = () => {
|
|
5
|
+
const mock = () => mock;
|
|
6
|
+
return {
|
|
7
|
+
exists: mock(),
|
|
8
|
+
existsSync: () => true,
|
|
9
|
+
readFile: mock(),
|
|
10
|
+
readJson: mock(),
|
|
11
|
+
writeFile: mock(),
|
|
12
|
+
writeJson: mock(),
|
|
13
|
+
readdir: mock(),
|
|
14
|
+
readdirNames: mock(),
|
|
15
|
+
remove: mock(),
|
|
16
|
+
ensureDir: mock(),
|
|
17
|
+
stat: mock(),
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
describe('DIContainer', () => {
|
|
21
|
+
let container;
|
|
22
|
+
beforeEach(() => {
|
|
23
|
+
(0, container_1.resetContainer)();
|
|
24
|
+
container = new container_1.DIContainer();
|
|
25
|
+
});
|
|
26
|
+
afterEach(() => {
|
|
27
|
+
(0, container_1.resetContainer)();
|
|
28
|
+
});
|
|
29
|
+
describe('registerInstance', () => {
|
|
30
|
+
it('should register and resolve instance', () => {
|
|
31
|
+
const instance = { value: 'test' };
|
|
32
|
+
container.registerInstance('test-service', instance);
|
|
33
|
+
const resolved = container.resolve('test-service');
|
|
34
|
+
expect(resolved).toBe(instance);
|
|
35
|
+
});
|
|
36
|
+
it('should throw when resolving unregistered service', () => {
|
|
37
|
+
expect(() => container.resolve('non-existent')).toThrow('Service not registered');
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
describe('registerSingleton', () => {
|
|
41
|
+
it('should create singleton via factory', () => {
|
|
42
|
+
let callCount = 0;
|
|
43
|
+
container.registerSingleton('counter', () => {
|
|
44
|
+
callCount++;
|
|
45
|
+
return { count: callCount };
|
|
46
|
+
});
|
|
47
|
+
const instance1 = container.resolve('counter');
|
|
48
|
+
const instance2 = container.resolve('counter');
|
|
49
|
+
expect(instance1).toBe(instance2);
|
|
50
|
+
expect(callCount).toBe(1);
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
describe('registerTransient', () => {
|
|
54
|
+
it('should create new instance each time', () => {
|
|
55
|
+
let callCount = 0;
|
|
56
|
+
container.registerTransient('transient-service', () => {
|
|
57
|
+
callCount++;
|
|
58
|
+
return { id: callCount };
|
|
59
|
+
});
|
|
60
|
+
const instance1 = container.resolve('transient-service');
|
|
61
|
+
const instance2 = container.resolve('transient-service');
|
|
62
|
+
expect(instance1).not.toBe(instance2);
|
|
63
|
+
expect(instance1.id).toBe(1);
|
|
64
|
+
expect(instance2.id).toBe(2);
|
|
65
|
+
expect(callCount).toBe(2);
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
describe('createLogger', () => {
|
|
69
|
+
it('should create logger via provider', () => {
|
|
70
|
+
const logger = container.createLogger('TestContext');
|
|
71
|
+
expect(logger).toBeDefined();
|
|
72
|
+
expect(typeof logger.info).toBe('function');
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
describe('createFileSystem', () => {
|
|
76
|
+
it('should create file system via provider', () => {
|
|
77
|
+
const fs = container.createFileSystem();
|
|
78
|
+
expect(fs).toBeDefined();
|
|
79
|
+
expect(typeof fs.exists).toBe('function');
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
describe('createConfigParser', () => {
|
|
83
|
+
it('should create config parser for yaml', () => {
|
|
84
|
+
const parser = container.createConfigParser('yaml');
|
|
85
|
+
expect(parser).toBeDefined();
|
|
86
|
+
expect(typeof parser.parse).toBe('function');
|
|
87
|
+
});
|
|
88
|
+
it('should create config parser for json', () => {
|
|
89
|
+
const parser = container.createConfigParser('json');
|
|
90
|
+
expect(parser).toBeDefined();
|
|
91
|
+
expect(typeof parser.parse).toBe('function');
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
describe('setLoggerProvider', () => {
|
|
95
|
+
it('should replace logger provider', () => {
|
|
96
|
+
const mockProvider = {
|
|
97
|
+
createLogger: (context) => ({ info: jest.fn(), warn: jest.fn(), error: jest.fn(), debug: jest.fn() }),
|
|
98
|
+
};
|
|
99
|
+
container.setLoggerProvider(mockProvider);
|
|
100
|
+
const logger = container.createLogger('new-context');
|
|
101
|
+
expect(logger).toBeDefined();
|
|
102
|
+
});
|
|
103
|
+
});
|
|
104
|
+
describe('setFileSystemProvider', () => {
|
|
105
|
+
it('should replace file system provider', () => {
|
|
106
|
+
const mockProvider = {
|
|
107
|
+
createFileSystem: () => createMockFileSystem(),
|
|
108
|
+
};
|
|
109
|
+
container.setFileSystemProvider(mockProvider);
|
|
110
|
+
const fs = container.createFileSystem();
|
|
111
|
+
expect(fs).toBeDefined();
|
|
112
|
+
});
|
|
113
|
+
});
|
|
114
|
+
describe('global container', () => {
|
|
115
|
+
it('should return same instance with getContainer', () => {
|
|
116
|
+
const container1 = (0, container_1.getContainer)();
|
|
117
|
+
const container2 = (0, container_1.getContainer)();
|
|
118
|
+
expect(container1).toBe(container2);
|
|
119
|
+
});
|
|
120
|
+
it('should reset container with resetContainer', () => {
|
|
121
|
+
const container1 = (0, container_1.getContainer)();
|
|
122
|
+
(0, container_1.resetContainer)();
|
|
123
|
+
const container2 = (0, container_1.getContainer)();
|
|
124
|
+
expect(container1).not.toBe(container2);
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
describe('createChildContainer', () => {
|
|
128
|
+
it('should inherit providers from parent', () => {
|
|
129
|
+
const parent = (0, container_1.getContainer)();
|
|
130
|
+
const child = (0, container_1.createChildContainer)();
|
|
131
|
+
expect(child).toBeDefined();
|
|
132
|
+
const logger = child.createLogger('child');
|
|
133
|
+
expect(logger).toBeDefined();
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
//# sourceMappingURL=container.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"container.spec.js","sourceRoot":"","sources":["../../../src/core/di/container.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export declare class EvolithError extends Error {
|
|
2
|
+
code: string;
|
|
3
|
+
context?: Record<string, unknown>;
|
|
4
|
+
constructor(message: string, code: string, context?: Record<string, unknown>);
|
|
5
|
+
}
|
|
6
|
+
export declare class PlatformNotFoundError extends EvolithError {
|
|
7
|
+
constructor(platform: string, hint?: string);
|
|
8
|
+
}
|
|
9
|
+
export declare class PhaseTransitionError extends EvolithError {
|
|
10
|
+
constructor(from: string, to: string, reason: string);
|
|
11
|
+
}
|
|
12
|
+
export declare class CatalogLoadError extends EvolithError {
|
|
13
|
+
constructor(catalog: string, cause: string);
|
|
14
|
+
}
|
|
15
|
+
export declare class ToolValidationError extends EvolithError {
|
|
16
|
+
constructor(tool: string, reason: string);
|
|
17
|
+
}
|
|
18
|
+
export declare class CommandExecutionError extends EvolithError {
|
|
19
|
+
constructor(command: string, exitCode: number, stderr: string);
|
|
20
|
+
}
|
|
21
|
+
export declare class ValidationError extends EvolithError {
|
|
22
|
+
constructor(errors: string[]);
|
|
23
|
+
}
|
|
24
|
+
export declare function isEvolithError(error: unknown): error is EvolithError;
|
|
25
|
+
export declare function getErrorCode(error: unknown): string;
|
|
26
|
+
export declare function getErrorContext(error: unknown): Record<string, unknown> | undefined;
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ValidationError = exports.CommandExecutionError = exports.ToolValidationError = exports.CatalogLoadError = exports.PhaseTransitionError = exports.PlatformNotFoundError = exports.EvolithError = void 0;
|
|
4
|
+
exports.isEvolithError = isEvolithError;
|
|
5
|
+
exports.getErrorCode = getErrorCode;
|
|
6
|
+
exports.getErrorContext = getErrorContext;
|
|
7
|
+
class EvolithError extends Error {
|
|
8
|
+
constructor(message, code, context) {
|
|
9
|
+
super(message);
|
|
10
|
+
this.code = code;
|
|
11
|
+
this.context = context;
|
|
12
|
+
this.name = 'EvolithError';
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.EvolithError = EvolithError;
|
|
16
|
+
class PlatformNotFoundError extends EvolithError {
|
|
17
|
+
constructor(platform, hint) {
|
|
18
|
+
super(`${platform} not found in PATH`, 'PLATFORM_NOT_FOUND', { platform, hint });
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
exports.PlatformNotFoundError = PlatformNotFoundError;
|
|
22
|
+
class PhaseTransitionError extends EvolithError {
|
|
23
|
+
constructor(from, to, reason) {
|
|
24
|
+
super(`Cannot transition from ${from} to ${to}: ${reason}`, 'PHASE_TRANSITION_ERROR', { from, to, reason });
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
exports.PhaseTransitionError = PhaseTransitionError;
|
|
28
|
+
class CatalogLoadError extends EvolithError {
|
|
29
|
+
constructor(catalog, cause) {
|
|
30
|
+
super(`Failed to load catalog ${catalog}: ${cause}`, 'CATALOG_LOAD_ERROR', { catalog });
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
exports.CatalogLoadError = CatalogLoadError;
|
|
34
|
+
class ToolValidationError extends EvolithError {
|
|
35
|
+
constructor(tool, reason) {
|
|
36
|
+
super(`Tool ${tool} validation failed: ${reason}`, 'TOOL_VALIDATION_ERROR', { tool });
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
exports.ToolValidationError = ToolValidationError;
|
|
40
|
+
class CommandExecutionError extends EvolithError {
|
|
41
|
+
constructor(command, exitCode, stderr) {
|
|
42
|
+
super(`Command "${command}" failed with exit code ${exitCode}: ${stderr}`, 'COMMAND_EXECUTION_ERROR', { command, exitCode, stderr });
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.CommandExecutionError = CommandExecutionError;
|
|
46
|
+
class ValidationError extends EvolithError {
|
|
47
|
+
constructor(errors) {
|
|
48
|
+
super(`Validation failed: ${errors.join(', ')}`, 'VALIDATION_ERROR', { errors });
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
exports.ValidationError = ValidationError;
|
|
52
|
+
function isEvolithError(error) {
|
|
53
|
+
return error instanceof EvolithError;
|
|
54
|
+
}
|
|
55
|
+
function getErrorCode(error) {
|
|
56
|
+
if (isEvolithError(error)) {
|
|
57
|
+
return error.code;
|
|
58
|
+
}
|
|
59
|
+
return 'UNKNOWN_ERROR';
|
|
60
|
+
}
|
|
61
|
+
function getErrorContext(error) {
|
|
62
|
+
if (isEvolithError(error)) {
|
|
63
|
+
return error.context;
|
|
64
|
+
}
|
|
65
|
+
return undefined;
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/errors/index.ts"],"names":[],"mappings":";;;AAuEA,wCAEC;AAED,oCAKC;AAED,0CAKC;AAvFD,MAAa,YAAa,SAAQ,KAAK;IACrC,YACE,OAAe,EACR,IAAY,EACZ,OAAiC;QAExC,KAAK,CAAC,OAAO,CAAC,CAAC;QAHR,SAAI,GAAJ,IAAI,CAAQ;QACZ,YAAO,GAAP,OAAO,CAA0B;QAGxC,IAAI,CAAC,IAAI,GAAG,cAAc,CAAC;IAC7B,CAAC;CACF;AATD,oCASC;AAED,MAAa,qBAAsB,SAAQ,YAAY;IACrD,YAAY,QAAgB,EAAE,IAAa;QACzC,KAAK,CACH,GAAG,QAAQ,oBAAoB,EAC/B,oBAAoB,EACpB,EAAE,QAAQ,EAAE,IAAI,EAAE,CACnB,CAAC;IACJ,CAAC;CACF;AARD,sDAQC;AAED,MAAa,oBAAqB,SAAQ,YAAY;IACpD,YAAY,IAAY,EAAE,EAAU,EAAE,MAAc;QAClD,KAAK,CACH,0BAA0B,IAAI,OAAO,EAAE,KAAK,MAAM,EAAE,EACpD,wBAAwB,EACxB,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,CACrB,CAAC;IACJ,CAAC;CACF;AARD,oDAQC;AAED,MAAa,gBAAiB,SAAQ,YAAY;IAChD,YAAY,OAAe,EAAE,KAAa;QACxC,KAAK,CACH,0BAA0B,OAAO,KAAK,KAAK,EAAE,EAC7C,oBAAoB,EACpB,EAAE,OAAO,EAAE,CACZ,CAAC;IACJ,CAAC;CACF;AARD,4CAQC;AAED,MAAa,mBAAoB,SAAQ,YAAY;IACnD,YAAY,IAAY,EAAE,MAAc;QACtC,KAAK,CACH,QAAQ,IAAI,uBAAuB,MAAM,EAAE,EAC3C,uBAAuB,EACvB,EAAE,IAAI,EAAE,CACT,CAAC;IACJ,CAAC;CACF;AARD,kDAQC;AAED,MAAa,qBAAsB,SAAQ,YAAY;IACrD,YAAY,OAAe,EAAE,QAAgB,EAAE,MAAc;QAC3D,KAAK,CACH,YAAY,OAAO,2BAA2B,QAAQ,KAAK,MAAM,EAAE,EACnE,yBAAyB,EACzB,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,CAC9B,CAAC;IACJ,CAAC;CACF;AARD,sDAQC;AAED,MAAa,eAAgB,SAAQ,YAAY;IAC/C,YAAY,MAAgB;QAC1B,KAAK,CACH,sBAAsB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,EACzC,kBAAkB,EAClB,EAAE,MAAM,EAAE,CACX,CAAC;IACJ,CAAC;CACF;AARD,0CAQC;AAED,SAAgB,cAAc,CAAC,KAAc;IAC3C,OAAO,KAAK,YAAY,YAAY,CAAC;AACvC,CAAC;AAED,SAAgB,YAAY,CAAC,KAAc;IACzC,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,KAAK,CAAC,IAAI,CAAC;IACpB,CAAC;IACD,OAAO,eAAe,CAAC;AACzB,CAAC;AAED,SAAgB,eAAe,CAAC,KAAc;IAC5C,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,KAAK,CAAC,OAAO,CAAC;IACvB,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC"}
|
|
@@ -0,0 +1,96 @@
|
|
|
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 __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
19
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
20
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
21
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
22
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
23
|
+
};
|
|
24
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
25
|
+
var ownKeys = function(o) {
|
|
26
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
27
|
+
var ar = [];
|
|
28
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
29
|
+
return ar;
|
|
30
|
+
};
|
|
31
|
+
return ownKeys(o);
|
|
32
|
+
};
|
|
33
|
+
return function (mod) {
|
|
34
|
+
if (mod && mod.__esModule) return mod;
|
|
35
|
+
var result = {};
|
|
36
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
37
|
+
__setModuleDefault(result, mod);
|
|
38
|
+
return result;
|
|
39
|
+
};
|
|
40
|
+
})();
|
|
41
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
42
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
43
|
+
};
|
|
44
|
+
var FileManagerService_1;
|
|
45
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
46
|
+
exports.FileManagerService = void 0;
|
|
47
|
+
const common_1 = require("@nestjs/common");
|
|
48
|
+
const fs = __importStar(require("fs-extra"));
|
|
49
|
+
const p = __importStar(require("@clack/prompts"));
|
|
50
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
51
|
+
let FileManagerService = FileManagerService_1 = class FileManagerService {
|
|
52
|
+
constructor() {
|
|
53
|
+
this.logger = new common_1.Logger(FileManagerService_1.name);
|
|
54
|
+
}
|
|
55
|
+
async safeCopy(source, destination, dryRun = false) {
|
|
56
|
+
if (!await fs.pathExists(source)) {
|
|
57
|
+
this.logger.error(`Source file does not exist: ${source}`);
|
|
58
|
+
return false;
|
|
59
|
+
}
|
|
60
|
+
if (await fs.pathExists(destination)) {
|
|
61
|
+
const sourceContent = await fs.readFile(source, 'utf-8');
|
|
62
|
+
const destContent = await fs.readFile(destination, 'utf-8');
|
|
63
|
+
if (sourceContent === destContent) {
|
|
64
|
+
p.log.info(chalk_1.default.gray(`[SKIP] ${destination} ya cumple con el estándar.`));
|
|
65
|
+
return true;
|
|
66
|
+
}
|
|
67
|
+
if (!dryRun) {
|
|
68
|
+
const overwrite = await p.confirm({
|
|
69
|
+
message: `El archivo ${destination} ya existe y es distinto. ¿Deseas sobrescribirlo?`,
|
|
70
|
+
initialValue: false,
|
|
71
|
+
});
|
|
72
|
+
if (!overwrite) {
|
|
73
|
+
p.log.warn(`[SKIP] Omitido: ${destination}`);
|
|
74
|
+
return false;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
p.log.info(chalk_1.default.yellow(`[DRY-RUN] Se sobrescribiría: ${destination}`));
|
|
79
|
+
return true;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
if (!dryRun) {
|
|
83
|
+
await fs.copy(source, destination, { overwrite: true });
|
|
84
|
+
p.log.success(`[CREADO/ACTUALIZADO] ${destination}`);
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
p.log.info(chalk_1.default.yellow(`[DRY-RUN] Se crearía: ${destination}`));
|
|
88
|
+
}
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
exports.FileManagerService = FileManagerService;
|
|
93
|
+
exports.FileManagerService = FileManagerService = FileManagerService_1 = __decorate([
|
|
94
|
+
(0, common_1.Injectable)()
|
|
95
|
+
], FileManagerService);
|
|
96
|
+
//# sourceMappingURL=file-manager.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-manager.service.js","sourceRoot":"","sources":["../../../src/core/filesystem/file-manager.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAAoD;AACpD,6CAA+B;AAE/B,kDAAoC;AACpC,kDAA0B;AAGnB,IAAM,kBAAkB,0BAAxB,MAAM,kBAAkB;IAAxB;QACY,WAAM,GAAG,IAAI,eAAM,CAAC,oBAAkB,CAAC,IAAI,CAAC,CAAC;IA2ChE,CAAC;IAzCC,KAAK,CAAC,QAAQ,CAAC,MAAc,EAAE,WAAmB,EAAE,SAAkB,KAAK;QACzE,IAAI,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,+BAA+B,MAAM,EAAE,CAAC,CAAC;YAC3D,OAAO,KAAK,CAAC;QACf,CAAC;QAED,IAAI,MAAM,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC;YAErC,MAAM,aAAa,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;YACzD,MAAM,WAAW,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YAE5D,IAAI,aAAa,KAAK,WAAW,EAAE,CAAC;gBAClC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,eAAK,CAAC,IAAI,CAAC,UAAU,WAAW,6BAA6B,CAAC,CAAC,CAAC;gBAC3E,OAAO,IAAI,CAAC;YACd,CAAC;YAED,IAAI,CAAC,MAAM,EAAE,CAAC;gBACZ,MAAM,SAAS,GAAG,MAAM,CAAC,CAAC,OAAO,CAAC;oBAChC,OAAO,EAAE,cAAc,WAAW,mDAAmD;oBACrF,YAAY,EAAE,KAAK;iBACpB,CAAC,CAAC;gBAEH,IAAI,CAAC,SAAS,EAAE,CAAC;oBACf,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,mBAAmB,WAAW,EAAE,CAAC,CAAC;oBAC7C,OAAO,KAAK,CAAC;gBACf,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,eAAK,CAAC,MAAM,CAAC,gCAAgC,WAAW,EAAE,CAAC,CAAC,CAAC;gBACxE,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;QAED,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YACxD,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,wBAAwB,WAAW,EAAE,CAAC,CAAC;QACvD,CAAC;aAAM,CAAC;YACN,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,eAAK,CAAC,MAAM,CAAC,yBAAyB,WAAW,EAAE,CAAC,CAAC,CAAC;QACnE,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AA5CY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;GACA,kBAAkB,CA4C9B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,103 @@
|
|
|
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
|
+
const testing_1 = require("@nestjs/testing");
|
|
37
|
+
const file_manager_service_1 = require("./file-manager.service");
|
|
38
|
+
const fs = __importStar(require("fs-extra"));
|
|
39
|
+
const p = __importStar(require("@clack/prompts"));
|
|
40
|
+
jest.mock('fs-extra');
|
|
41
|
+
jest.mock('@clack/prompts');
|
|
42
|
+
describe('FileManagerService', () => {
|
|
43
|
+
let service;
|
|
44
|
+
beforeEach(async () => {
|
|
45
|
+
const module = await testing_1.Test.createTestingModule({
|
|
46
|
+
providers: [file_manager_service_1.FileManagerService],
|
|
47
|
+
}).compile();
|
|
48
|
+
service = module.get(file_manager_service_1.FileManagerService);
|
|
49
|
+
jest.clearAllMocks();
|
|
50
|
+
});
|
|
51
|
+
it('should be defined', () => {
|
|
52
|
+
expect(service).toBeDefined();
|
|
53
|
+
});
|
|
54
|
+
it('should return false if source does not exist', async () => {
|
|
55
|
+
fs.pathExists.mockResolvedValueOnce(false);
|
|
56
|
+
const result = await service.safeCopy('src', 'dest');
|
|
57
|
+
expect(result).toBe(false);
|
|
58
|
+
});
|
|
59
|
+
it('should skip if destination exists and contents are identical', async () => {
|
|
60
|
+
fs.pathExists.mockResolvedValue(true);
|
|
61
|
+
fs.readFile.mockResolvedValue('same content');
|
|
62
|
+
const result = await service.safeCopy('src', 'dest');
|
|
63
|
+
expect(result).toBe(true);
|
|
64
|
+
expect(fs.copy).not.toHaveBeenCalled();
|
|
65
|
+
});
|
|
66
|
+
it('should ask for confirmation if destination exists and contents differ (not dry-run)', async () => {
|
|
67
|
+
fs.pathExists.mockResolvedValue(true);
|
|
68
|
+
fs.readFile
|
|
69
|
+
.mockResolvedValueOnce('source content')
|
|
70
|
+
.mockResolvedValueOnce('dest content');
|
|
71
|
+
p.confirm.mockResolvedValueOnce(false);
|
|
72
|
+
const result = await service.safeCopy('src', 'dest', false);
|
|
73
|
+
expect(result).toBe(false);
|
|
74
|
+
expect(fs.copy).not.toHaveBeenCalled();
|
|
75
|
+
});
|
|
76
|
+
it('should overwrite if user confirms', async () => {
|
|
77
|
+
fs.pathExists.mockResolvedValue(true);
|
|
78
|
+
fs.readFile
|
|
79
|
+
.mockResolvedValueOnce('source content')
|
|
80
|
+
.mockResolvedValueOnce('dest content');
|
|
81
|
+
p.confirm.mockResolvedValueOnce(true);
|
|
82
|
+
const result = await service.safeCopy('src', 'dest', false);
|
|
83
|
+
expect(result).toBe(true);
|
|
84
|
+
expect(fs.copy).toHaveBeenCalledWith('src', 'dest', { overwrite: true });
|
|
85
|
+
});
|
|
86
|
+
it('should copy if destination does not exist', async () => {
|
|
87
|
+
fs.pathExists
|
|
88
|
+
.mockResolvedValueOnce(true)
|
|
89
|
+
.mockResolvedValueOnce(false);
|
|
90
|
+
const result = await service.safeCopy('src', 'dest', false);
|
|
91
|
+
expect(result).toBe(true);
|
|
92
|
+
expect(fs.copy).toHaveBeenCalledWith('src', 'dest', { overwrite: true });
|
|
93
|
+
});
|
|
94
|
+
it('should not copy if in dry-run mode', async () => {
|
|
95
|
+
fs.pathExists
|
|
96
|
+
.mockResolvedValueOnce(true)
|
|
97
|
+
.mockResolvedValueOnce(false);
|
|
98
|
+
const result = await service.safeCopy('src', 'dest', true);
|
|
99
|
+
expect(result).toBe(true);
|
|
100
|
+
expect(fs.copy).not.toHaveBeenCalled();
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
//# sourceMappingURL=file-manager.service.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-manager.service.spec.js","sourceRoot":"","sources":["../../../src/core/filesystem/file-manager.service.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var McpServerService_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.McpServerService = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
let McpServerService = McpServerService_1 = class McpServerService {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.logger = new common_1.Logger(McpServerService_1.name);
|
|
15
|
+
}
|
|
16
|
+
onModuleInit() {
|
|
17
|
+
this.startServer();
|
|
18
|
+
}
|
|
19
|
+
startServer() {
|
|
20
|
+
this.logger.log('Iniciando servidor MCP (Model Context Protocol) para integración con Antigravity / VSCode (OpenCode Style)...');
|
|
21
|
+
this.logger.log('Servidor MCP en escucha en el puerto local 49100');
|
|
22
|
+
}
|
|
23
|
+
onModuleDestroy() {
|
|
24
|
+
this.logger.log('Servidor MCP detenido.');
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
exports.McpServerService = McpServerService;
|
|
28
|
+
exports.McpServerService = McpServerService = McpServerService_1 = __decorate([
|
|
29
|
+
(0, common_1.Injectable)()
|
|
30
|
+
], McpServerService);
|
|
31
|
+
//# sourceMappingURL=mcp-server.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-server.service.js","sourceRoot":"","sources":["../../../src/core/mcp/mcp-server.service.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAmF;AAG5E,IAAM,gBAAgB,wBAAtB,MAAM,gBAAgB;IAAtB;QACY,WAAM,GAAG,IAAI,eAAM,CAAC,kBAAgB,CAAC,IAAI,CAAC,CAAC;IAkB9D,CAAC;IAhBC,YAAY;QAEV,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,+GAA+G,CAAC,CAAC;QAIjI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,kDAAkD,CAAC,CAAC;IACtE,CAAC;IAED,eAAe;QACb,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;IAC5C,CAAC;CACF,CAAA;AAnBY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,mBAAU,GAAE;GACA,gBAAgB,CAmB5B"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export interface ToolMetrics {
|
|
2
|
+
toolName: string;
|
|
3
|
+
callCount: number;
|
|
4
|
+
successCount: number;
|
|
5
|
+
errorCount: number;
|
|
6
|
+
totalLatencyMs: number;
|
|
7
|
+
lastCalled: string;
|
|
8
|
+
}
|
|
9
|
+
export interface McpMetrics {
|
|
10
|
+
serverStartTime: string;
|
|
11
|
+
totalRequests: number;
|
|
12
|
+
toolMetrics: Map<string, ToolMetrics>;
|
|
13
|
+
errorMetrics: Map<string, number>;
|
|
14
|
+
}
|
|
15
|
+
export declare class McpMetricsService {
|
|
16
|
+
private readonly logger;
|
|
17
|
+
private metrics;
|
|
18
|
+
constructor();
|
|
19
|
+
recordToolCall(toolName: string, latencyMs: number, success: boolean): void;
|
|
20
|
+
recordError(errorCode: string): void;
|
|
21
|
+
getMetrics(): McpMetricsSnapshot;
|
|
22
|
+
getToolMetrics(toolName: string): ToolMetrics | undefined;
|
|
23
|
+
reset(): void;
|
|
24
|
+
}
|
|
25
|
+
export interface McpMetricsSnapshot {
|
|
26
|
+
serverStartTime: string;
|
|
27
|
+
uptimeMs: number;
|
|
28
|
+
totalRequests: number;
|
|
29
|
+
toolMetrics: Array<ToolMetrics & {
|
|
30
|
+
averageLatencyMs: number;
|
|
31
|
+
errorRate: string;
|
|
32
|
+
}>;
|
|
33
|
+
topErrors: Array<{
|
|
34
|
+
code: string;
|
|
35
|
+
count: number;
|
|
36
|
+
}>;
|
|
37
|
+
}
|