context-gatekeeper 0.3.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.
- package/LICENSE +21 -0
- package/README.md +774 -0
- package/README.zh.md +765 -0
- package/bin/context-gatekeeper-cli.js +60 -0
- package/dist/api/gdpr.d.ts +104 -0
- package/dist/api/gdpr.d.ts.map +1 -0
- package/dist/api/gdpr.js +229 -0
- package/dist/api/gdpr.js.map +1 -0
- package/dist/api/health-check.d.ts +13 -0
- package/dist/api/health-check.d.ts.map +1 -0
- package/dist/api/health-check.js +2 -0
- package/dist/api/health-check.js.map +1 -0
- package/dist/api/index.d.ts +7 -0
- package/dist/api/index.d.ts.map +1 -0
- package/dist/api/index.js +8 -0
- package/dist/api/index.js.map +1 -0
- package/dist/api/observability.d.ts +39 -0
- package/dist/api/observability.d.ts.map +1 -0
- package/dist/api/observability.js +132 -0
- package/dist/api/observability.js.map +1 -0
- package/dist/api/session-manager.d.ts +41 -0
- package/dist/api/session-manager.d.ts.map +1 -0
- package/dist/api/session-manager.js +129 -0
- package/dist/api/session-manager.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/server.d.ts +8 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +613 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/configure-llm.d.ts +26 -0
- package/dist/mcp/tools/configure-llm.d.ts.map +1 -0
- package/dist/mcp/tools/configure-llm.js +32 -0
- package/dist/mcp/tools/configure-llm.js.map +1 -0
- package/dist/mcp/tools/context-compress.d.ts +15 -0
- package/dist/mcp/tools/context-compress.d.ts.map +1 -0
- package/dist/mcp/tools/context-compress.js +15 -0
- package/dist/mcp/tools/context-compress.js.map +1 -0
- package/dist/mcp/tools/dual-mode-execute.d.ts +78 -0
- package/dist/mcp/tools/dual-mode-execute.d.ts.map +1 -0
- package/dist/mcp/tools/dual-mode-execute.js +299 -0
- package/dist/mcp/tools/dual-mode-execute.js.map +1 -0
- package/dist/mcp/tools/index.d.ts +19 -0
- package/dist/mcp/tools/index.d.ts.map +1 -0
- package/dist/mcp/tools/index.js +20 -0
- package/dist/mcp/tools/index.js.map +1 -0
- package/dist/mcp/tools/intelligent-recall.d.ts +67 -0
- package/dist/mcp/tools/intelligent-recall.d.ts.map +1 -0
- package/dist/mcp/tools/intelligent-recall.js +208 -0
- package/dist/mcp/tools/intelligent-recall.js.map +1 -0
- package/dist/mcp/tools/memory-anchor.d.ts +13 -0
- package/dist/mcp/tools/memory-anchor.d.ts.map +1 -0
- package/dist/mcp/tools/memory-anchor.js +16 -0
- package/dist/mcp/tools/memory-anchor.js.map +1 -0
- package/dist/mcp/tools/memory-delete-batch.d.ts +16 -0
- package/dist/mcp/tools/memory-delete-batch.d.ts.map +1 -0
- package/dist/mcp/tools/memory-delete-batch.js +26 -0
- package/dist/mcp/tools/memory-delete-batch.js.map +1 -0
- package/dist/mcp/tools/memory-extract.d.ts +68 -0
- package/dist/mcp/tools/memory-extract.d.ts.map +1 -0
- package/dist/mcp/tools/memory-extract.js +280 -0
- package/dist/mcp/tools/memory-extract.js.map +1 -0
- package/dist/mcp/tools/memory-recall.d.ts +42 -0
- package/dist/mcp/tools/memory-recall.d.ts.map +1 -0
- package/dist/mcp/tools/memory-recall.js +37 -0
- package/dist/mcp/tools/memory-recall.js.map +1 -0
- package/dist/mcp/tools/memory-report-usage.d.ts +17 -0
- package/dist/mcp/tools/memory-report-usage.d.ts.map +1 -0
- package/dist/mcp/tools/memory-report-usage.js +15 -0
- package/dist/mcp/tools/memory-report-usage.js.map +1 -0
- package/dist/mcp/tools/memory-search.d.ts +43 -0
- package/dist/mcp/tools/memory-search.d.ts.map +1 -0
- package/dist/mcp/tools/memory-search.js +38 -0
- package/dist/mcp/tools/memory-search.js.map +1 -0
- package/dist/mcp/tools/memory-session.d.ts +118 -0
- package/dist/mcp/tools/memory-session.d.ts.map +1 -0
- package/dist/mcp/tools/memory-session.js +113 -0
- package/dist/mcp/tools/memory-session.js.map +1 -0
- package/dist/mcp/tools/memory-stats.d.ts +10 -0
- package/dist/mcp/tools/memory-stats.d.ts.map +1 -0
- package/dist/mcp/tools/memory-stats.js +35 -0
- package/dist/mcp/tools/memory-stats.js.map +1 -0
- package/dist/mcp/tools/memory-store-batch.d.ts +49 -0
- package/dist/mcp/tools/memory-store-batch.d.ts.map +1 -0
- package/dist/mcp/tools/memory-store-batch.js +48 -0
- package/dist/mcp/tools/memory-store-batch.js.map +1 -0
- package/dist/mcp/tools/memory-store.d.ts +37 -0
- package/dist/mcp/tools/memory-store.d.ts.map +1 -0
- package/dist/mcp/tools/memory-store.js +34 -0
- package/dist/mcp/tools/memory-store.js.map +1 -0
- package/dist/mcp/tools/project-create.d.ts +16 -0
- package/dist/mcp/tools/project-create.d.ts.map +1 -0
- package/dist/mcp/tools/project-create.js +14 -0
- package/dist/mcp/tools/project-create.js.map +1 -0
- package/dist/models/types.d.ts +88 -0
- package/dist/models/types.d.ts.map +1 -0
- package/dist/models/types.js +19 -0
- package/dist/models/types.js.map +1 -0
- package/dist/schema/compression.d.ts +7 -0
- package/dist/schema/compression.d.ts.map +1 -0
- package/dist/schema/compression.js +66 -0
- package/dist/schema/compression.js.map +1 -0
- package/dist/schema/fulltext-search.d.ts +10 -0
- package/dist/schema/fulltext-search.d.ts.map +1 -0
- package/dist/schema/fulltext-search.js +73 -0
- package/dist/schema/fulltext-search.js.map +1 -0
- package/dist/schema/index.d.ts +9 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +9 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/knowledge-graph.d.ts +108 -0
- package/dist/schema/knowledge-graph.d.ts.map +1 -0
- package/dist/schema/knowledge-graph.js +372 -0
- package/dist/schema/knowledge-graph.js.map +1 -0
- package/dist/schema/memory-session.d.ts +62 -0
- package/dist/schema/memory-session.d.ts.map +1 -0
- package/dist/schema/memory-session.js +258 -0
- package/dist/schema/memory-session.js.map +1 -0
- package/dist/schema/memory.d.ts +84 -0
- package/dist/schema/memory.d.ts.map +1 -0
- package/dist/schema/memory.js +622 -0
- package/dist/schema/memory.js.map +1 -0
- package/dist/schema/project.d.ts +8 -0
- package/dist/schema/project.d.ts.map +1 -0
- package/dist/schema/project.js +68 -0
- package/dist/schema/project.js.map +1 -0
- package/dist/schema/schema-init.d.ts +2 -0
- package/dist/schema/schema-init.d.ts.map +1 -0
- package/dist/schema/schema-init.js +199 -0
- package/dist/schema/schema-init.js.map +1 -0
- package/dist/schema/vector-index.d.ts +28 -0
- package/dist/schema/vector-index.d.ts.map +1 -0
- package/dist/schema/vector-index.js +179 -0
- package/dist/schema/vector-index.js.map +1 -0
- package/dist/scripts/agents/base.d.ts +89 -0
- package/dist/scripts/agents/base.d.ts.map +1 -0
- package/dist/scripts/agents/base.js +148 -0
- package/dist/scripts/agents/base.js.map +1 -0
- package/dist/scripts/agents/base.ts +193 -0
- package/dist/scripts/agents/claude-code.d.ts +21 -0
- package/dist/scripts/agents/claude-code.d.ts.map +1 -0
- package/dist/scripts/agents/claude-code.js +33 -0
- package/dist/scripts/agents/claude-code.js.map +1 -0
- package/dist/scripts/agents/claude-code.ts +36 -0
- package/dist/scripts/agents/claude-desktop.d.ts +25 -0
- package/dist/scripts/agents/claude-desktop.d.ts.map +1 -0
- package/dist/scripts/agents/claude-desktop.js +36 -0
- package/dist/scripts/agents/claude-desktop.js.map +1 -0
- package/dist/scripts/agents/claude-desktop.ts +39 -0
- package/dist/scripts/agents/cline.d.ts +22 -0
- package/dist/scripts/agents/cline.d.ts.map +1 -0
- package/dist/scripts/agents/cline.js +35 -0
- package/dist/scripts/agents/cline.js.map +1 -0
- package/dist/scripts/agents/cline.ts +38 -0
- package/dist/scripts/agents/continue.d.ts +20 -0
- package/dist/scripts/agents/continue.d.ts.map +1 -0
- package/dist/scripts/agents/continue.js +35 -0
- package/dist/scripts/agents/continue.js.map +1 -0
- package/dist/scripts/agents/continue.ts +38 -0
- package/dist/scripts/agents/cursor.d.ts +27 -0
- package/dist/scripts/agents/cursor.d.ts.map +1 -0
- package/dist/scripts/agents/cursor.js +38 -0
- package/dist/scripts/agents/cursor.js.map +1 -0
- package/dist/scripts/agents/cursor.ts +41 -0
- package/dist/scripts/cli/config-gen.d.ts +59 -0
- package/dist/scripts/cli/config-gen.d.ts.map +1 -0
- package/dist/scripts/cli/config-gen.js +156 -0
- package/dist/scripts/cli/config-gen.js.map +1 -0
- package/dist/scripts/cli/config-gen.ts +164 -0
- package/dist/scripts/cli/detect.d.ts +42 -0
- package/dist/scripts/cli/detect.d.ts.map +1 -0
- package/dist/scripts/cli/detect.js +131 -0
- package/dist/scripts/cli/detect.js.map +1 -0
- package/dist/scripts/cli/detect.ts +162 -0
- package/dist/scripts/cli/install.d.ts +31 -0
- package/dist/scripts/cli/install.d.ts.map +1 -0
- package/dist/scripts/cli/install.js +125 -0
- package/dist/scripts/cli/install.js.map +1 -0
- package/dist/scripts/cli/install.ts +157 -0
- package/dist/scripts/cli/status.d.ts +8 -0
- package/dist/scripts/cli/status.d.ts.map +1 -0
- package/dist/scripts/cli/status.js +39 -0
- package/dist/scripts/cli/status.js.map +1 -0
- package/dist/scripts/cli/status.ts +48 -0
- package/dist/scripts/cli/uninstall.d.ts +22 -0
- package/dist/scripts/cli/uninstall.d.ts.map +1 -0
- package/dist/scripts/cli/uninstall.js +141 -0
- package/dist/scripts/cli/uninstall.js.map +1 -0
- package/dist/scripts/cli/uninstall.ts +157 -0
- package/dist/scripts/cli.d.ts +23 -0
- package/dist/scripts/cli.d.ts.map +1 -0
- package/dist/scripts/cli.js +166 -0
- package/dist/scripts/cli.js.map +1 -0
- package/dist/scripts/cli.ts +173 -0
- package/dist/services/classifier/index.d.ts +36 -0
- package/dist/services/classifier/index.d.ts.map +1 -0
- package/dist/services/classifier/index.js +104 -0
- package/dist/services/classifier/index.js.map +1 -0
- package/dist/services/classifier/llm.d.ts +37 -0
- package/dist/services/classifier/llm.d.ts.map +1 -0
- package/dist/services/classifier/llm.js +119 -0
- package/dist/services/classifier/llm.js.map +1 -0
- package/dist/services/classifier/rules.d.ts +22 -0
- package/dist/services/classifier/rules.d.ts.map +1 -0
- package/dist/services/classifier/rules.js +98 -0
- package/dist/services/classifier/rules.js.map +1 -0
- package/dist/services/compressor/index.d.ts +3 -0
- package/dist/services/compressor/index.d.ts.map +1 -0
- package/dist/services/compressor/index.js +3 -0
- package/dist/services/compressor/index.js.map +1 -0
- package/dist/services/compressor/threshold.d.ts +35 -0
- package/dist/services/compressor/threshold.d.ts.map +1 -0
- package/dist/services/compressor/threshold.js +60 -0
- package/dist/services/compressor/threshold.js.map +1 -0
- package/dist/services/compressor/trigger.d.ts +24 -0
- package/dist/services/compressor/trigger.d.ts.map +1 -0
- package/dist/services/compressor/trigger.js +91 -0
- package/dist/services/compressor/trigger.js.map +1 -0
- package/dist/services/constraint-extractor.d.ts +25 -0
- package/dist/services/constraint-extractor.d.ts.map +1 -0
- package/dist/services/constraint-extractor.js +97 -0
- package/dist/services/constraint-extractor.js.map +1 -0
- package/dist/services/database-health.d.ts +22 -0
- package/dist/services/database-health.d.ts.map +1 -0
- package/dist/services/database-health.js +122 -0
- package/dist/services/database-health.js.map +1 -0
- package/dist/services/embedding-fixed.d.ts +9 -0
- package/dist/services/embedding-fixed.d.ts.map +1 -0
- package/dist/services/embedding-fixed.js +70 -0
- package/dist/services/embedding-fixed.js.map +1 -0
- package/dist/services/embedding-provider.d.ts +79 -0
- package/dist/services/embedding-provider.d.ts.map +1 -0
- package/dist/services/embedding-provider.js +229 -0
- package/dist/services/embedding-provider.js.map +1 -0
- package/dist/services/embedding.d.ts +17 -0
- package/dist/services/embedding.d.ts.map +1 -0
- package/dist/services/embedding.js +99 -0
- package/dist/services/embedding.js.map +1 -0
- package/dist/services/hnsw-index.d.ts +76 -0
- package/dist/services/hnsw-index.d.ts.map +1 -0
- package/dist/services/hnsw-index.js +301 -0
- package/dist/services/hnsw-index.js.map +1 -0
- package/dist/services/llm.d.ts +39 -0
- package/dist/services/llm.d.ts.map +1 -0
- package/dist/services/llm.js +207 -0
- package/dist/services/llm.js.map +1 -0
- package/dist/services/memory-tiers.d.ts +75 -0
- package/dist/services/memory-tiers.d.ts.map +1 -0
- package/dist/services/memory-tiers.js +275 -0
- package/dist/services/memory-tiers.js.map +1 -0
- package/dist/services/memory.d.ts +33 -0
- package/dist/services/memory.d.ts.map +1 -0
- package/dist/services/memory.js +209 -0
- package/dist/services/memory.js.map +1 -0
- package/dist/services/multi-agent-sharing.d.ts +83 -0
- package/dist/services/multi-agent-sharing.d.ts.map +1 -0
- package/dist/services/multi-agent-sharing.js +278 -0
- package/dist/services/multi-agent-sharing.js.map +1 -0
- package/dist/services/reranker.d.ts +88 -0
- package/dist/services/reranker.d.ts.map +1 -0
- package/dist/services/reranker.js +234 -0
- package/dist/services/reranker.js.map +1 -0
- package/dist/services/triple-extractor.d.ts +35 -0
- package/dist/services/triple-extractor.d.ts.map +1 -0
- package/dist/services/triple-extractor.js +293 -0
- package/dist/services/triple-extractor.js.map +1 -0
- package/dist/services/vector-provider.d.ts +40 -0
- package/dist/services/vector-provider.d.ts.map +1 -0
- package/dist/services/vector-provider.js +225 -0
- package/dist/services/vector-provider.js.map +1 -0
- package/dist/utils/after-chain-executor.d.ts +26 -0
- package/dist/utils/after-chain-executor.d.ts.map +1 -0
- package/dist/utils/after-chain-executor.js +135 -0
- package/dist/utils/after-chain-executor.js.map +1 -0
- package/dist/utils/after-chain.d.ts +94 -0
- package/dist/utils/after-chain.d.ts.map +1 -0
- package/dist/utils/after-chain.js +155 -0
- package/dist/utils/after-chain.js.map +1 -0
- package/dist/utils/db.d.ts +29 -0
- package/dist/utils/db.d.ts.map +1 -0
- package/dist/utils/db.js +201 -0
- package/dist/utils/db.js.map +1 -0
- package/dist/utils/encryption.d.ts +87 -0
- package/dist/utils/encryption.d.ts.map +1 -0
- package/dist/utils/encryption.js +175 -0
- package/dist/utils/encryption.js.map +1 -0
- package/dist/utils/errors.d.ts +35 -0
- package/dist/utils/errors.d.ts.map +1 -0
- package/dist/utils/errors.js +56 -0
- package/dist/utils/errors.js.map +1 -0
- package/dist/utils/logger.d.ts +27 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +177 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/priority.d.ts +26 -0
- package/dist/utils/priority.d.ts.map +1 -0
- package/dist/utils/priority.js +43 -0
- package/dist/utils/priority.js.map +1 -0
- package/dist/utils/watchdog.d.ts +57 -0
- package/dist/utils/watchdog.d.ts.map +1 -0
- package/dist/utils/watchdog.js +164 -0
- package/dist/utils/watchdog.js.map +1 -0
- package/package.json +78 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"priority.js","sourceRoot":"","sources":["../../src/utils/priority.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,gBAAgB,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAE7G;;GAEG;AACH,MAAM,UAAU,kBAAkB,CAAC,SAAe,EAAE,QAAiB;IACnE,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,qBAAqB,CAAC;IAC/B,CAAC;IAED,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACvB,MAAM,SAAS,GAAG,CAAC,GAAG,GAAG,SAAS,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;IAEtE,6CAA6C;IAC7C,OAAO,IAAI,CAAC,GAAG,CAAC,oBAAoB,EAAE,SAAS,CAAC,CAAC;AACnD,CAAC;AAED;;;;;;;;;;GAUG;AACH,MAAM,UAAU,sBAAsB,CACpC,QAAkB,EAClB,WAAmB,EACnB,SAAe,EACf,QAAiB;IAEjB,MAAM,MAAM,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC;IAC1C,MAAM,KAAK,GAAG,kBAAkB,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;IACtD,MAAM,WAAW,GAAG,CAAC,GAAG,WAAW,GAAG,GAAG,CAAC;IAE1C,OAAO,MAAM,GAAG,WAAW,GAAG,KAAK,CAAC;AACtC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,iBAAiB,CAAC,QAAkB;IAClD,OAAO,gBAAgB,CAAC,QAAQ,CAAC,CAAC;AACpC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,QAAkB;IAC/C,OAAO,QAAQ,KAAK,UAAU,IAAI,QAAQ,KAAK,YAAY,CAAC;AAC9D,CAAC"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Watchdog 权限架构
|
|
3
|
+
*
|
|
4
|
+
* 核心设计:
|
|
5
|
+
* - 工具分为 read(只读)和 write(读写)两类
|
|
6
|
+
* - 主 agent 持只读 token,只能调用 read 工具
|
|
7
|
+
* - 特殊 token 可绕过限制(如 watchdog agent)
|
|
8
|
+
* - 权限检查在工具执行前进行
|
|
9
|
+
*/
|
|
10
|
+
/** 工具权限级别 */
|
|
11
|
+
export type ToolPermission = 'read' | 'write';
|
|
12
|
+
/** 权限配置 */
|
|
13
|
+
export interface PermissionConfig {
|
|
14
|
+
/** 工具名称 */
|
|
15
|
+
tool: string;
|
|
16
|
+
/** 权限级别 */
|
|
17
|
+
permission: ToolPermission;
|
|
18
|
+
/** 描述 */
|
|
19
|
+
description?: string;
|
|
20
|
+
}
|
|
21
|
+
/** 所有工具的权限配置 */
|
|
22
|
+
export declare const TOOL_PERMISSIONS: PermissionConfig[];
|
|
23
|
+
/** 只读工具列表 */
|
|
24
|
+
export declare const READ_ONLY_TOOLS: string[];
|
|
25
|
+
/** 读写工具列表 */
|
|
26
|
+
export declare const READ_WRITE_TOOLS: string[];
|
|
27
|
+
/** 权限验证结果 */
|
|
28
|
+
export interface PermissionCheckResult {
|
|
29
|
+
allowed: boolean;
|
|
30
|
+
tool: string;
|
|
31
|
+
token: string;
|
|
32
|
+
requiredPermission: ToolPermission;
|
|
33
|
+
reason?: string;
|
|
34
|
+
}
|
|
35
|
+
/** Watchdog Token 管理器 */
|
|
36
|
+
export declare class WatchdogTokenManager {
|
|
37
|
+
private readToken;
|
|
38
|
+
private writeToken;
|
|
39
|
+
private watchdogToken;
|
|
40
|
+
constructor();
|
|
41
|
+
/** 设置 token */
|
|
42
|
+
setToken(type: 'read' | 'write' | 'watchdog', token: string): void;
|
|
43
|
+
/** 获取当前 token 类型 */
|
|
44
|
+
getCurrentTokenType(token: string): 'read' | 'write' | 'watchdog' | 'unknown';
|
|
45
|
+
/** 检查工具调用权限 */
|
|
46
|
+
checkPermission(tool: string, token: string): PermissionCheckResult;
|
|
47
|
+
/** 检查是否有任何 token 配置 */
|
|
48
|
+
hasTokens(): boolean;
|
|
49
|
+
/** 生成随机 token */
|
|
50
|
+
static generateToken(length?: number): string;
|
|
51
|
+
}
|
|
52
|
+
export declare function getWatchdogTokenManager(): WatchdogTokenManager;
|
|
53
|
+
/** 便捷函数:检查工具权限 */
|
|
54
|
+
export declare function checkPermission(tool: string, token: string): PermissionCheckResult;
|
|
55
|
+
/** 重置 token 管理器(测试用) */
|
|
56
|
+
export declare function resetWatchdogTokenManager(): void;
|
|
57
|
+
//# sourceMappingURL=watchdog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"watchdog.d.ts","sourceRoot":"","sources":["../../src/utils/watchdog.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH,aAAa;AACb,MAAM,MAAM,cAAc,GAAG,MAAM,GAAG,OAAO,CAAC;AAE9C,WAAW;AACX,MAAM,WAAW,gBAAgB;IAC/B,WAAW;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW;IACX,UAAU,EAAE,cAAc,CAAC;IAC3B,SAAS;IACT,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,gBAAgB;AAChB,eAAO,MAAM,gBAAgB,EAAE,gBAAgB,EAoB9C,CAAC;AAEF,aAAa;AACb,eAAO,MAAM,eAAe,UAAyE,CAAC;AAEtG,aAAa;AACb,eAAO,MAAM,gBAAgB,UAA0E,CAAC;AAExG,aAAa;AACb,MAAM,WAAW,qBAAqB;IACpC,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,kBAAkB,EAAE,cAAc,CAAC;IACnC,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,yBAAyB;AACzB,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,SAAS,CAAc;IAC/B,OAAO,CAAC,UAAU,CAAc;IAChC,OAAO,CAAC,aAAa,CAAc;;IAQnC,eAAe;IACf,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,GAAG,UAAU,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAclE,oBAAoB;IACpB,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,UAAU,GAAG,SAAS;IAO7E,eAAe;IACf,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,qBAAqB;IAsEnE,uBAAuB;IACvB,SAAS,IAAI,OAAO;IAIpB,iBAAiB;IACjB,MAAM,CAAC,aAAa,CAAC,MAAM,SAAK,GAAG,MAAM;CAQ1C;AAKD,wBAAgB,uBAAuB,IAAI,oBAAoB,CAK9D;AAED,kBAAkB;AAClB,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,qBAAqB,CAElF;AAED,wBAAwB;AACxB,wBAAgB,yBAAyB,IAAI,IAAI,CAEhD"}
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Watchdog 权限架构
|
|
3
|
+
*
|
|
4
|
+
* 核心设计:
|
|
5
|
+
* - 工具分为 read(只读)和 write(读写)两类
|
|
6
|
+
* - 主 agent 持只读 token,只能调用 read 工具
|
|
7
|
+
* - 特殊 token 可绕过限制(如 watchdog agent)
|
|
8
|
+
* - 权限检查在工具执行前进行
|
|
9
|
+
*/
|
|
10
|
+
import { logger } from './logger.js';
|
|
11
|
+
/** 所有工具的权限配置 */
|
|
12
|
+
export const TOOL_PERMISSIONS = [
|
|
13
|
+
// 只读工具
|
|
14
|
+
{ tool: 'memory_recall', permission: 'read', description: '读取记忆' },
|
|
15
|
+
{ tool: 'memory_search', permission: 'read', description: '搜索记忆' },
|
|
16
|
+
{ tool: 'memory_stats', permission: 'read', description: '获取统计' },
|
|
17
|
+
{ tool: 'intelligent_recall', permission: 'read', description: '智能召回' },
|
|
18
|
+
{ tool: 'dual_mode_execute', permission: 'read', description: '双模式执行(仅软引导)' },
|
|
19
|
+
{ tool: 'data_summary', permission: 'read', description: '数据摘要(GDPR)' },
|
|
20
|
+
{ tool: 'memory_extract', permission: 'read', description: '约束提取(仅分析)' },
|
|
21
|
+
// 读写工具
|
|
22
|
+
{ tool: 'memory_store', permission: 'write', description: '存储记忆' },
|
|
23
|
+
{ tool: 'memory_store_batch', permission: 'write', description: '批量存储' },
|
|
24
|
+
{ tool: 'memory_delete_batch', permission: 'write', description: '批量删除' },
|
|
25
|
+
{ tool: 'memory_anchor', permission: 'write', description: '锚定记忆' },
|
|
26
|
+
{ tool: 'context_compress', permission: 'write', description: '压缩上下文' },
|
|
27
|
+
{ tool: 'project_create', permission: 'write', description: '创建项目' },
|
|
28
|
+
{ tool: 'configure_llm', permission: 'write', description: '配置 LLM' },
|
|
29
|
+
{ tool: 'gdpr_export', permission: 'write', description: 'GDPR 导出' },
|
|
30
|
+
{ tool: 'gdpr_delete', permission: 'write', description: 'GDPR 删除' },
|
|
31
|
+
];
|
|
32
|
+
/** 只读工具列表 */
|
|
33
|
+
export const READ_ONLY_TOOLS = TOOL_PERMISSIONS.filter(p => p.permission === 'read').map(p => p.tool);
|
|
34
|
+
/** 读写工具列表 */
|
|
35
|
+
export const READ_WRITE_TOOLS = TOOL_PERMISSIONS.filter(p => p.permission === 'write').map(p => p.tool);
|
|
36
|
+
/** Watchdog Token 管理器 */
|
|
37
|
+
export class WatchdogTokenManager {
|
|
38
|
+
readToken = '';
|
|
39
|
+
writeToken = '';
|
|
40
|
+
watchdogToken = '';
|
|
41
|
+
constructor() {
|
|
42
|
+
this.readToken = process.env.CG_READ_TOKEN || '';
|
|
43
|
+
this.writeToken = process.env.CG_WRITE_TOKEN || '';
|
|
44
|
+
this.watchdogToken = process.env.CG_WATCHDOG_TOKEN || '';
|
|
45
|
+
}
|
|
46
|
+
/** 设置 token */
|
|
47
|
+
setToken(type, token) {
|
|
48
|
+
switch (type) {
|
|
49
|
+
case 'read':
|
|
50
|
+
this.readToken = token;
|
|
51
|
+
break;
|
|
52
|
+
case 'write':
|
|
53
|
+
this.writeToken = token;
|
|
54
|
+
break;
|
|
55
|
+
case 'watchdog':
|
|
56
|
+
this.watchdogToken = token;
|
|
57
|
+
break;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
/** 获取当前 token 类型 */
|
|
61
|
+
getCurrentTokenType(token) {
|
|
62
|
+
if (token === this.watchdogToken && this.watchdogToken)
|
|
63
|
+
return 'watchdog';
|
|
64
|
+
if (token === this.writeToken && this.writeToken)
|
|
65
|
+
return 'write';
|
|
66
|
+
if (token === this.readToken && this.readToken)
|
|
67
|
+
return 'read';
|
|
68
|
+
return 'unknown';
|
|
69
|
+
}
|
|
70
|
+
/** 检查工具调用权限 */
|
|
71
|
+
checkPermission(tool, token) {
|
|
72
|
+
const start = performance.now();
|
|
73
|
+
const toolConfig = TOOL_PERMISSIONS.find(p => p.tool === tool);
|
|
74
|
+
if (!toolConfig) {
|
|
75
|
+
logger.debug('Permission check: unknown tool', { tool, tokenType: this.getCurrentTokenType(token) });
|
|
76
|
+
return {
|
|
77
|
+
allowed: false,
|
|
78
|
+
tool,
|
|
79
|
+
token,
|
|
80
|
+
requiredPermission: 'read',
|
|
81
|
+
reason: `Unknown tool: ${tool}`,
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
if (token === this.watchdogToken && this.watchdogToken) {
|
|
85
|
+
const latencyMs = Math.round(performance.now() - start);
|
|
86
|
+
logger.debug('Permission check: watchdog bypass', { tool, requiredPermission: toolConfig.permission, latencyMs });
|
|
87
|
+
return {
|
|
88
|
+
allowed: true,
|
|
89
|
+
tool,
|
|
90
|
+
token,
|
|
91
|
+
requiredPermission: toolConfig.permission,
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
const tokenType = this.getCurrentTokenType(token);
|
|
95
|
+
if (tokenType === 'unknown' || !token) {
|
|
96
|
+
if (toolConfig.permission === 'read') {
|
|
97
|
+
const latencyMs = Math.round(performance.now() - start);
|
|
98
|
+
logger.debug('Permission check: no token, read allowed', { tool, latencyMs });
|
|
99
|
+
return {
|
|
100
|
+
allowed: true,
|
|
101
|
+
tool,
|
|
102
|
+
token: token || '(none)',
|
|
103
|
+
requiredPermission: toolConfig.permission,
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
logger.debug('Permission check: no token, write denied', { tool, requiredPermission: toolConfig.permission });
|
|
107
|
+
return {
|
|
108
|
+
allowed: false,
|
|
109
|
+
tool,
|
|
110
|
+
token: token || '(none)',
|
|
111
|
+
requiredPermission: toolConfig.permission,
|
|
112
|
+
reason: `Tool '${tool}' requires write permission but no write token provided`,
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
if (tokenType === 'read' && toolConfig.permission === 'write') {
|
|
116
|
+
logger.debug('Permission check: read token cannot write', { tool, requiredPermission: toolConfig.permission });
|
|
117
|
+
return {
|
|
118
|
+
allowed: false,
|
|
119
|
+
tool,
|
|
120
|
+
token,
|
|
121
|
+
requiredPermission: toolConfig.permission,
|
|
122
|
+
reason: `Read-only token cannot execute write tool '${tool}'`,
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
const latencyMs = Math.round(performance.now() - start);
|
|
126
|
+
logger.debug('Permission check: allowed', { tool, tokenType, requiredPermission: toolConfig.permission, latencyMs });
|
|
127
|
+
return {
|
|
128
|
+
allowed: true,
|
|
129
|
+
tool,
|
|
130
|
+
token,
|
|
131
|
+
requiredPermission: toolConfig.permission,
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
/** 检查是否有任何 token 配置 */
|
|
135
|
+
hasTokens() {
|
|
136
|
+
return !!(this.readToken || this.writeToken || this.watchdogToken);
|
|
137
|
+
}
|
|
138
|
+
/** 生成随机 token */
|
|
139
|
+
static generateToken(length = 32) {
|
|
140
|
+
const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
|
|
141
|
+
let result = '';
|
|
142
|
+
for (let i = 0; i < length; i++) {
|
|
143
|
+
result += chars.charAt(Math.floor(Math.random() * chars.length));
|
|
144
|
+
}
|
|
145
|
+
return result;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
// 全局单例
|
|
149
|
+
let _tokenManager = null;
|
|
150
|
+
export function getWatchdogTokenManager() {
|
|
151
|
+
if (!_tokenManager) {
|
|
152
|
+
_tokenManager = new WatchdogTokenManager();
|
|
153
|
+
}
|
|
154
|
+
return _tokenManager;
|
|
155
|
+
}
|
|
156
|
+
/** 便捷函数:检查工具权限 */
|
|
157
|
+
export function checkPermission(tool, token) {
|
|
158
|
+
return getWatchdogTokenManager().checkPermission(tool, token);
|
|
159
|
+
}
|
|
160
|
+
/** 重置 token 管理器(测试用) */
|
|
161
|
+
export function resetWatchdogTokenManager() {
|
|
162
|
+
_tokenManager = null;
|
|
163
|
+
}
|
|
164
|
+
//# sourceMappingURL=watchdog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"watchdog.js","sourceRoot":"","sources":["../../src/utils/watchdog.ts"],"names":[],"mappings":"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"}
|
package/package.json
ADDED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "context-gatekeeper",
|
|
3
|
+
"version": "0.3.0",
|
|
4
|
+
"description": "MCP context management with intelligent constraint detection. AutoSkill-style extraction, MemGate-style recall, MPR-style dual-mode execution. Universal install for Cursor / Claude Desktop / Claude Code / Cline / Continue.",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "dist/src/index.js",
|
|
7
|
+
"types": "dist/src/index.d.ts",
|
|
8
|
+
"bin": {
|
|
9
|
+
"context-gatekeeper": "dist/src/mcp/server.js",
|
|
10
|
+
"context-gatekeeper-cli": "bin/context-gatekeeper-cli.js"
|
|
11
|
+
},
|
|
12
|
+
"files": [
|
|
13
|
+
"dist",
|
|
14
|
+
"bin",
|
|
15
|
+
"README.md",
|
|
16
|
+
"README.zh.md",
|
|
17
|
+
"LICENSE"
|
|
18
|
+
],
|
|
19
|
+
"scripts": {
|
|
20
|
+
"build": "tsc && node scripts/copy-for-publish.mjs",
|
|
21
|
+
"build:js": "tsc",
|
|
22
|
+
"copy:scripts": "node scripts/copy-for-publish.mjs",
|
|
23
|
+
"prepack": "npm run build",
|
|
24
|
+
"prepublishOnly": "npm run build",
|
|
25
|
+
"prepublish": "npm run build",
|
|
26
|
+
"dev": "tsc --watch",
|
|
27
|
+
"test": "vitest run",
|
|
28
|
+
"test:watch": "vitest",
|
|
29
|
+
"test:coverage": "vitest run --coverage",
|
|
30
|
+
"test:agents": "tsx scripts/cross-agent-test.ts",
|
|
31
|
+
"cli": "tsx scripts/cli.ts",
|
|
32
|
+
"lint": "eslint src --ext .ts"
|
|
33
|
+
},
|
|
34
|
+
"keywords": [
|
|
35
|
+
"mcp",
|
|
36
|
+
"context",
|
|
37
|
+
"agent",
|
|
38
|
+
"memory",
|
|
39
|
+
"constraint",
|
|
40
|
+
"autoskill",
|
|
41
|
+
"memgate",
|
|
42
|
+
"meta-policy",
|
|
43
|
+
"token",
|
|
44
|
+
"universal",
|
|
45
|
+
"cursor",
|
|
46
|
+
"claude",
|
|
47
|
+
"cline",
|
|
48
|
+
"continue"
|
|
49
|
+
],
|
|
50
|
+
"author": "context-gatekeeper contributors",
|
|
51
|
+
"license": "MIT",
|
|
52
|
+
"repository": {
|
|
53
|
+
"type": "git",
|
|
54
|
+
"url": "https://github.com/changebusiness/context-gatekeeper.git"
|
|
55
|
+
},
|
|
56
|
+
"bugs": {
|
|
57
|
+
"url": "https://github.com/changebusiness/context-gatekeeper/issues"
|
|
58
|
+
},
|
|
59
|
+
"homepage": "https://github.com/changebusiness/context-gatekeeper#readme",
|
|
60
|
+
"dependencies": {
|
|
61
|
+
"@modelcontextprotocol/sdk": "^1.29.0",
|
|
62
|
+
"sql.js": "^1.10.0",
|
|
63
|
+
"uuid": "^9.0.0",
|
|
64
|
+
"zod": "^3.22.0"
|
|
65
|
+
},
|
|
66
|
+
"devDependencies": {
|
|
67
|
+
"@types/node": "^20.10.0",
|
|
68
|
+
"@types/sql.js": "^1.4.9",
|
|
69
|
+
"@types/uuid": "^9.0.0",
|
|
70
|
+
"@vitest/coverage-v8": "^1.6.1",
|
|
71
|
+
"tsx": "^4.22.4",
|
|
72
|
+
"typescript": "^5.3.0",
|
|
73
|
+
"vitest": "^1.2.0"
|
|
74
|
+
},
|
|
75
|
+
"engines": {
|
|
76
|
+
"node": ">=18.0.0"
|
|
77
|
+
}
|
|
78
|
+
}
|