@gulibs/safe-coder 0.0.4 → 0.0.6

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 (74) hide show
  1. package/README.md +112 -1
  2. package/dist/documentation/github-client.d.ts +3 -1
  3. package/dist/documentation/github-client.d.ts.map +1 -1
  4. package/dist/documentation/github-client.js +7 -5
  5. package/dist/documentation/github-client.js.map +1 -1
  6. package/dist/documentation/http-fetcher.d.ts +3 -0
  7. package/dist/documentation/http-fetcher.d.ts.map +1 -1
  8. package/dist/documentation/http-fetcher.js +6 -2
  9. package/dist/documentation/http-fetcher.js.map +1 -1
  10. package/dist/documentation/index.d.ts +5 -3
  11. package/dist/documentation/index.d.ts.map +1 -1
  12. package/dist/documentation/index.js +98 -14
  13. package/dist/documentation/index.js.map +1 -1
  14. package/dist/documentation/npm-client.d.ts +12 -0
  15. package/dist/documentation/npm-client.d.ts.map +1 -1
  16. package/dist/documentation/npm-client.js +150 -17
  17. package/dist/documentation/npm-client.js.map +1 -1
  18. package/dist/errors/api-validator.d.ts +9 -0
  19. package/dist/errors/api-validator.d.ts.map +1 -0
  20. package/dist/errors/api-validator.js +57 -0
  21. package/dist/errors/api-validator.js.map +1 -0
  22. package/dist/errors/contextual-analysis.d.ts +3 -0
  23. package/dist/errors/contextual-analysis.d.ts.map +1 -1
  24. package/dist/errors/contextual-analysis.js +102 -4
  25. package/dist/errors/contextual-analysis.js.map +1 -1
  26. package/dist/errors/cross-file-analyzer.d.ts +16 -0
  27. package/dist/errors/cross-file-analyzer.d.ts.map +1 -0
  28. package/dist/errors/cross-file-analyzer.js +172 -0
  29. package/dist/errors/cross-file-analyzer.js.map +1 -0
  30. package/dist/errors/eslint-integration.d.ts +1 -0
  31. package/dist/errors/eslint-integration.d.ts.map +1 -1
  32. package/dist/errors/eslint-integration.js +101 -22
  33. package/dist/errors/eslint-integration.js.map +1 -1
  34. package/dist/errors/framework-detector.d.ts +10 -0
  35. package/dist/errors/framework-detector.d.ts.map +1 -0
  36. package/dist/errors/framework-detector.js +126 -0
  37. package/dist/errors/framework-detector.js.map +1 -0
  38. package/dist/errors/index.d.ts +9 -2
  39. package/dist/errors/index.d.ts.map +1 -1
  40. package/dist/errors/index.js +78 -2
  41. package/dist/errors/index.js.map +1 -1
  42. package/dist/errors/patterns.d.ts.map +1 -1
  43. package/dist/errors/patterns.js +314 -0
  44. package/dist/errors/patterns.js.map +1 -1
  45. package/dist/errors/performance-detector.d.ts +11 -0
  46. package/dist/errors/performance-detector.d.ts.map +1 -0
  47. package/dist/errors/performance-detector.js +119 -0
  48. package/dist/errors/performance-detector.js.map +1 -0
  49. package/dist/errors/runtime-detector.d.ts +7 -0
  50. package/dist/errors/runtime-detector.d.ts.map +1 -0
  51. package/dist/errors/runtime-detector.js +86 -0
  52. package/dist/errors/runtime-detector.js.map +1 -0
  53. package/dist/errors/security-detector.d.ts +6 -0
  54. package/dist/errors/security-detector.d.ts.map +1 -0
  55. package/dist/errors/security-detector.js +75 -0
  56. package/dist/errors/security-detector.js.map +1 -0
  57. package/dist/index.js +10 -3
  58. package/dist/index.js.map +1 -1
  59. package/dist/server/mcp-server.d.ts.map +1 -1
  60. package/dist/server/mcp-server.js +155 -61
  61. package/dist/server/mcp-server.js.map +1 -1
  62. package/dist/utils/config.d.ts +12 -0
  63. package/dist/utils/config.d.ts.map +1 -1
  64. package/dist/utils/config.js +24 -0
  65. package/dist/utils/config.js.map +1 -1
  66. package/dist/utils/http-client.d.ts +17 -0
  67. package/dist/utils/http-client.d.ts.map +1 -0
  68. package/dist/utils/http-client.js +62 -0
  69. package/dist/utils/http-client.js.map +1 -0
  70. package/dist/utils/logger.d.ts +36 -0
  71. package/dist/utils/logger.d.ts.map +1 -0
  72. package/dist/utils/logger.js +128 -0
  73. package/dist/utils/logger.js.map +1 -0
  74. package/package.json +5 -4
