@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.
- package/README.md +112 -1
- package/dist/documentation/github-client.d.ts +3 -1
- package/dist/documentation/github-client.d.ts.map +1 -1
- package/dist/documentation/github-client.js +7 -5
- package/dist/documentation/github-client.js.map +1 -1
- package/dist/documentation/http-fetcher.d.ts +3 -0
- package/dist/documentation/http-fetcher.d.ts.map +1 -1
- package/dist/documentation/http-fetcher.js +6 -2
- package/dist/documentation/http-fetcher.js.map +1 -1
- package/dist/documentation/index.d.ts +5 -3
- package/dist/documentation/index.d.ts.map +1 -1
- package/dist/documentation/index.js +98 -14
- package/dist/documentation/index.js.map +1 -1
- package/dist/documentation/npm-client.d.ts +12 -0
- package/dist/documentation/npm-client.d.ts.map +1 -1
- package/dist/documentation/npm-client.js +150 -17
- package/dist/documentation/npm-client.js.map +1 -1
- package/dist/errors/api-validator.d.ts +9 -0
- package/dist/errors/api-validator.d.ts.map +1 -0
- package/dist/errors/api-validator.js +57 -0
- package/dist/errors/api-validator.js.map +1 -0
- package/dist/errors/contextual-analysis.d.ts +3 -0
- package/dist/errors/contextual-analysis.d.ts.map +1 -1
- package/dist/errors/contextual-analysis.js +102 -4
- package/dist/errors/contextual-analysis.js.map +1 -1
- package/dist/errors/cross-file-analyzer.d.ts +16 -0
- package/dist/errors/cross-file-analyzer.d.ts.map +1 -0
- package/dist/errors/cross-file-analyzer.js +172 -0
- package/dist/errors/cross-file-analyzer.js.map +1 -0
- package/dist/errors/eslint-integration.d.ts +1 -0
- package/dist/errors/eslint-integration.d.ts.map +1 -1
- package/dist/errors/eslint-integration.js +101 -22
- package/dist/errors/eslint-integration.js.map +1 -1
- package/dist/errors/framework-detector.d.ts +10 -0
- package/dist/errors/framework-detector.d.ts.map +1 -0
- package/dist/errors/framework-detector.js +126 -0
- package/dist/errors/framework-detector.js.map +1 -0
- package/dist/errors/index.d.ts +9 -2
- package/dist/errors/index.d.ts.map +1 -1
- package/dist/errors/index.js +78 -2
- package/dist/errors/index.js.map +1 -1
- package/dist/errors/patterns.d.ts.map +1 -1
- package/dist/errors/patterns.js +314 -0
- package/dist/errors/patterns.js.map +1 -1
- package/dist/errors/performance-detector.d.ts +11 -0
- package/dist/errors/performance-detector.d.ts.map +1 -0
- package/dist/errors/performance-detector.js +119 -0
- package/dist/errors/performance-detector.js.map +1 -0
- package/dist/errors/runtime-detector.d.ts +7 -0
- package/dist/errors/runtime-detector.d.ts.map +1 -0
- package/dist/errors/runtime-detector.js +86 -0
- package/dist/errors/runtime-detector.js.map +1 -0
- package/dist/errors/security-detector.d.ts +6 -0
- package/dist/errors/security-detector.d.ts.map +1 -0
- package/dist/errors/security-detector.js +75 -0
- package/dist/errors/security-detector.js.map +1 -0
- package/dist/index.js +10 -3
- package/dist/index.js.map +1 -1
- package/dist/server/mcp-server.d.ts.map +1 -1
- package/dist/server/mcp-server.js +155 -61
- package/dist/server/mcp-server.js.map +1 -1
- package/dist/utils/config.d.ts +12 -0
- package/dist/utils/config.d.ts.map +1 -1
- package/dist/utils/config.js +24 -0
- package/dist/utils/config.js.map +1 -1
- package/dist/utils/http-client.d.ts +17 -0
- package/dist/utils/http-client.d.ts.map +1 -0
- package/dist/utils/http-client.js +62 -0
- package/dist/utils/http-client.js.map +1 -0
- package/dist/utils/logger.d.ts +36 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +128 -0
- package/dist/utils/logger.js.map +1 -0
- 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":"AAAA,OAAO,KAA4C,MAAM,OAAO,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAQlD,MAAM,OAAO,UAAU;IACb,aAAa,CAAgB;IAC7B,WAAW,CAAe;IAElC,YAAY,WAAyB;QACnC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;QACpC,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,OAAO;QACT,CAAC;QAED,sBAAsB;QACtB,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QACxC,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QAEnE,yCAAyC;QACzC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YACrD,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;gBAChB,OAAO,MAAM,CAAC;YAChB,CAAC;YAED,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC;YACvB,MAAM,OAAO,GAAG,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;YAE3C,kCAAkC;YAClC,IAAI,IAAI,CAAC,WAAW,EAAE,OAAO,IAAI,CAAC,SAAS,IAAI,UAAU,CAAC,EAAE,CAAC;gBAC3D,IAAI,CAAC;oBACH,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,GAAG,EAAE,CAAC,CAAC;oBAC3E,MAAM,QAAQ,GAAG,SAAS,CAAC,QAAQ,CAAC;oBACpC,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAC1C,QAAQ,KAAK,OAAO,IAAI,QAAQ,CAAC,QAAQ,CAAC,IAAI,OAAO,EAAE,CAAC,CACzD,EAAE,CAAC;wBACF,OAAO,MAAM,CAAC,CAAC,0BAA0B;oBAC3C,CAAC;gBACH,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,0CAA0C;gBAC5C,CAAC;YACH,CAAC;YAED,oCAAoC;YACpC,IAAI,OAAO,IAAI,UAAU,EAAE,CAAC;gBAC1B,MAAM,CAAC,UAAU,GAAG,IAAI,eAAe,CAAC,UAAU,CAAC,CAAC;YACtD,CAAC;iBAAM,IAAI,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC;gBACjC,MAAM,CAAC,SAAS,GAAG,IAAI,cAAc,CAAC,SAAS,CAAC,CAAC;YACnD,CAAC;YAED,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,MAA2B;QAC1C,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IAC7C,CAAC;IAED,IAAI,CAAC,GAAW,EAAE,IAAU,EAAE,MAA2B;QACvD,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IACpD,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,IAAU,EAAE,MAA2B;QACtD,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IACnD,CAAC;IAED,MAAM,CAAC,GAAW,EAAE,MAA2B;QAC7C,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IAChD,CAAC;CACF"}
|
|
@@ -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":"AAAA,MAAM,CAAN,IAAY,QAKX;AALD,WAAY,QAAQ;IAClB,yCAAS,CAAA;IACT,uCAAQ,CAAA;IACR,uCAAQ,CAAA;IACR,yCAAS,CAAA;AACX,CAAC,EALW,QAAQ,KAAR,QAAQ,QAKnB;AAUD,MAAM,OAAO,MAAM;IACT,QAAQ,CAAW;IACnB,YAAY,CAAU;IACtB,gBAAgB,GAAW,CAAC,CAAC;IAErC,YAAY,WAAqB,QAAQ,CAAC,IAAI,EAAE,eAAwB,IAAI;QAC1E,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;IACnC,CAAC;IAED,WAAW,CAAC,KAAe;QACzB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,OAAO,OAAO,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;IACtD,CAAC;IAEO,aAAa,CAAC,KAAe;QACnC,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;QAChD,MAAM,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACvC,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5E,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAE7D,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACjD,OAAO,QAAQ,KAAK,KAAK,SAAS,MAAM,QAAQ,KAAK,KAAK,CAAC,OAAO,GAAG,UAAU,GAAG,QAAQ,SAAS,CAAC;QACtG,CAAC;QAED,OAAO,IAAI,SAAS,MAAM,QAAQ,KAAK,KAAK,CAAC,OAAO,GAAG,UAAU,GAAG,QAAQ,EAAE,CAAC;IACjF,CAAC;IAEO,gBAAgB,CAAC,KAAe;QACtC,QAAQ,KAAK,EAAE,CAAC;YACd,KAAK,QAAQ,CAAC,KAAK,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,OAAO;YACzC,KAAK,QAAQ,CAAC,IAAI,CAAC,CAAC,OAAO,IAAI,CAAC,CAAE,QAAQ;YAC1C,KAAK,QAAQ,CAAC,IAAI,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,SAAS;YAC1C,KAAK,QAAQ,CAAC,KAAK,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,MAAM;YACxC,OAAO,CAAC,CAAC,OAAO,GAAG,CAAC;QACtB,CAAC;IACH,CAAC;IAEO,GAAG,CAAC,KAAe,EAAE,OAAe,EAAE,OAAiC,EAAE,KAAa;QAC5F,IAAI,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC1B,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAa;YACtB,SAAS,EAAE,IAAI,IAAI,EAAE;YACrB,KAAK;YACL,OAAO;YACP,OAAO;YACP,KAAK;SACN,CAAC;QAEF,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE5C,uEAAuE;QACvE,IAAI,KAAK,KAAK,QAAQ,CAAC,KAAK,EAAE,CAAC;YAC7B,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAC3B,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,OAAiC;QACtD,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IAC7C,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,OAAiC;QACrD,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,OAAiC;QACrD,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,OAAiC,EAAE,KAAa;QACrE,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IACpD,CAAC;IAED,8BAA8B;IAC9B,WAAW,CAAC,QAAgB,EAAE,SAAiB,EAAE,MAAgC;QAC/E,IAAI,CAAC,IAAI,CAAC,iBAAiB,QAAQ,EAAE,EAAE;YACrC,SAAS;YACT,IAAI,EAAE,QAAQ;YACd,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;SACpC,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,QAAgB,EAAE,SAAiB,EAAE,QAAgB,EAAE,OAAgB;QACnF,IAAI,CAAC,IAAI,CAAC,mBAAmB,QAAQ,EAAE,EAAE;YACvC,SAAS;YACT,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,GAAG,QAAQ,IAAI;YACzB,OAAO;SACR,CAAC,CAAC;IACL,CAAC;IAED,SAAS,CAAC,QAAgB,EAAE,SAAiB,EAAE,KAAY,EAAE,MAAgC;QAC3F,IAAI,CAAC,KAAK,CAAC,eAAe,QAAQ,EAAE,EAAE;YACpC,SAAS;YACT,IAAI,EAAE,QAAQ;YACd,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;SACpC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAED,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,+BAA+B,EAAE;YACzC,OAAO,EAAE,OAAO;YAChB,GAAG,EAAE,OAAO,CAAC,GAAG;SACjB,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,mCAAmC,CAAC,CAAC;IACjD,CAAC;IAEO,cAAc,CAAC,MAAgC;QACrD,IAAI,CAAC,MAAM;YAAE,OAAO,SAAS,CAAC;QAE9B,MAAM,SAAS,GAA4B,EAAE,CAAC;QAC9C,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAClD,8CAA8C;YAC9C,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC;gBACpD,SAAS,CAAC,GAAG,CAAC,GAAG,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,GAAG,CAAC,iBAAiB,CAAC;YAC/D,CAAC;iBAAM,CAAC;gBACN,SAAS,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YACzB,CAAC;QACH,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AAED,qBAAqB;AACrB,MAAM,CAAC,MAAM,MAAM,GAAG,IAAI,MAAM,CAC9B,OAAO,CAAC,GAAG,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACpD,OAAO,CAAC,GAAG,CAAC,SAAS,KAAK,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAClD,OAAO,CAAC,GAAG,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACpD,QAAQ,CAAC,IAAI,EACb,OAAO,CAAC,GAAG,CAAC,UAAU,KAAK,OAAO,CACnC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@gulibs/safe-coder",
|
|
3
|
-
"version": "0.0.
|
|
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": {
|