@mcp-guardian/server 0.4.0 → 0.5.0

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 (91) hide show
  1. package/README.md +105 -8
  2. package/dist/auth/auth-types.d.ts +40 -0
  3. package/dist/auth/auth-types.d.ts.map +1 -0
  4. package/dist/auth/auth-types.js +5 -0
  5. package/dist/auth/auth-types.js.map +1 -0
  6. package/dist/auth/dashboard-auth.d.ts +97 -0
  7. package/dist/auth/dashboard-auth.d.ts.map +1 -0
  8. package/dist/auth/dashboard-auth.js +319 -0
  9. package/dist/auth/dashboard-auth.js.map +1 -0
  10. package/dist/auth/dpop.d.ts +38 -0
  11. package/dist/auth/dpop.d.ts.map +1 -0
  12. package/dist/auth/dpop.js +72 -0
  13. package/dist/auth/dpop.js.map +1 -0
  14. package/dist/auth/oauth.d.ts +25 -0
  15. package/dist/auth/oauth.d.ts.map +1 -0
  16. package/dist/auth/oauth.js +96 -0
  17. package/dist/auth/oauth.js.map +1 -0
  18. package/dist/auth/redis-session-cache.d.ts +21 -0
  19. package/dist/auth/redis-session-cache.d.ts.map +1 -0
  20. package/dist/auth/redis-session-cache.js +74 -0
  21. package/dist/auth/redis-session-cache.js.map +1 -0
  22. package/dist/auth/session-cache.d.ts +47 -0
  23. package/dist/auth/session-cache.d.ts.map +1 -0
  24. package/dist/auth/session-cache.js +91 -0
  25. package/dist/auth/session-cache.js.map +1 -0
  26. package/dist/cli.js +23 -5
  27. package/dist/cli.js.map +1 -1
  28. package/dist/database/database-interface.d.ts +17 -0
  29. package/dist/database/database-interface.d.ts.map +1 -0
  30. package/dist/database/database-interface.js +2 -0
  31. package/dist/database/database-interface.js.map +1 -0
  32. package/dist/database/postgres-db.d.ts +18 -0
  33. package/dist/database/postgres-db.d.ts.map +1 -0
  34. package/dist/database/postgres-db.js +118 -0
  35. package/dist/database/postgres-db.js.map +1 -0
  36. package/dist/index.js +1 -1
  37. package/dist/policy/policy-watcher.d.ts +24 -0
  38. package/dist/policy/policy-watcher.d.ts.map +1 -0
  39. package/dist/policy/policy-watcher.js +68 -0
  40. package/dist/policy/policy-watcher.js.map +1 -0
  41. package/dist/policy/shell-tokenizer.d.ts +92 -0
  42. package/dist/policy/shell-tokenizer.d.ts.map +1 -0
  43. package/dist/policy/shell-tokenizer.js +300 -0
  44. package/dist/policy/shell-tokenizer.js.map +1 -0
  45. package/dist/proxy/http-proxy-server.d.ts +26 -0
  46. package/dist/proxy/http-proxy-server.d.ts.map +1 -0
  47. package/dist/proxy/http-proxy-server.js +172 -0
  48. package/dist/proxy/http-proxy-server.js.map +1 -0
  49. package/dist/proxy/proxy-manager.d.ts +3 -1
  50. package/dist/proxy/proxy-manager.d.ts.map +1 -1
  51. package/dist/proxy/proxy-manager.js +10 -3
  52. package/dist/proxy/proxy-manager.js.map +1 -1
  53. package/dist/proxy/proxy-server.d.ts +15 -8
  54. package/dist/proxy/proxy-server.d.ts.map +1 -1
  55. package/dist/proxy/proxy-server.js +80 -26
  56. package/dist/proxy/proxy-server.js.map +1 -1
  57. package/dist/utils/circuit-breaker.d.ts +29 -0
  58. package/dist/utils/circuit-breaker.d.ts.map +1 -0
  59. package/dist/utils/circuit-breaker.js +81 -0
  60. package/dist/utils/circuit-breaker.js.map +1 -0
  61. package/dist/utils/dashboard-server.d.ts +19 -0
  62. package/dist/utils/dashboard-server.d.ts.map +1 -0
  63. package/dist/utils/dashboard-server.js +258 -0
  64. package/dist/utils/dashboard-server.js.map +1 -0
  65. package/dist/utils/metrics.d.ts +17 -0
  66. package/dist/utils/metrics.d.ts.map +1 -0
  67. package/dist/utils/metrics.js +79 -0
  68. package/dist/utils/metrics.js.map +1 -0
  69. package/dist/utils/mtls-config.d.ts +27 -0
  70. package/dist/utils/mtls-config.d.ts.map +1 -0
  71. package/dist/utils/mtls-config.js +82 -0
  72. package/dist/utils/mtls-config.js.map +1 -0
  73. package/dist/utils/payload-normalizer.d.ts +62 -0
  74. package/dist/utils/payload-normalizer.d.ts.map +1 -0
  75. package/dist/utils/payload-normalizer.js +240 -0
  76. package/dist/utils/payload-normalizer.js.map +1 -0
  77. package/dist/utils/policy-auditor.d.ts +24 -0
  78. package/dist/utils/policy-auditor.d.ts.map +1 -0
  79. package/dist/utils/policy-auditor.js +58 -0
  80. package/dist/utils/policy-auditor.js.map +1 -0
  81. package/dist/utils/redis-rate-limiter.d.ts +22 -0
  82. package/dist/utils/redis-rate-limiter.d.ts.map +1 -0
  83. package/dist/utils/redis-rate-limiter.js +61 -0
  84. package/dist/utils/redis-rate-limiter.js.map +1 -0
  85. package/dist/utils/structured-logger.d.ts +1 -1
  86. package/dist/utils/structured-logger.d.ts.map +1 -1
  87. package/dist/utils/tracing.d.ts +7 -0
  88. package/dist/utils/tracing.d.ts.map +1 -0
  89. package/dist/utils/tracing.js +34 -0
  90. package/dist/utils/tracing.js.map +1 -0
  91. package/package.json +2 -1
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Redis-backed rate limit counters for multi-replica HA.
3
+ * Extends the in-memory counters with shared Redis state.
4
+ * Enable with: REDIS_URL=redis://localhost:6379
5
+ */
6
+ export declare class RedisRateLimiter {
7
+ private redis;
8
+ private prefix;
9
+ private local;
10
+ constructor();
11
+ /**
12
+ * Check and increment a rate limit counter.
13
+ * Returns the new count, or -1 if the limit is exceeded.
14
+ * Counter resets every windowMs milliseconds.
15
+ */
16
+ checkAndIncrement(key: string, maxRequests: number, windowMs?: number): Promise<{
17
+ allowed: boolean;
18
+ count: number;
19
+ }>;
20
+ close(): Promise<void>;
21
+ }
22
+ //# sourceMappingURL=redis-rate-limiter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redis-rate-limiter.d.ts","sourceRoot":"","sources":["../../src/utils/redis-rate-limiter.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AACH,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,KAAK,CAAQ;IACrB,OAAO,CAAC,MAAM,CAA6B;IAC3C,OAAO,CAAC,KAAK,CAA8D;;IAQ3E;;;;OAIG;IACG,iBAAiB,CAAC,GAAG,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,QAAQ,GAAE,MAAc,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IAoC3H,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAG7B"}
@@ -0,0 +1,61 @@
1
+ import { Redis } from 'ioredis';
2
+ import { Logger } from './logger.js';
3
+ /**
4
+ * Redis-backed rate limit counters for multi-replica HA.
5
+ * Extends the in-memory counters with shared Redis state.
6
+ * Enable with: REDIS_URL=redis://localhost:6379
7
+ */
8
+ export class RedisRateLimiter {
9
+ redis;
10
+ prefix = 'mcp_guardian:ratelimit:';
11
+ local = new Map();
12
+ constructor() {
13
+ const redisUrl = process.env['REDIS_URL'] || 'redis://localhost:6379';
14
+ this.redis = new Redis(redisUrl, { maxRetriesPerRequest: 2, lazyConnect: false });
15
+ Logger.info(`[redis-rate-limiter] Connected to ${redisUrl}`);
16
+ }
17
+ /**
18
+ * Check and increment a rate limit counter.
19
+ * Returns the new count, or -1 if the limit is exceeded.
20
+ * Counter resets every windowMs milliseconds.
21
+ */
22
+ async checkAndIncrement(key, maxRequests, windowMs = 60000) {
23
+ const redisKey = `${this.prefix}${key}`;
24
+ try {
25
+ // Use Redis MULTI for atomic increment + TTL
26
+ const count = await this.redis.incr(redisKey);
27
+ if (count === 1) {
28
+ await this.redis.pexpire(redisKey, windowMs);
29
+ }
30
+ // Also update local for fast reads
31
+ const now = Date.now();
32
+ let localCounter = this.local.get(key);
33
+ if (!localCounter || now > localCounter.resetAt) {
34
+ localCounter = { count: 1, resetAt: now + windowMs };
35
+ }
36
+ else {
37
+ localCounter.count++;
38
+ }
39
+ this.local.set(key, localCounter);
40
+ return { allowed: count <= maxRequests, count };
41
+ }
42
+ catch (err) {
43
+ // Redis unavailable — fall back to local
44
+ Logger.debug(`[redis-rate-limiter] Redis error, using local: ${err?.message}`);
45
+ const now = Date.now();
46
+ let localCounter = this.local.get(key);
47
+ if (!localCounter || now > localCounter.resetAt) {
48
+ localCounter = { count: 1, resetAt: now + windowMs };
49
+ }
50
+ else {
51
+ localCounter.count++;
52
+ }
53
+ this.local.set(key, localCounter);
54
+ return { allowed: localCounter.count <= maxRequests, count: localCounter.count };
55
+ }
56
+ }
57
+ async close() {
58
+ await this.redis.quit();
59
+ }
60
+ }
61
+ //# sourceMappingURL=redis-rate-limiter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redis-rate-limiter.js","sourceRoot":"","sources":["../../src/utils/redis-rate-limiter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC;;;;GAIG;AACH,MAAM,OAAO,gBAAgB;IACnB,KAAK,CAAQ;IACb,MAAM,GAAG,yBAAyB,CAAC;IACnC,KAAK,GAAoD,IAAI,GAAG,EAAE,CAAC;IAE3E;QACE,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,wBAAwB,CAAC;QACtE,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC,QAAQ,EAAE,EAAE,oBAAoB,EAAE,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC;QAClF,MAAM,CAAC,IAAI,CAAC,qCAAqC,QAAQ,EAAE,CAAC,CAAC;IAC/D,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,iBAAiB,CAAC,GAAW,EAAE,WAAmB,EAAE,WAAmB,KAAK;QAChF,MAAM,QAAQ,GAAG,GAAG,IAAI,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC;QAExC,IAAI,CAAC;YACH,6CAA6C;YAC7C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC9C,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;gBAChB,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;YAC/C,CAAC;YAED,mCAAmC;YACnC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,IAAI,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACvC,IAAI,CAAC,YAAY,IAAI,GAAG,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC;gBAChD,YAAY,GAAG,EAAE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,GAAG,GAAG,QAAQ,EAAE,CAAC;YACvD,CAAC;iBAAM,CAAC;gBACN,YAAY,CAAC,KAAK,EAAE,CAAC;YACvB,CAAC;YACD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;YAElC,OAAO,EAAE,OAAO,EAAE,KAAK,IAAI,WAAW,EAAE,KAAK,EAAE,CAAC;QAClD,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,yCAAyC;YACzC,MAAM,CAAC,KAAK,CAAC,kDAAkD,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC;YAC/E,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,IAAI,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACvC,IAAI,CAAC,YAAY,IAAI,GAAG,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC;gBAChD,YAAY,GAAG,EAAE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,GAAG,GAAG,QAAQ,EAAE,CAAC;YACvD,CAAC;iBAAM,CAAC;gBACN,YAAY,CAAC,KAAK,EAAE,CAAC;YACvB,CAAC;YACD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;YAClC,OAAO,EAAE,OAAO,EAAE,YAAY,CAAC,KAAK,IAAI,WAAW,EAAE,KAAK,EAAE,YAAY,CAAC,KAAK,EAAE,CAAC;QACnF,CAAC;IACH,CAAC;IAED,KAAK,CAAC,KAAK;QACT,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;CACF"}
@@ -16,7 +16,7 @@ export interface BlockLogEntry {
16
16
  rule: string;
17
17
  }