@@ -0,0 +1,62 @@
1
+ import axios from 'axios';
2
+ import { HttpsProxyAgent } from 'https-proxy-agent';
3
+ import { HttpProxyAgent } from 'http-proxy-agent';
4
+ export class HttpClient {
5
+ axiosInstance;
6
+ proxyConfig;
7
+ constructor(proxyConfig) {
8
+ this.proxyConfig = proxyConfig;
9
+ this.axiosInstance = axios.create();
10
+ this.setupProxy();
11
+ }
12
+ setupProxy() {
13
+ if (!this.proxyConfig) {
14
+ return;
15
+ }
16
+ // Create proxy agents
17
+ const httpProxy = this.proxyConfig.http;
18
+ const httpsProxy = this.proxyConfig.https || this.proxyConfig.http;
19
+ // Setup request interceptor to add proxy
20
+ this.axiosInstance.interceptors.request.use((config) => {
21
+ if (!config.url) {
22
+ return config;
23
+ }
24
+ const url = config.url;
25
+ const isHttps = url.startsWith('https://');
26
+ // Check if URL is in noProxy list
27
+ if (this.proxyConfig?.noProxy && (httpProxy || httpsProxy)) {
28
+ try {
29
+ const targetUrl = new URL(url.startsWith('http') ? url : `https://${url}`);
30
+ const hostname = targetUrl.hostname;
31
+ if (this.proxyConfig.noProxy.some(noProxy => hostname === noProxy || hostname.endsWith(`.${noProxy}`))) {
32
+ return config; // Skip proxy for this URL
33
+ }
34
+ }
35
+ catch (error) {
36
+ // URL parsing failed, continue with proxy
37
+ }
38
+ }
39
+ // Set proxy agent based on protocol
40
+ if (isHttps && httpsProxy) {
41
+ config.httpsAgent = new HttpsProxyAgent(httpsProxy);
42
+ }
43
+ else if (!isHttps && httpProxy) {
44
+ config.httpAgent = new HttpProxyAgent(httpProxy);
45
+ }
46
+ return config;
47
+ });
48
+ }
49
+ get(url, config) {
50
+ return this.axiosInstance.get(url, config);
51
+ }
52
+ post(url, data, config) {
53
+ return this.axiosInstance.post(url, data, config);
54
+ }
55
+ put(url, data, config) {
56
+ return this.axiosInstance.put(url, data, config);
57
+ }
58
+ delete(url, config) {
59
+ return this.axiosInstance.delete(url, config);
60
+ }
61
+ }
62
+ //# sourceMappingURL=http-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http-client.js","sourceRoot":"","sources":["../../src/utils/http-client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ export declare enum LogLevel {
2
+ DEBUG = 0,
3
+ INFO = 1,
4
+ WARN = 2,
5
+ ERROR = 3
6
+ }
7
+ export interface LogEntry {
8
+ timestamp: Date;
9
+ level: LogLevel;
10
+ message: string;
11
+ context?: Record<string, unknown>;
12
+ error?: Error;
13
+ }
14
+ export declare class Logger {
15
+ private logLevel;
16
+ private enableColors;
17
+ private requestIdCounter;
18
+ constructor(logLevel?: LogLevel, enableColors?: boolean);
19
+ setLogLevel(level: LogLevel): void;
20
+ generateRequestId(): string;
21
+ private formatMessage;
22
+ private getColorForLevel;
23
+ private log;
24
+ debug(message: string, context?: Record<string, unknown>): void;
25
+ info(message: string, context?: Record<string, unknown>): void;
26
+ warn(message: string, context?: Record<string, unknown>): void;
27
+ error(message: string, context?: Record<string, unknown>, error?: Error): void;
28
+ toolInvoked(toolName: string, requestId: string, params?: Record<string, unknown>): void;
29
+ toolCompleted(toolName: string, requestId: string, duration: number, success: boolean): void;
30
+ toolError(toolName: string, requestId: string, error: Error, params?: Record<string, unknown>): void;
31
+ serverStarted(): void;
32
+ serverConnected(): void;
33
+ private sanitizeParams;
34
+ }
35
+ export declare const logger: Logger;
36
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAAA,oBAAY,QAAQ;IAClB,KAAK,IAAI;IACT,IAAI,IAAI;IACR,IAAI,IAAI;IACR,KAAK,IAAI;CACV;AAED,MAAM,WAAW,QAAQ;IACvB,SAAS,EAAE,IAAI,CAAC;IAChB,KAAK,EAAE,QAAQ,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,KAAK,CAAC,EAAE,KAAK,CAAC;CACf;AAED,qBAAa,MAAM;IACjB,OAAO,CAAC,QAAQ,CAAW;IAC3B,OAAO,CAAC,YAAY,CAAU;IAC9B,OAAO,CAAC,gBAAgB,CAAa;gBAEzB,QAAQ,GAAE,QAAwB,EAAE,YAAY,GAAE,OAAc;IAK5E,WAAW,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI;IAIlC,iBAAiB,IAAI,MAAM;IAK3B,OAAO,CAAC,aAAa;IAcrB,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,GAAG;IAuBX,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI/D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI9D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI9D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI;IAK9E,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAQxF,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,IAAI;IAS5F,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAQpG,aAAa,IAAI,IAAI;IAOrB,eAAe,IAAI,IAAI;IAIvB,OAAO,CAAC,cAAc;CAcvB;AAGD,eAAO,MAAM,MAAM,QAMlB,CAAC"}
@@ -0,0 +1,128 @@
1
+ export var LogLevel;
2
+ (function (LogLevel) {
3
+ LogLevel[LogLevel["DEBUG"] = 0] = "DEBUG";
4
+ LogLevel[LogLevel["INFO"] = 1] = "INFO";
5
+ LogLevel[LogLevel["WARN"] = 2] = "WARN";
6
+ LogLevel[LogLevel["ERROR"] = 3] = "ERROR";
7
+ })(LogLevel || (LogLevel = {}));
8
+ export class Logger {
9
+ logLevel;
10
+ enableColors;
11
+ requestIdCounter = 0;
12
+ constructor(logLevel = LogLevel.INFO, enableColors = true) {
13
+ this.logLevel = logLevel;
14
+ this.enableColors = enableColors;
15
+ }
16
+ setLogLevel(level) {
17
+ this.logLevel = level;
18
+ }
19
+ generateRequestId() {
20
+ this.requestIdCounter++;
21
+ return `req-${Date.now()}-${this.requestIdCounter}`;
22
+ }
23
+ formatMessage(entry) {
24
+ const timestamp = entry.timestamp.toISOString();
25
+ const levelStr = LogLevel[entry.level];
26
+ const contextStr = entry.context ? ` ${JSON.stringify(entry.context)}` : '';
27
+ const errorStr = entry.error ? `\n${entry.error.stack}` : '';
28
+ if (this.enableColors) {
29
+ const color = this.getColorForLevel(entry.level);
30
+ return `\x1b[${color}m[${timestamp}] [${levelStr}] ${entry.message}${contextStr}${errorStr}\x1b[0m`;
31
+ }
32
+ return `[${timestamp}] [${levelStr}] ${entry.message}${contextStr}${errorStr}`;
33
+ }
34
+ getColorForLevel(level) {
35
+ switch (level) {
36
+ case LogLevel.DEBUG: return '36'; // Cyan
37
+ case LogLevel.INFO: return '32'; // Green
38
+ case LogLevel.WARN: return '33'; // Yellow
39
+ case LogLevel.ERROR: return '31'; // Red
40
+ default: return '0';
41
+ }
42
+ }
43
+ log(level, message, context, error) {
44
+ if (level < this.logLevel) {
45
+ return;
46
+ }
47
+ const entry = {
48
+ timestamp: new Date(),
49
+ level,
50
+ message,
51
+ context,
52
+ error,
53
+ };
54
+ const formatted = this.formatMessage(entry);
55
+ // Use stderr for all logs (MCP protocol uses stdout for communication)
56
+ if (level === LogLevel.ERROR) {
57
+ console.error(formatted);
58
+ }
59
+ else {
60
+ console.error(formatted);
61
+ }
62
+ }
63
+ debug(message, context) {
64
+ this.log(LogLevel.DEBUG, message, context);
65
+ }
66
+ info(message, context) {
67
+ this.log(LogLevel.INFO, message, context);
68
+ }
69
+ warn(message, context) {
70
+ this.log(LogLevel.WARN, message, context);
71
+ }
72
+ error(message, context, error) {
73
+ this.log(LogLevel.ERROR, message, context, error);
74
+ }
75
+ // Specialized logging methods
76
+ toolInvoked(toolName, requestId, params) {
77
+ this.info(`Tool invoked: ${toolName}`, {
78
+ requestId,
79
+ tool: toolName,
80
+ params: this.sanitizeParams(params),
81
+ });
82
+ }
83
+ toolCompleted(toolName, requestId, duration, success) {
84
+ this.info(`Tool completed: ${toolName}`, {
85
+ requestId,
86
+ tool: toolName,
87
+ duration: `${duration}ms`,
88
+ success,
89
+ });
90
+ }
91
+ toolError(toolName, requestId, error, params) {
92
+ this.error(`Tool error: ${toolName}`, {
93
+ requestId,
94
+ tool: toolName,
95
+ params: this.sanitizeParams(params),
96
+ }, error);
97
+ }
98
+ serverStarted() {
99
+ this.info('Safe Coder MCP server started', {
100
+ version: '1.0.0',
101
+ pid: process.pid,
102
+ });
103
+ }
104
+ serverConnected() {
105
+ this.info('MCP server connected to transport');
106
+ }
107
+ sanitizeParams(params) {
108
+ if (!params)
109
+ return undefined;
110
+ const sanitized = {};
111
+ for (const [key, value] of Object.entries(params)) {
112
+ // Truncate long strings (e.g., code snippets)
113
+ if (typeof value === 'string' && value.length > 200) {
114
+ sanitized[key] = `${value.substring(0, 200)}... (truncated)`;
115
+ }
116
+ else {
117
+ sanitized[key] = value;
118
+ }
119
+ }
120
+ return sanitized;
121
+ }
122
+ }
123
+ // Singleton instance
124
+ export const logger = new Logger(process.env.LOG_LEVEL === 'DEBUG' ? LogLevel.DEBUG :
125
+ process.env.LOG_LEVEL === 'WARN' ? LogLevel.WARN :
126
+ process.env.LOG_LEVEL === 'ERROR' ? LogLevel.ERROR :
127
+ LogLevel.INFO, process.env.LOG_COLORS !== 'false');
128
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gulibs/safe-coder",
3
- "version": "0.0.4",
3
+ "version": "0.0.6",
4
4
  "publishConfig": {
5
5
  "access": "public",
6
6
  "registry": "https://registry.npmjs.org"
@@ -26,9 +26,6 @@
26
26
  "README.md",
27
27
  "LICENSE"
28
28
  ],
29
- "exports": {
30
- ".": "./dist/index.js"
31
- },
32
29
  "keywords": [
33
30
  "mcp",
34
31
  "model-context-protocol",
@@ -43,6 +40,10 @@
43
40
  "@typescript-eslint/typescript-estree": "^8.48.0",
44
41
  "axios": "^1.13.2",
45
42
  "eslint": "^8.57.1",
43
+ "eslint-plugin-react": "^7.37.5",
44
+ "eslint-plugin-security": "^3.0.1",
45
+ "http-proxy-agent": "^7.0.2",
46
+ "https-proxy-agent": "^7.0.6",
46
47
  "zod": "^3.25.76"
47
48
  },
48
49
  "devDependencies": {