codingbuddy 0.0.0-canary.20251219012535.c6f28a6 → 0.0.0-canary.20251219020448.5f0fa81

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 (60) hide show
  1. package/dist/src/cli/cli.d.ts +10 -0
  2. package/dist/src/cli/cli.js +98 -0
  3. package/dist/src/cli/cli.js.map +1 -0
  4. package/dist/src/cli/cli.spec.d.ts +1 -0
  5. package/dist/src/cli/cli.spec.js +84 -0
  6. package/dist/src/cli/cli.spec.js.map +1 -0
  7. package/dist/src/cli/cli.types.d.ts +18 -0
  8. package/dist/src/cli/cli.types.js +3 -0
  9. package/dist/src/cli/cli.types.js.map +1 -0
  10. package/dist/src/cli/index.d.ts +6 -0
  11. package/dist/src/cli/index.js +15 -0
  12. package/dist/src/cli/index.js.map +1 -0
  13. package/dist/src/cli/init/config.generator.d.ts +16 -0
  14. package/dist/src/cli/init/config.generator.js +70 -0
  15. package/dist/src/cli/init/config.generator.js.map +1 -0
  16. package/dist/src/cli/init/config.generator.spec.d.ts +1 -0
  17. package/dist/src/cli/init/config.generator.spec.js +182 -0
  18. package/dist/src/cli/init/config.generator.spec.js.map +1 -0
  19. package/dist/src/cli/init/config.writer.d.ts +10 -0
  20. package/dist/src/cli/init/config.writer.js +40 -0
  21. package/dist/src/cli/init/config.writer.js.map +1 -0
  22. package/dist/src/cli/init/config.writer.spec.d.ts +1 -0
  23. package/dist/src/cli/init/config.writer.spec.js +112 -0
  24. package/dist/src/cli/init/config.writer.spec.js.map +1 -0
  25. package/dist/src/cli/init/index.d.ts +5 -0
  26. package/dist/src/cli/init/index.js +16 -0
  27. package/dist/src/cli/init/index.js.map +1 -0
  28. package/dist/src/cli/init/init.command.d.ts +3 -0
  29. package/dist/src/cli/init/init.command.js +80 -0
  30. package/dist/src/cli/init/init.command.js.map +1 -0
  31. package/dist/src/cli/init/init.command.spec.d.ts +1 -0
  32. package/dist/src/cli/init/init.command.spec.js +227 -0
  33. package/dist/src/cli/init/init.command.spec.js.map +1 -0
  34. package/dist/src/cli/init/prompt.builder.d.ts +7 -0
  35. package/dist/src/cli/init/prompt.builder.js +222 -0
  36. package/dist/src/cli/init/prompt.builder.js.map +1 -0
  37. package/dist/src/cli/init/prompt.builder.spec.d.ts +1 -0
  38. package/dist/src/cli/init/prompt.builder.spec.js +199 -0
  39. package/dist/src/cli/init/prompt.builder.spec.js.map +1 -0
  40. package/dist/src/cli/utils/console.d.ts +18 -0
  41. package/dist/src/cli/utils/console.js +83 -0
  42. package/dist/src/cli/utils/console.js.map +1 -0
  43. package/dist/src/cli/utils/console.spec.d.ts +1 -0
  44. package/dist/src/cli/utils/console.spec.js +100 -0
  45. package/dist/src/cli/utils/console.spec.js.map +1 -0
  46. package/dist/src/cli/utils/index.d.ts +2 -0
  47. package/dist/src/cli/utils/index.js +7 -0
  48. package/dist/src/cli/utils/index.js.map +1 -0
  49. package/dist/src/config/config.schema.d.ts +30 -30
  50. package/dist/src/main.js +0 -0
  51. package/dist/src/mcp/mcp.module.js +2 -1
  52. package/dist/src/mcp/mcp.module.js.map +1 -1
  53. package/dist/src/mcp/mcp.service.d.ts +10 -1
  54. package/dist/src/mcp/mcp.service.js +139 -64
  55. package/dist/src/mcp/mcp.service.js.map +1 -1
  56. package/dist/src/mcp/mcp.service.spec.d.ts +1 -0
  57. package/dist/src/mcp/mcp.service.spec.js +262 -0
  58. package/dist/src/mcp/mcp.service.spec.js.map +1 -0
  59. package/dist/tsconfig.tsbuildinfo +1 -1
  60. package/package.json +7 -5