18
18
  export interface ErrorLogEntry {
19
- event: 'proxy_error';
19
+ event: 'proxy_error' | 'oidc_discovery_error' | 'oidc_auth_error';
20
20
  requestId?: string | number;
21
21
  serverName: string;
22
22
  error: string;
@@ -1 +1 @@
1
- {"version":3,"file":"structured-logger.d.ts","sourceRoot":"","sources":["../../src/utils/structured-logger.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAkBxE,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,iBAAiB,CAAC;IACzB,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,cAAc,CAAC;IACzB,OAAO,EAAE,WAAW,CAAC;CACtB;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,cAAc,CAAC;IACtB,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,aAAa,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC5B,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,qBAAa,gBAAgB;IAC3B;;OAEG;IACH,MAAM,CAAC,iBAAiB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAIpD;;OAEG;IACH,MAAM,CAAC,UAAU,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAI7C;;OAEG;IACH,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAI3C;;OAEG;IACH,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAIvC;;OAEG;IACH,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;CAGzC"}
1
+ {"version":3,"file":"structured-logger.d.ts","sourceRoot":"","sources":["../../src/utils/structured-logger.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAkBxE,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,iBAAiB,CAAC;IACzB,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,cAAc,CAAC;IACzB,OAAO,EAAE,WAAW,CAAC;CACtB;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,cAAc,CAAC;IACtB,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,aAAa,GAAG,sBAAsB,GAAG,iBAAiB,CAAC;IAClE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC5B,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,qBAAa,gBAAgB;IAC3B;;OAEG;IACH,MAAM,CAAC,iBAAiB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAIpD;;OAEG;IACH,MAAM,CAAC,UAAU,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAI7C;;OAEG;IACH,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAI3C;;OAEG;IACH,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAIvC;;OAEG;IACH,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;CAGzC"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * OpenTelemetry tracing for distributed request tracking across proxy + MCP servers.
3
+ * Enable with: OTEL_EXPORTER_OTLP_ENDPOINT=http://localhost:4318
4
+ * Uses OTLP HTTP exporter (gRPC exporter deprecated due to critical CVE in protobufjs).
5
+ */
6
+ export declare function initTracing(): Promise<void>;
7
+ //# sourceMappingURL=tracing.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tracing.d.ts","sourceRoot":"","sources":["../../src/utils/tracing.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,wBAAsB,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC,CA8BjD"}
@@ -0,0 +1,34 @@
1
+ import { Logger } from './logger.js';
2
+ /**
3
+ * OpenTelemetry tracing for distributed request tracking across proxy + MCP servers.
4
+ * Enable with: OTEL_EXPORTER_OTLP_ENDPOINT=http://localhost:4318
5
+ * Uses OTLP HTTP exporter (gRPC exporter deprecated due to critical CVE in protobufjs).
6
+ */
7
+ export async function initTracing() {
8
+ if (!process.env['OTEL_EXPORTER_OTLP_ENDPOINT']) {
9
+ Logger.debug('[tracing] OpenTelemetry not configured (set OTEL_EXPORTER_OTLP_ENDPOINT)');
10
+ return;
11
+ }
12
+ try {
13
+ const { NodeSDK } = await import('@opentelemetry/sdk-node');
14
+ const { getNodeAutoInstrumentations } = await import('@opentelemetry/auto-instrumentations-node');
15
+ // Use OTLP HTTP exporter instead of deprecated gRPC
16
+ const { OTLPTraceExporter } = await import('@opentelemetry/exporter-trace-otlp-http');
17
+ const exporter = new OTLPTraceExporter({
18
+ url: `${process.env['OTEL_EXPORTER_OTLP_ENDPOINT']}/v1/traces`,
19
+ });
20
+ const instruments = getNodeAutoInstrumentations({
21
+ '@opentelemetry/instrumentation-http': { enabled: true },
22
+ });
23
+ const sdk = new NodeSDK({
24
+ traceExporter: exporter,
25
+ instrumentations: [instruments],
26
+ });
27
+ await sdk.start();
28
+ Logger.info('[tracing] OpenTelemetry tracing initialized — exporting to OTLP HTTP endpoint');
29
+ }
30
+ catch (err) {
31
+ Logger.warn(`[tracing] OpenTelemetry initialization failed: ${err?.message}`);
32
+ }
33
+ }
34
+ //# sourceMappingURL=tracing.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tracing.js","sourceRoot":"","sources":["../../src/utils/tracing.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,WAAW;IAC/B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,EAAE,CAAC;QAChD,MAAM,CAAC,KAAK,CAAC,0EAA0E,CAAC,CAAC;QACzF,OAAO;IACT,CAAC;IAED,IAAI,CAAC;QACH,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,MAAM,CAAC,yBAAyB,CAAC,CAAC;QAC5D,MAAM,EAAE,2BAA2B,EAAE,GAAG,MAAM,MAAM,CAAC,2CAA2C,CAAC,CAAC;QAClG,oDAAoD;QACpD,MAAM,EAAE,iBAAiB,EAAE,GAAG,MAAM,MAAM,CAAC,yCAAyC,CAAC,CAAC;QAEtF,MAAM,QAAQ,GAAG,IAAI,iBAAiB,CAAC;YACrC,GAAG,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,YAAY;SAC/D,CAAQ,CAAC;QAEV,MAAM,WAAW,GAAG,2BAA2B,CAAC;YAC9C,qCAAqC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;SACzD,CAAQ,CAAC;QAEV,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC;YACtB,aAAa,EAAE,QAAQ;YACvB,gBAAgB,EAAE,CAAC,WAAW,CAAC;SAChC,CAAC,CAAC;QAEH,MAAM,GAAG,CAAC,KAAK,EAAE,CAAC;QAClB,MAAM,CAAC,IAAI,CAAC,+EAA+E,CAAC,CAAC;IAC/F,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,MAAM,CAAC,IAAI,CAAC,kDAAkD,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC;IAChF,CAAC;AACH,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mcp-guardian/server",
3
- "version": "0.4.0",
3
+ "version": "0.5.0",
4
4
  "description": "Security, cost, and health audit for MCP infrastructure",
5
5
  "type": "module",
6
6
  "files": [
@@ -41,6 +41,7 @@
41
41
  "axios": "^1.7.0",
42
42
  "chalk": "^5.3.0",
43
43
  "commander": "^12.0.0",
44
+ "jose": "^6.2.3",
44
45
  "js-yaml": "^4.1.1",
45
46
  "pino": "^10.3.1",
46
47
  "sql.js": "^1.11.0",