@@ -0,0 +1,100 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const console_1 = require("./console");
5
+ (0, vitest_1.describe)('console utils', () => {
6
+ let consoleUtils;
7
+ let stdoutWrite;
8
+ let stderrWrite;
9
+ (0, vitest_1.beforeEach)(() => {
10
+ stdoutWrite = vitest_1.vi.spyOn(process.stdout, 'write').mockImplementation(() => true);
11
+ stderrWrite = vitest_1.vi.spyOn(process.stderr, 'write').mockImplementation(() => true);
12
+ consoleUtils = (0, console_1.createConsoleUtils)();
13
+ });
14
+ (0, vitest_1.afterEach)(() => {
15
+ vitest_1.vi.restoreAllMocks();
16
+ });
17
+ (0, vitest_1.describe)('log', () => {
18
+ (0, vitest_1.it)('should output info message', () => {
19
+ consoleUtils.log.info('Test message');
20
+ (0, vitest_1.expect)(stdoutWrite).toHaveBeenCalled();
21
+ const output = stdoutWrite.mock.calls[0][0];
22
+ (0, vitest_1.expect)(output).toContain('Test message');
23
+ });
24
+ (0, vitest_1.it)('should output success message with checkmark', () => {
25
+ consoleUtils.log.success('Success message');
26
+ (0, vitest_1.expect)(stdoutWrite).toHaveBeenCalled();
27
+ const output = stdoutWrite.mock.calls[0][0];
28
+ (0, vitest_1.expect)(output).toContain('Success message');
29
+ (0, vitest_1.expect)(output).toContain('✓');
30
+ });
31
+ (0, vitest_1.it)('should output warning message', () => {
32
+ consoleUtils.log.warn('Warning message');
33
+ (0, vitest_1.expect)(stdoutWrite).toHaveBeenCalled();
34
+ const output = stdoutWrite.mock.calls[0][0];
35
+ (0, vitest_1.expect)(output).toContain('Warning message');
36
+ (0, vitest_1.expect)(output).toContain('⚠');
37
+ });
38
+ (0, vitest_1.it)('should output error message to stderr', () => {
39
+ consoleUtils.log.error('Error message');
40
+ (0, vitest_1.expect)(stderrWrite).toHaveBeenCalled();
41
+ const output = stderrWrite.mock.calls[0][0];
42
+ (0, vitest_1.expect)(output).toContain('Error message');
43
+ (0, vitest_1.expect)(output).toContain('✗');
44
+ });
45
+ (0, vitest_1.it)('should output step with custom emoji', () => {
46
+ consoleUtils.log.step('🔍', 'Analyzing project...');
47
+ (0, vitest_1.expect)(stdoutWrite).toHaveBeenCalled();
48
+ const output = stdoutWrite.mock.calls[0][0];
49
+ (0, vitest_1.expect)(output).toContain('🔍');
50
+ (0, vitest_1.expect)(output).toContain('Analyzing project...');
51
+ });
52
+ });
53
+ (0, vitest_1.describe)('spinner', () => {
54
+ (0, vitest_1.it)('should start spinner with message', () => {
55
+ consoleUtils.spinner.start('Loading...');
56
+ (0, vitest_1.expect)(stdoutWrite).toHaveBeenCalled();
57
+ const output = stdoutWrite.mock.calls[0][0];
58
+ (0, vitest_1.expect)(output).toContain('Loading...');
59
+ });
60
+ (0, vitest_1.it)('should stop spinner and show success', () => {
61
+ consoleUtils.spinner.start('Loading...');
62
+ stdoutWrite.mockClear();
63
+ consoleUtils.spinner.succeed('Done!');
64
+ (0, vitest_1.expect)(stdoutWrite).toHaveBeenCalled();
65
+ const output = stdoutWrite.mock.calls.map((c) => c[0]).join('');
66
+ (0, vitest_1.expect)(output).toContain('Done!');
67
+ (0, vitest_1.expect)(output).toContain('✓');
68
+ });
69
+ (0, vitest_1.it)('should stop spinner and show failure', () => {
70
+ consoleUtils.spinner.start('Loading...');
71
+ stderrWrite.mockClear();
72
+ consoleUtils.spinner.fail('Failed!');
73
+ (0, vitest_1.expect)(stderrWrite).toHaveBeenCalled();
74
+ const output = stderrWrite.mock.calls.map((c) => c[0]).join('');
75
+ (0, vitest_1.expect)(output).toContain('Failed!');
76
+ (0, vitest_1.expect)(output).toContain('✗');
77
+ });
78
+ (0, vitest_1.it)('should stop spinner without message', () => {
79
+ consoleUtils.spinner.start('Loading...');
80
+ stdoutWrite.mockClear();
81
+ consoleUtils.spinner.stop();
82
+ (0, vitest_1.expect)(stdoutWrite).toHaveBeenCalled();
83
+ });
84
+ });
85
+ (0, vitest_1.describe)('formatConfig', () => {
86
+ (0, vitest_1.it)('should format config object as readable output', () => {
87
+ const config = {
88
+ projectName: 'my-app',
89
+ techStack: {
90
+ frontend: ['React'],
91
+ },
92
+ };
93
+ const result = consoleUtils.formatConfig(config);
94
+ (0, vitest_1.expect)(result).toContain('projectName');
95
+ (0, vitest_1.expect)(result).toContain('my-app');
96
+ (0, vitest_1.expect)(result).toContain('React');
97
+ });
98
+ });
99
+ });
100
+ //# sourceMappingURL=console.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"console.spec.js","sourceRoot":"","sources":["../../../../src/cli/utils/console.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export { createConsoleUtils, consoleUtils } from './console';
2
+ export type { ConsoleUtils } from './console';
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.consoleUtils = exports.createConsoleUtils = void 0;
4
+ var console_1 = require("./console");
5
+ Object.defineProperty(exports, "createConsoleUtils", { enumerable: true, get: function () { return console_1.createConsoleUtils; } });
6
+ Object.defineProperty(exports, "consoleUtils", { enumerable: true, get: function () { return console_1.consoleUtils; } });
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/cli/utils/index.ts"],"names":[],"mappings":";;;AAAA,qCAA6D;AAApD,6GAAA,kBAAkB,OAAA;AAAE,uGAAA,YAAY,OAAA"}
@@ -37,16 +37,16 @@ export declare const NamingConventionSchema: z.ZodObject<{
37
37
  types: z.ZodOptional<z.ZodEnum<["PascalCase"]>>;
38
38
  interfaces: z.ZodOptional<z.ZodEnum<["PascalCase", "IPascalCase"]>>;
39
39
  }, "strip", z.ZodTypeAny, {
40
- components?: "kebab-case" | "PascalCase";
41
40
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
41
+ components?: "kebab-case" | "PascalCase";
42
42
  functions?: "camelCase" | "snake_case";
43
43
  variables?: "camelCase" | "snake_case";
44
44
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
45
45
  types?: "PascalCase";
46
46
  interfaces?: "PascalCase" | "IPascalCase";
47
47
  }, {
48
- components?: "kebab-case" | "PascalCase";
49
48
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
49
+ components?: "kebab-case" | "PascalCase";
50
50
  functions?: "camelCase" | "snake_case";
51
51
  variables?: "camelCase" | "snake_case";
52
52
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
@@ -74,24 +74,24 @@ export declare const TechStackConfigSchema: z.ZodObject<{
74
74
  notes?: string;
75
75
  }>>>;
76
76
  }, "strip", z.ZodTypeAny, {
77
- tools?: string[];
77
+ languages?: string[];
78
78
  frontend?: string[];
79
79
  backend?: string[];
80
80
  database?: string[];
81
- languages?: string[];
82
81
  infrastructure?: string[];
82
+ tools?: string[];
83
83
  details?: Record<string, {
84
84
  version?: string;
85
85
  config?: Record<string, unknown>;
86
86
  notes?: string;
87
87
  }>;
88
88
  }, {
89
- tools?: string[];
89
+ languages?: string[];
90
90
  frontend?: string[];
91
91
  backend?: string[];
92
92
  database?: string[];
93
- languages?: string[];
94
93
  infrastructure?: string[];
94
+ tools?: string[];
95
95
  details?: Record<string, {
96
96
  version?: string;
97
97
  config?: Record<string, unknown>;
@@ -150,16 +150,16 @@ export declare const ConventionsConfigSchema: z.ZodObject<{
150
150
  types: z.ZodOptional<z.ZodEnum<["PascalCase"]>>;
151
151
  interfaces: z.ZodOptional<z.ZodEnum<["PascalCase", "IPascalCase"]>>;
152
152
  }, "strip", z.ZodTypeAny, {
153
- components?: "kebab-case" | "PascalCase";
154
153
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
154
+ components?: "kebab-case" | "PascalCase";
155
155
  functions?: "camelCase" | "snake_case";
156
156
  variables?: "camelCase" | "snake_case";
157
157
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
158
158
  types?: "PascalCase";
159
159
  interfaces?: "PascalCase" | "IPascalCase";
160
160
  }, {
161
- components?: "kebab-case" | "PascalCase";
162
161
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
162
+ components?: "kebab-case" | "PascalCase";
163
163
  functions?: "camelCase" | "snake_case";
164
164
  variables?: "camelCase" | "snake_case";
165
165
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
@@ -175,8 +175,8 @@ export declare const ConventionsConfigSchema: z.ZodObject<{
175
175
  rules?: Record<string, unknown>;
176
176
  style?: string;
177
177
  naming?: {
178
- components?: "kebab-case" | "PascalCase";
179
178
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
179
+ components?: "kebab-case" | "PascalCase";
180
180
  functions?: "camelCase" | "snake_case";
181
181
  variables?: "camelCase" | "snake_case";
182
182
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
@@ -191,8 +191,8 @@ export declare const ConventionsConfigSchema: z.ZodObject<{
191
191
  rules?: Record<string, unknown>;
192
192
  style?: string;
193
193
  naming?: {
194
- components?: "kebab-case" | "PascalCase";
195
194
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
195
+ components?: "kebab-case" | "PascalCase";
196
196
  functions?: "camelCase" | "snake_case";
197
197
  variables?: "camelCase" | "snake_case";
198
198
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
@@ -212,16 +212,16 @@ export declare const TestStrategyConfigSchema: z.ZodObject<{
212
212
  e2eDirectory: z.ZodOptional<z.ZodString>;
213
213
  mockingStrategy: z.ZodOptional<z.ZodEnum<["minimal", "extensive", "no-mocks"]>>;
214
214
  }, "strip", z.ZodTypeAny, {
215
- coverage?: number;
216
215
  approach?: "tdd" | "bdd" | "test-after" | "mixed";
217
216
  frameworks?: string[];
217
+ coverage?: number;
218
218
  unitTestPattern?: "colocated" | "separate";
219
219
  e2eDirectory?: string;
220
220
  mockingStrategy?: "minimal" | "extensive" | "no-mocks";
221
221
  }, {
222
- coverage?: number;
223
222
  approach?: "tdd" | "bdd" | "test-after" | "mixed";
224
223
  frameworks?: string[];
224
+ coverage?: number;
225
225
  unitTestPattern?: "colocated" | "separate";
226
226
  e2eDirectory?: string;
227
227
  mockingStrategy?: "minimal" | "extensive" | "no-mocks";
@@ -252,24 +252,24 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
252
252
  notes?: string;
253
253
  }>>>;
254
254
  }, "strip", z.ZodTypeAny, {
255
- tools?: string[];
255
+ languages?: string[];
256
256
  frontend?: string[];
257
257
  backend?: string[];
258
258
  database?: string[];
259
- languages?: string[];
260
259
  infrastructure?: string[];
260
+ tools?: string[];
261
261
  details?: Record<string, {
262
262
  version?: string;
263
263
  config?: Record<string, unknown>;
264
264
  notes?: string;
265
265
  }>;
266
266
  }, {
267
- tools?: string[];
267
+ languages?: string[];
268
268
  frontend?: string[];
269
269
  backend?: string[];
270
270
  database?: string[];
271
- languages?: string[];
272
271
  infrastructure?: string[];
272
+ tools?: string[];
273
273
  details?: Record<string, {
274
274
  version?: string;
275
275
  config?: Record<string, unknown>;
@@ -328,16 +328,16 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
328
328
  types: z.ZodOptional<z.ZodEnum<["PascalCase"]>>;
329
329
  interfaces: z.ZodOptional<z.ZodEnum<["PascalCase", "IPascalCase"]>>;
330
330
  }, "strip", z.ZodTypeAny, {
331
- components?: "kebab-case" | "PascalCase";
332
331
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
332
+ components?: "kebab-case" | "PascalCase";
333
333
  functions?: "camelCase" | "snake_case";
334
334
  variables?: "camelCase" | "snake_case";
335
335
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
336
336
  types?: "PascalCase";
337
337
  interfaces?: "PascalCase" | "IPascalCase";
338
338
  }, {
339
- components?: "kebab-case" | "PascalCase";
340
339
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
340
+ components?: "kebab-case" | "PascalCase";
341
341
  functions?: "camelCase" | "snake_case";
342
342
  variables?: "camelCase" | "snake_case";
343
343
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
@@ -353,8 +353,8 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
353
353
  rules?: Record<string, unknown>;
354
354
  style?: string;
355
355
  naming?: {
356
- components?: "kebab-case" | "PascalCase";
357
356
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
357
+ components?: "kebab-case" | "PascalCase";
358
358
  functions?: "camelCase" | "snake_case";
359
359
  variables?: "camelCase" | "snake_case";
360
360
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
@@ -369,8 +369,8 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
369
369
  rules?: Record<string, unknown>;
370
370
  style?: string;
371
371
  naming?: {
372
- components?: "kebab-case" | "PascalCase";
373
372
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
373
+ components?: "kebab-case" | "PascalCase";
374
374
  functions?: "camelCase" | "snake_case";
375
375
  variables?: "camelCase" | "snake_case";
376
376
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
@@ -390,16 +390,16 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
390
390
  e2eDirectory: z.ZodOptional<z.ZodString>;
391
391
  mockingStrategy: z.ZodOptional<z.ZodEnum<["minimal", "extensive", "no-mocks"]>>;
392
392
  }, "strip", z.ZodTypeAny, {
393
- coverage?: number;
394
393
  approach?: "tdd" | "bdd" | "test-after" | "mixed";
395
394
  frameworks?: string[];
395
+ coverage?: number;
396
396
  unitTestPattern?: "colocated" | "separate";
397
397
  e2eDirectory?: string;
398
398
  mockingStrategy?: "minimal" | "extensive" | "no-mocks";
399
399
  }, {
400
- coverage?: number;
401
400
  approach?: "tdd" | "bdd" | "test-after" | "mixed";
402
401
  frameworks?: string[];
402
+ coverage?: number;
403
403
  unitTestPattern?: "colocated" | "separate";
404
404
  e2eDirectory?: string;
405
405
  mockingStrategy?: "minimal" | "extensive" | "no-mocks";
@@ -414,12 +414,12 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
414
414
  projectName?: string;
415
415
  repository?: string;
416
416
  techStack?: {
417
- tools?: string[];
417
+ languages?: string[];
418
418
  frontend?: string[];
419
419
  backend?: string[];
420
420
  database?: string[];
421
- languages?: string[];
422
421
  infrastructure?: string[];
422
+ tools?: string[];
423
423
  details?: Record<string, {
424
424
  version?: string;
425
425
  config?: Record<string, unknown>;
@@ -441,8 +441,8 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
441
441
  rules?: Record<string, unknown>;
442
442
  style?: string;
443
443
  naming?: {
444
- components?: "kebab-case" | "PascalCase";
445
444
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
445
+ components?: "kebab-case" | "PascalCase";
446
446
  functions?: "camelCase" | "snake_case";
447
447
  variables?: "camelCase" | "snake_case";
448
448
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
@@ -455,9 +455,9 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
455
455
  quotes?: "single" | "double";
456
456
  };
457
457
  testStrategy?: {
458
- coverage?: number;
459
458
  approach?: "tdd" | "bdd" | "test-after" | "mixed";
460
459
  frameworks?: string[];
460
+ coverage?: number;
461
461
  unitTestPattern?: "colocated" | "separate";
462
462
  e2eDirectory?: string;
463
463
  mockingStrategy?: "minimal" | "extensive" | "no-mocks";
@@ -471,12 +471,12 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
471
471
  projectName?: string;
472
472
  repository?: string;
473
473
  techStack?: {
474
- tools?: string[];
474
+ languages?: string[];
475
475
  frontend?: string[];
476
476
  backend?: string[];
477
477
  database?: string[];
478
- languages?: string[];
479
478
  infrastructure?: string[];
479
+ tools?: string[];
480
480
  details?: Record<string, {
481
481
  version?: string;
482
482
  config?: Record<string, unknown>;
@@ -498,8 +498,8 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
498
498
  rules?: Record<string, unknown>;
499
499
  style?: string;
500
500
  naming?: {
501
- components?: "kebab-case" | "PascalCase";
502
501
  files?: "kebab-case" | "camelCase" | "PascalCase" | "snake_case";
502
+ components?: "kebab-case" | "PascalCase";
503
503
  functions?: "camelCase" | "snake_case";
504
504
  variables?: "camelCase" | "snake_case";
505
505
  constants?: "camelCase" | "UPPER_SNAKE_CASE";
@@ -512,9 +512,9 @@ export declare const CodingBuddyConfigSchema: z.ZodObject<{
512
512
  quotes?: "single" | "double";
513
513
  };
514
514
  testStrategy?: {
515
- coverage?: number;
516
515
  approach?: "tdd" | "bdd" | "test-after" | "mixed";
517
516
  frameworks?: string[];
517
+ coverage?: number;
518
518
  unitTestPattern?: "colocated" | "separate";
519
519
  e2eDirectory?: string;
520
520
  mockingStrategy?: "minimal" | "extensive" | "no-mocks";
package/dist/src/main.js CHANGED
File without changes
@@ -12,12 +12,13 @@ const mcp_service_1 = require("./mcp.service");
12
12
  const mcp_controller_1 = require("./mcp.controller");
13
13
  const rules_module_1 = require("../rules/rules.module");
14
14
  const keyword_module_1 = require("../keyword/keyword.module");
15
+ const config_module_1 = require("../config/config.module");
15
16
  let McpModule = class McpModule {
16
17
  };
17
18
  exports.McpModule = McpModule;
18
19
  exports.McpModule = McpModule = __decorate([
19
20
  (0, common_1.Module)({
20
- imports: [rules_module_1.RulesModule, keyword_module_1.KeywordModule],
21
+ imports: [rules_module_1.RulesModule, keyword_module_1.KeywordModule, config_module_1.CodingBuddyConfigModule],
21
22
  controllers: [mcp_controller_1.McpController],
22
23
  providers: [mcp_service_1.McpService],
23
24
  exports: [mcp_service_1.McpService],
@@ -1 +1 @@
1
- {"version":3,"file":"mcp.module.js","sourceRoot":"","sources":["../../../src/mcp/mcp.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,+CAA2C;AAC3C,qDAAiD;AACjD,wDAAoD;AACpD,8DAA0D;AAQnD,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IANrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,0BAAW,EAAE,8BAAa,CAAC;QACrC,WAAW,EAAE,CAAC,8BAAa,CAAC;QAC5B,SAAS,EAAE,CAAC,wBAAU,CAAC;QACvB,OAAO,EAAE,CAAC,wBAAU,CAAC;KACtB,CAAC;GACW,SAAS,CAAG"}
1
+ {"version":3,"file":"mcp.module.js","sourceRoot":"","sources":["../../../src/mcp/mcp.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,+CAA2C;AAC3C,qDAAiD;AACjD,wDAAoD;AACpD,8DAA0D;AAC1D,2DAAkE;AAQ3D,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IANrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,0BAAW,EAAE,8BAAa,EAAE,uCAAuB,CAAC;QAC9D,WAAW,EAAE,CAAC,8BAAa,CAAC;QAC5B,SAAS,EAAE,CAAC,wBAAU,CAAC;QACvB,OAAO,EAAE,CAAC,wBAAU,CAAC;KACtB,CAAC;GACW,SAAS,CAAG"}
@@ -2,12 +2,14 @@ import { OnModuleInit } from '@nestjs/common';
2
2
  import { Server } from '@modelcontextprotocol/sdk/server/index.js';
3
3
  import { RulesService } from '../rules/rules.service';
4
4
  import { KeywordService } from '../keyword/keyword.service';
5
+ import { ConfigService } from '../config/config.service';
5
6
  export declare class McpService implements OnModuleInit {
6
7
  private rulesService;
7
8
  private keywordService;
9
+ private configService;
8
10
  private server;
9
11
  private readonly logger;
10
- constructor(rulesService: RulesService, keywordService: KeywordService);
12
+ constructor(rulesService: RulesService, keywordService: KeywordService, configService: ConfigService);
11
13
  onModuleInit(): void;
12
14
  startStdio(): Promise<void>;
13
15
  getServer(): Server<{
@@ -36,4 +38,11 @@ export declare class McpService implements OnModuleInit {
36
38
  private registerResources;
37
39
  private registerTools;
38
40
  private registerPrompts;
41
+ private handleSearchRules;
42
+ private handleGetAgentDetails;
43
+ private handleParseMode;
44
+ private handleGetProjectConfig;
45
+ private jsonResponse;
46
+ private errorResponse;
47
+ private formatProjectContext;
39
48
  }