@gencode/agents 0.0.9 → 0.0.10
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/dist/builtin-provider-C0d7-NZt.js +66 -0
- package/dist/config/index.d.ts +2 -9
- package/dist/config/index.js +1 -9
- package/dist/config-DG3Q1aJ6.js +1 -0
- package/dist/{index-JD6Ye-N5.d.ts → index-BdfpRxFA.d.ts} +7 -8
- package/dist/index.d.ts +1603 -40
- package/dist/index.js +504 -35
- package/dist/provider-registry-rVbsCDN2.js +1 -0
- package/dist/rolldown-runtime-CNxR59P3.js +1 -0
- package/package.json +2 -2
- package/dist/bootstrap/bootstrap-layout.d.ts +0 -23
- package/dist/bootstrap/bootstrap-layout.d.ts.map +0 -1
- package/dist/bootstrap/bootstrap-layout.js +0 -151
- package/dist/bootstrap/bootstrap-layout.js.map +0 -1
- package/dist/bootstrap/bootstrap.d.ts +0 -36
- package/dist/bootstrap/bootstrap.d.ts.map +0 -1
- package/dist/bootstrap/bootstrap.js +0 -136
- package/dist/bootstrap/bootstrap.js.map +0 -1
- package/dist/bootstrap/templates/AGENTS_MD.d.ts +0 -2
- package/dist/bootstrap/templates/AGENTS_MD.d.ts.map +0 -1
- package/dist/bootstrap/templates/AGENTS_MD.js +0 -223
- package/dist/bootstrap/templates/AGENTS_MD.js.map +0 -1
- package/dist/bootstrap/templates/BOOTSTRAP_MD.d.ts +0 -2
- package/dist/bootstrap/templates/BOOTSTRAP_MD.d.ts.map +0 -1
- package/dist/bootstrap/templates/BOOTSTRAP_MD.js +0 -66
- package/dist/bootstrap/templates/BOOTSTRAP_MD.js.map +0 -1
- package/dist/bootstrap/templates/HEARTBEAT_MD.d.ts +0 -2
- package/dist/bootstrap/templates/HEARTBEAT_MD.d.ts.map +0 -1
- package/dist/bootstrap/templates/HEARTBEAT_MD.js +0 -16
- package/dist/bootstrap/templates/HEARTBEAT_MD.js.map +0 -1
- package/dist/bootstrap/templates/IDENTITY_MD.d.ts +0 -2
- package/dist/bootstrap/templates/IDENTITY_MD.d.ts.map +0 -1
- package/dist/bootstrap/templates/IDENTITY_MD.js +0 -31
- package/dist/bootstrap/templates/IDENTITY_MD.js.map +0 -1
- package/dist/bootstrap/templates/SOUL_MD.d.ts +0 -2
- package/dist/bootstrap/templates/SOUL_MD.d.ts.map +0 -1
- package/dist/bootstrap/templates/SOUL_MD.js +0 -47
- package/dist/bootstrap/templates/SOUL_MD.js.map +0 -1
- package/dist/bootstrap/templates/TOOLS_MD.d.ts +0 -2
- package/dist/bootstrap/templates/TOOLS_MD.d.ts.map +0 -1
- package/dist/bootstrap/templates/TOOLS_MD.js +0 -51
- package/dist/bootstrap/templates/TOOLS_MD.js.map +0 -1
- package/dist/bootstrap/templates/USER_MD.d.ts +0 -2
- package/dist/bootstrap/templates/USER_MD.d.ts.map +0 -1
- package/dist/bootstrap/templates/USER_MD.js +0 -27
- package/dist/bootstrap/templates/USER_MD.js.map +0 -1
- package/dist/bootstrap/templates/index.d.ts +0 -3
- package/dist/bootstrap/templates/index.d.ts.map +0 -1
- package/dist/bootstrap/templates/index.js +0 -26
- package/dist/bootstrap/templates/index.js.map +0 -1
- package/dist/commands/compact.d.ts +0 -28
- package/dist/commands/compact.d.ts.map +0 -1
- package/dist/commands/compact.js +0 -57
- package/dist/commands/compact.js.map +0 -1
- package/dist/commands/help.d.ts +0 -3
- package/dist/commands/help.d.ts.map +0 -1
- package/dist/commands/help.js +0 -50
- package/dist/commands/help.js.map +0 -1
- package/dist/commands/index.d.ts +0 -6
- package/dist/commands/index.d.ts.map +0 -1
- package/dist/commands/index.js +0 -32
- package/dist/commands/index.js.map +0 -1
- package/dist/commands/new.d.ts +0 -3
- package/dist/commands/new.d.ts.map +0 -1
- package/dist/commands/new.js +0 -15
- package/dist/commands/new.js.map +0 -1
- package/dist/commands/registry.d.ts +0 -11
- package/dist/commands/registry.d.ts.map +0 -1
- package/dist/commands/registry.js +0 -122
- package/dist/commands/registry.js.map +0 -1
- package/dist/commands/reset.d.ts +0 -3
- package/dist/commands/reset.d.ts.map +0 -1
- package/dist/commands/reset.js +0 -4
- package/dist/commands/reset.js.map +0 -1
- package/dist/commands/skill.d.ts +0 -7
- package/dist/commands/skill.d.ts.map +0 -1
- package/dist/commands/skill.js +0 -23
- package/dist/commands/skill.js.map +0 -1
- package/dist/commands/types.d.ts +0 -57
- package/dist/commands/types.d.ts.map +0 -1
- package/dist/commands/types.js +0 -2
- package/dist/commands/types.js.map +0 -1
- package/dist/config/agents-config.d.ts +0 -85
- package/dist/config/agents-config.d.ts.map +0 -1
- package/dist/config/agents-config.js +0 -257
- package/dist/config/agents-config.js.map +0 -1
- package/dist/config/index.d.ts.map +0 -1
- package/dist/config/index.js.map +0 -1
- package/dist/config/types.d.ts +0 -87
- package/dist/config/types.d.ts.map +0 -1
- package/dist/config/types.js +0 -6
- package/dist/config/types.js.map +0 -1
- package/dist/config-DJX-VM7S.js +0 -198
- package/dist/config-DJX-VM7S.js.map +0 -1
- package/dist/history/compaction.d.ts +0 -42
- package/dist/history/compaction.d.ts.map +0 -1
- package/dist/history/compaction.js +0 -135
- package/dist/history/compaction.js.map +0 -1
- package/dist/history/index.d.ts +0 -57
- package/dist/history/index.d.ts.map +0 -1
- package/dist/history/index.js +0 -145
- package/dist/history/index.js.map +0 -1
- package/dist/history/limit.d.ts +0 -13
- package/dist/history/limit.d.ts.map +0 -1
- package/dist/history/limit.js +0 -32
- package/dist/history/limit.js.map +0 -1
- package/dist/history/repair.d.ts +0 -13
- package/dist/history/repair.d.ts.map +0 -1
- package/dist/history/repair.js +0 -25
- package/dist/history/repair.js.map +0 -1
- package/dist/history/token-estimate.d.ts +0 -22
- package/dist/history/token-estimate.d.ts.map +0 -1
- package/dist/history/token-estimate.js +0 -38
- package/dist/history/token-estimate.js.map +0 -1
- package/dist/index-JD6Ye-N5.d.ts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/llm/client.d.ts +0 -53
- package/dist/llm/client.d.ts.map +0 -1
- package/dist/llm/client.js +0 -214
- package/dist/llm/client.js.map +0 -1
- package/dist/llm/openai-completions-compat.d.ts +0 -23
- package/dist/llm/openai-completions-compat.d.ts.map +0 -1
- package/dist/llm/openai-completions-compat.js +0 -602
- package/dist/llm/openai-completions-compat.js.map +0 -1
- package/dist/llm/openai-stream-error.d.ts +0 -11
- package/dist/llm/openai-stream-error.d.ts.map +0 -1
- package/dist/llm/openai-stream-error.js +0 -77
- package/dist/llm/openai-stream-error.js.map +0 -1
- package/dist/loop-detection/session-state.d.ts +0 -5
- package/dist/loop-detection/session-state.d.ts.map +0 -1
- package/dist/loop-detection/session-state.js +0 -16
- package/dist/loop-detection/session-state.js.map +0 -1
- package/dist/loop-detection/tool-loop-detection.d.ts +0 -122
- package/dist/loop-detection/tool-loop-detection.d.ts.map +0 -1
- package/dist/loop-detection/tool-loop-detection.js +0 -516
- package/dist/loop-detection/tool-loop-detection.js.map +0 -1
- package/dist/manager-qXa-NP0p.js +0 -1651
- package/dist/manager-qXa-NP0p.js.map +0 -1
- package/dist/memory/builtin-provider.d.ts +0 -5
- package/dist/memory/builtin-provider.d.ts.map +0 -1
- package/dist/memory/builtin-provider.js +0 -42
- package/dist/memory/builtin-provider.js.map +0 -1
- package/dist/memory/config.d.ts +0 -50
- package/dist/memory/config.d.ts.map +0 -1
- package/dist/memory/config.js +0 -46
- package/dist/memory/config.js.map +0 -1
- package/dist/memory/embedding-registry.d.ts +0 -37
- package/dist/memory/embedding-registry.d.ts.map +0 -1
- package/dist/memory/embedding-registry.js +0 -56
- package/dist/memory/embedding-registry.js.map +0 -1
- package/dist/memory/embeddings.d.ts +0 -11
- package/dist/memory/embeddings.d.ts.map +0 -1
- package/dist/memory/embeddings.js +0 -40
- package/dist/memory/embeddings.js.map +0 -1
- package/dist/memory/fs-utils.d.ts +0 -12
- package/dist/memory/fs-utils.d.ts.map +0 -1
- package/dist/memory/fs-utils.js +0 -24
- package/dist/memory/fs-utils.js.map +0 -1
- package/dist/memory/hybrid.d.ts +0 -43
- package/dist/memory/hybrid.d.ts.map +0 -1
- package/dist/memory/hybrid.js +0 -80
- package/dist/memory/hybrid.js.map +0 -1
- package/dist/memory/internal.d.ts +0 -28
- package/dist/memory/internal.d.ts.map +0 -1
- package/dist/memory/internal.js +0 -270
- package/dist/memory/internal.js.map +0 -1
- package/dist/memory/manager-search.d.ts +0 -61
- package/dist/memory/manager-search.d.ts.map +0 -1
- package/dist/memory/manager-search.js +0 -106
- package/dist/memory/manager-search.js.map +0 -1
- package/dist/memory/manager.d.ts +0 -126
- package/dist/memory/manager.d.ts.map +0 -1
- package/dist/memory/manager.js +0 -1006
- package/dist/memory/manager.js.map +0 -1
- package/dist/memory/memory-schema.d.ts +0 -11
- package/dist/memory/memory-schema.d.ts.map +0 -1
- package/dist/memory/memory-schema.js +0 -78
- package/dist/memory/memory-schema.js.map +0 -1
- package/dist/memory/memory.d.ts +0 -46
- package/dist/memory/memory.d.ts.map +0 -1
- package/dist/memory/memory.js +0 -127
- package/dist/memory/memory.js.map +0 -1
- package/dist/memory/mmr.d.ts +0 -22
- package/dist/memory/mmr.d.ts.map +0 -1
- package/dist/memory/mmr.js +0 -112
- package/dist/memory/mmr.js.map +0 -1
- package/dist/memory/provider-registry.d.ts +0 -29
- package/dist/memory/provider-registry.d.ts.map +0 -1
- package/dist/memory/provider-registry.js +0 -58
- package/dist/memory/provider-registry.js.map +0 -1
- package/dist/memory/provider.d.ts +0 -40
- package/dist/memory/provider.d.ts.map +0 -1
- package/dist/memory/provider.js +0 -2
- package/dist/memory/provider.js.map +0 -1
- package/dist/memory/session-files.d.ts +0 -13
- package/dist/memory/session-files.d.ts.map +0 -1
- package/dist/memory/session-files.js +0 -116
- package/dist/memory/session-files.js.map +0 -1
- package/dist/memory/sqlite-vec.d.ts +0 -10
- package/dist/memory/sqlite-vec.d.ts.map +0 -1
- package/dist/memory/sqlite-vec.js +0 -20
- package/dist/memory/sqlite-vec.js.map +0 -1
- package/dist/memory/sqlite.d.ts +0 -2
- package/dist/memory/sqlite.d.ts.map +0 -1
- package/dist/memory/sqlite.js +0 -12
- package/dist/memory/sqlite.js.map +0 -1
- package/dist/memory/temporal-decay.d.ts +0 -26
- package/dist/memory/temporal-decay.d.ts.map +0 -1
- package/dist/memory/temporal-decay.js +0 -119
- package/dist/memory/temporal-decay.js.map +0 -1
- package/dist/memory/watch-bridge.d.ts +0 -20
- package/dist/memory/watch-bridge.d.ts.map +0 -1
- package/dist/memory/watch-bridge.js +0 -128
- package/dist/memory/watch-bridge.js.map +0 -1
- package/dist/message.d.ts +0 -11
- package/dist/message.d.ts.map +0 -1
- package/dist/message.js +0 -46
- package/dist/message.js.map +0 -1
- package/dist/plugins/boundary-file-read.d.ts +0 -13
- package/dist/plugins/boundary-file-read.d.ts.map +0 -1
- package/dist/plugins/boundary-file-read.js +0 -31
- package/dist/plugins/boundary-file-read.js.map +0 -1
- package/dist/plugins/config-state.d.ts +0 -35
- package/dist/plugins/config-state.d.ts.map +0 -1
- package/dist/plugins/config-state.js +0 -97
- package/dist/plugins/config-state.js.map +0 -1
- package/dist/plugins/discovery.d.ts +0 -21
- package/dist/plugins/discovery.d.ts.map +0 -1
- package/dist/plugins/discovery.js +0 -425
- package/dist/plugins/discovery.js.map +0 -1
- package/dist/plugins/hooks.d.ts +0 -133
- package/dist/plugins/hooks.d.ts.map +0 -1
- package/dist/plugins/hooks.js +0 -19
- package/dist/plugins/hooks.js.map +0 -1
- package/dist/plugins/index.d.ts +0 -20
- package/dist/plugins/index.d.ts.map +0 -1
- package/dist/plugins/index.js +0 -11
- package/dist/plugins/index.js.map +0 -1
- package/dist/plugins/loader.d.ts +0 -60
- package/dist/plugins/loader.d.ts.map +0 -1
- package/dist/plugins/loader.js +0 -224
- package/dist/plugins/loader.js.map +0 -1
- package/dist/plugins/manager.d.ts +0 -20
- package/dist/plugins/manager.d.ts.map +0 -1
- package/dist/plugins/manager.js +0 -33
- package/dist/plugins/manager.js.map +0 -1
- package/dist/plugins/manifest-registry.d.ts +0 -15
- package/dist/plugins/manifest-registry.d.ts.map +0 -1
- package/dist/plugins/manifest-registry.js +0 -37
- package/dist/plugins/manifest-registry.js.map +0 -1
- package/dist/plugins/manifest.d.ts +0 -6
- package/dist/plugins/manifest.d.ts.map +0 -1
- package/dist/plugins/manifest.js +0 -80
- package/dist/plugins/manifest.js.map +0 -1
- package/dist/plugins/path-safety.d.ts +0 -6
- package/dist/plugins/path-safety.d.ts.map +0 -1
- package/dist/plugins/path-safety.js +0 -32
- package/dist/plugins/path-safety.js.map +0 -1
- package/dist/plugins/runtime-context.d.ts +0 -12
- package/dist/plugins/runtime-context.d.ts.map +0 -1
- package/dist/plugins/runtime-context.js +0 -2
- package/dist/plugins/runtime-context.js.map +0 -1
- package/dist/plugins/runtime.d.ts +0 -20
- package/dist/plugins/runtime.d.ts.map +0 -1
- package/dist/plugins/runtime.js +0 -33
- package/dist/plugins/runtime.js.map +0 -1
- package/dist/plugins/schema-validator.d.ts +0 -17
- package/dist/plugins/schema-validator.d.ts.map +0 -1
- package/dist/plugins/schema-validator.js +0 -26
- package/dist/plugins/schema-validator.js.map +0 -1
- package/dist/plugins/tool-hooks.d.ts +0 -4
- package/dist/plugins/tool-hooks.d.ts.map +0 -1
- package/dist/plugins/tool-hooks.js +0 -63
- package/dist/plugins/tool-hooks.js.map +0 -1
- package/dist/plugins/tools.d.ts +0 -20
- package/dist/plugins/tools.d.ts.map +0 -1
- package/dist/plugins/tools.js +0 -42
- package/dist/plugins/tools.js.map +0 -1
- package/dist/plugins/types.d.ts +0 -61
- package/dist/plugins/types.d.ts.map +0 -1
- package/dist/plugins/types.js +0 -2
- package/dist/plugins/types.js.map +0 -1
- package/dist/plugins/utils.d.ts +0 -4
- package/dist/plugins/utils.d.ts.map +0 -1
- package/dist/plugins/utils.js +0 -22
- package/dist/plugins/utils.js.map +0 -1
- package/dist/runner/agent-runtime.d.ts +0 -62
- package/dist/runner/agent-runtime.d.ts.map +0 -1
- package/dist/runner/agent-runtime.js +0 -186
- package/dist/runner/agent-runtime.js.map +0 -1
- package/dist/runner/announce-loop.d.ts +0 -41
- package/dist/runner/announce-loop.d.ts.map +0 -1
- package/dist/runner/announce-loop.js +0 -94
- package/dist/runner/announce-loop.js.map +0 -1
- package/dist/runner/event-dispatcher.d.ts +0 -12
- package/dist/runner/event-dispatcher.d.ts.map +0 -1
- package/dist/runner/event-dispatcher.js +0 -18
- package/dist/runner/event-dispatcher.js.map +0 -1
- package/dist/runner/finalizer.d.ts +0 -30
- package/dist/runner/finalizer.d.ts.map +0 -1
- package/dist/runner/finalizer.js +0 -75
- package/dist/runner/finalizer.js.map +0 -1
- package/dist/runner/invocation-resolver.d.ts +0 -67
- package/dist/runner/invocation-resolver.d.ts.map +0 -1
- package/dist/runner/invocation-resolver.js +0 -224
- package/dist/runner/invocation-resolver.js.map +0 -1
- package/dist/runner/plugin-context.d.ts +0 -18
- package/dist/runner/plugin-context.d.ts.map +0 -1
- package/dist/runner/plugin-context.js +0 -26
- package/dist/runner/plugin-context.js.map +0 -1
- package/dist/runner/run-context.d.ts +0 -38
- package/dist/runner/run-context.d.ts.map +0 -1
- package/dist/runner/run-context.js +0 -159
- package/dist/runner/run-context.js.map +0 -1
- package/dist/runner/runner-session.d.ts +0 -34
- package/dist/runner/runner-session.d.ts.map +0 -1
- package/dist/runner/runner-session.js +0 -61
- package/dist/runner/runner-session.js.map +0 -1
- package/dist/runner/runner.d.ts +0 -13
- package/dist/runner/runner.d.ts.map +0 -1
- package/dist/runner/runner.js +0 -234
- package/dist/runner/runner.js.map +0 -1
- package/dist/runner/runtime.d.ts +0 -7
- package/dist/runner/runtime.d.ts.map +0 -1
- package/dist/runner/runtime.js +0 -21
- package/dist/runner/runtime.js.map +0 -1
- package/dist/runner/session-lifecycle.d.ts +0 -31
- package/dist/runner/session-lifecycle.d.ts.map +0 -1
- package/dist/runner/session-lifecycle.js +0 -38
- package/dist/runner/session-lifecycle.js.map +0 -1
- package/dist/runner/skill-usage.d.ts +0 -29
- package/dist/runner/skill-usage.d.ts.map +0 -1
- package/dist/runner/skill-usage.js +0 -65
- package/dist/runner/skill-usage.js.map +0 -1
- package/dist/runner/title.d.ts +0 -3
- package/dist/runner/title.d.ts.map +0 -1
- package/dist/runner/title.js +0 -6
- package/dist/runner/title.js.map +0 -1
- package/dist/runner/turn-executor.d.ts +0 -51
- package/dist/runner/turn-executor.d.ts.map +0 -1
- package/dist/runner/turn-executor.js +0 -294
- package/dist/runner/turn-executor.js.map +0 -1
- package/dist/security/command-dangerous-rules.d.ts +0 -4
- package/dist/security/command-dangerous-rules.d.ts.map +0 -1
- package/dist/security/command-dangerous-rules.js +0 -26
- package/dist/security/command-dangerous-rules.js.map +0 -1
- package/dist/security/command-parser.d.ts +0 -3
- package/dist/security/command-parser.d.ts.map +0 -1
- package/dist/security/command-parser.js +0 -191
- package/dist/security/command-parser.js.map +0 -1
- package/dist/security/command-path-guard.d.ts +0 -10
- package/dist/security/command-path-guard.d.ts.map +0 -1
- package/dist/security/command-path-guard.js +0 -126
- package/dist/security/command-path-guard.js.map +0 -1
- package/dist/security/command-policy-config.d.ts +0 -5
- package/dist/security/command-policy-config.d.ts.map +0 -1
- package/dist/security/command-policy-config.js +0 -212
- package/dist/security/command-policy-config.js.map +0 -1
- package/dist/security/command-policy-engine.d.ts +0 -8
- package/dist/security/command-policy-engine.d.ts.map +0 -1
- package/dist/security/command-policy-engine.js +0 -122
- package/dist/security/command-policy-engine.js.map +0 -1
- package/dist/security/command-policy-types.d.ts +0 -67
- package/dist/security/command-policy-types.d.ts.map +0 -1
- package/dist/security/command-policy-types.js +0 -2
- package/dist/security/command-policy-types.js.map +0 -1
- package/dist/security/command-safe-bins.d.ts +0 -4
- package/dist/security/command-safe-bins.d.ts.map +0 -1
- package/dist/security/command-safe-bins.js +0 -84
- package/dist/security/command-safe-bins.js.map +0 -1
- package/dist/security/command-trusted-executables.d.ts +0 -6
- package/dist/security/command-trusted-executables.d.ts.map +0 -1
- package/dist/security/command-trusted-executables.js +0 -57
- package/dist/security/command-trusted-executables.js.map +0 -1
- package/dist/session/session.d.ts +0 -45
- package/dist/session/session.d.ts.map +0 -1
- package/dist/session/session.js +0 -167
- package/dist/session/session.js.map +0 -1
- package/dist/skills/skills.d.ts +0 -23
- package/dist/skills/skills.d.ts.map +0 -1
- package/dist/skills/skills.js +0 -109
- package/dist/skills/skills.js.map +0 -1
- package/dist/subagent/registry-persist.d.ts +0 -31
- package/dist/subagent/registry-persist.d.ts.map +0 -1
- package/dist/subagent/registry-persist.js +0 -115
- package/dist/subagent/registry-persist.js.map +0 -1
- package/dist/subagent/registry.d.ts +0 -52
- package/dist/subagent/registry.d.ts.map +0 -1
- package/dist/subagent/registry.js +0 -122
- package/dist/subagent/registry.js.map +0 -1
- package/dist/subagent/types.d.ts +0 -20
- package/dist/subagent/types.d.ts.map +0 -1
- package/dist/subagent/types.js +0 -2
- package/dist/subagent/types.js.map +0 -1
- package/dist/system-prompt/builder.d.ts +0 -50
- package/dist/system-prompt/builder.d.ts.map +0 -1
- package/dist/system-prompt/builder.js +0 -335
- package/dist/system-prompt/builder.js.map +0 -1
- package/dist/tools/apply-patch.d.ts +0 -15
- package/dist/tools/apply-patch.d.ts.map +0 -1
- package/dist/tools/apply-patch.js +0 -425
- package/dist/tools/apply-patch.js.map +0 -1
- package/dist/tools/bash.d.ts +0 -11
- package/dist/tools/bash.d.ts.map +0 -1
- package/dist/tools/bash.js +0 -13
- package/dist/tools/bash.js.map +0 -1
- package/dist/tools/cron.d.ts +0 -30
- package/dist/tools/cron.d.ts.map +0 -1
- package/dist/tools/cron.js +0 -57
- package/dist/tools/cron.js.map +0 -1
- package/dist/tools/exec.d.ts +0 -18
- package/dist/tools/exec.d.ts.map +0 -1
- package/dist/tools/exec.js +0 -144
- package/dist/tools/exec.js.map +0 -1
- package/dist/tools/files.d.ts +0 -37
- package/dist/tools/files.d.ts.map +0 -1
- package/dist/tools/files.js +0 -191
- package/dist/tools/files.js.map +0 -1
- package/dist/tools/image.d.ts +0 -14
- package/dist/tools/image.d.ts.map +0 -1
- package/dist/tools/image.js +0 -26
- package/dist/tools/image.js.map +0 -1
- package/dist/tools/index.d.ts +0 -36
- package/dist/tools/index.d.ts.map +0 -1
- package/dist/tools/index.js +0 -53
- package/dist/tools/index.js.map +0 -1
- package/dist/tools/memory.d.ts +0 -41
- package/dist/tools/memory.d.ts.map +0 -1
- package/dist/tools/memory.js +0 -114
- package/dist/tools/memory.js.map +0 -1
- package/dist/tools/process-registry.d.ts +0 -47
- package/dist/tools/process-registry.d.ts.map +0 -1
- package/dist/tools/process-registry.js +0 -262
- package/dist/tools/process-registry.js.map +0 -1
- package/dist/tools/process.d.ts +0 -17
- package/dist/tools/process.d.ts.map +0 -1
- package/dist/tools/process.js +0 -114
- package/dist/tools/process.js.map +0 -1
- package/dist/tools/subagent-spawn.d.ts +0 -44
- package/dist/tools/subagent-spawn.d.ts.map +0 -1
- package/dist/tools/subagent-spawn.js +0 -101
- package/dist/tools/subagent-spawn.js.map +0 -1
- package/dist/tools/subagents.d.ts +0 -30
- package/dist/tools/subagents.d.ts.map +0 -1
- package/dist/tools/subagents.js +0 -101
- package/dist/tools/subagents.js.map +0 -1
- package/dist/types.d.ts +0 -153
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -6
- package/dist/types.js.map +0 -1
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
import fs from "node:fs";
|
|
2
|
-
import path from "node:path";
|
|
3
|
-
import { unwrapExecutable } from "./command-trusted-executables.js";
|
|
4
|
-
function isWithinRoot(targetPath, root) {
|
|
5
|
-
return targetPath === root || targetPath.startsWith(`${root}${path.sep}`);
|
|
6
|
-
}
|
|
7
|
-
function realOrResolved(targetPath) {
|
|
8
|
-
try {
|
|
9
|
-
return fs.realpathSync(targetPath);
|
|
10
|
-
}
|
|
11
|
-
catch {
|
|
12
|
-
return path.resolve(targetPath);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
function validatePath(targetPath, allowedRoot, policy) {
|
|
16
|
-
const normalizedAllowedRoot = path.resolve(allowedRoot);
|
|
17
|
-
const resolved = realOrResolved(targetPath);
|
|
18
|
-
if (!isWithinRoot(resolved, normalizedAllowedRoot)) {
|
|
19
|
-
return `path escapes allowed root: ${targetPath}`;
|
|
20
|
-
}
|
|
21
|
-
for (const blockedRoot of policy.blockedRoots) {
|
|
22
|
-
const normalizedBlockedRoot = path.resolve(blockedRoot);
|
|
23
|
-
if (resolved === normalizedBlockedRoot || resolved.startsWith(`${normalizedBlockedRoot}${path.sep}`)) {
|
|
24
|
-
return `path hits blocked root: ${targetPath}`;
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
return null;
|
|
28
|
-
}
|
|
29
|
-
function looksLikePathToken(token) {
|
|
30
|
-
return (token === "." ||
|
|
31
|
-
token === ".." ||
|
|
32
|
-
token.startsWith("./") ||
|
|
33
|
-
token.startsWith("../") ||
|
|
34
|
-
token.startsWith("/") ||
|
|
35
|
-
token.includes("/"));
|
|
36
|
-
}
|
|
37
|
-
function basename(value) {
|
|
38
|
-
if (!value) {
|
|
39
|
-
return "";
|
|
40
|
-
}
|
|
41
|
-
return path.posix.basename(value).toLowerCase();
|
|
42
|
-
}
|
|
43
|
-
function candidatePathFromToken(token, cwd) {
|
|
44
|
-
if (path.isAbsolute(token)) {
|
|
45
|
-
return path.resolve(token);
|
|
46
|
-
}
|
|
47
|
-
return path.resolve(cwd, token);
|
|
48
|
-
}
|
|
49
|
-
function collectPositionalPathTokens(segment, allowlist) {
|
|
50
|
-
const executable = unwrapExecutable(segment, allowlist)?.split(/[\\/]/).pop()?.toLowerCase() ?? "";
|
|
51
|
-
const argv = [...segment.argv];
|
|
52
|
-
if (basename(segment.executable) === "env") {
|
|
53
|
-
let index = 1;
|
|
54
|
-
while (index < argv.length && /^[A-Za-z_][A-Za-z0-9_]*=/.test(argv[index])) {
|
|
55
|
-
index += 1;
|
|
56
|
-
}
|
|
57
|
-
return collectPathTokensForExecutable(executable, argv.slice(index + 1));
|
|
58
|
-
}
|
|
59
|
-
return collectPathTokensForExecutable(executable, argv.slice(1));
|
|
60
|
-
}
|
|
61
|
-
function collectPathTokensForExecutable(executable, args) {
|
|
62
|
-
const paths = [];
|
|
63
|
-
if (executable === "node" || executable === "python" || executable === "python3" || executable === "bash" || executable === "sh" || executable === "zsh") {
|
|
64
|
-
for (let index = 0; index < args.length; index += 1) {
|
|
65
|
-
const arg = args[index];
|
|
66
|
-
if (arg === "-e" || arg === "--eval" || arg === "-c" || arg === "--command") {
|
|
67
|
-
paths.push("__INLINE_EVAL__");
|
|
68
|
-
return paths;
|
|
69
|
-
}
|
|
70
|
-
if (!arg.startsWith("-")) {
|
|
71
|
-
paths.push(arg);
|
|
72
|
-
return paths;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
return paths;
|
|
76
|
-
}
|
|
77
|
-
if (executable === "npm" || executable === "npx" || executable === "pnpm" || executable === "pip" || executable === "pip3") {
|
|
78
|
-
return paths;
|
|
79
|
-
}
|
|
80
|
-
for (const arg of args) {
|
|
81
|
-
if (arg.startsWith("-")) {
|
|
82
|
-
continue;
|
|
83
|
-
}
|
|
84
|
-
if (looksLikePathToken(arg) || ["cat", "find", "grep", "sort", "sed", "awk", "git"].includes(executable)) {
|
|
85
|
-
paths.push(arg);
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
return paths;
|
|
89
|
-
}
|
|
90
|
-
export function validateCommandPaths(params) {
|
|
91
|
-
const unwrappedExecutable = basename(unwrapExecutable(params.segment, params.allowlist));
|
|
92
|
-
if ((unwrappedExecutable === "bash" || unwrappedExecutable === "sh" || unwrappedExecutable === "zsh") &&
|
|
93
|
-
params.segment.argv.some((arg) => arg === "-c" || arg === "--command")) {
|
|
94
|
-
return "inline shell command execution is not allowed";
|
|
95
|
-
}
|
|
96
|
-
if ((unwrappedExecutable === "node" ||
|
|
97
|
-
unwrappedExecutable === "python" ||
|
|
98
|
-
unwrappedExecutable === "python3") &&
|
|
99
|
-
params.segment.argv.some((arg) => arg === "-e" || arg === "--eval" || arg === "-c" || arg === "--command")) {
|
|
100
|
-
return "inline interpreter evaluation is not allowed";
|
|
101
|
-
}
|
|
102
|
-
const cwdError = validatePath(params.cwd, params.allowedRoot, params.pathPolicy);
|
|
103
|
-
if (cwdError) {
|
|
104
|
-
return cwdError;
|
|
105
|
-
}
|
|
106
|
-
for (const redirection of params.segment.redirections) {
|
|
107
|
-
const redirectionPath = candidatePathFromToken(redirection.target, params.cwd);
|
|
108
|
-
const redirectionError = validatePath(redirectionPath, params.allowedRoot, params.pathPolicy);
|
|
109
|
-
if (redirectionError) {
|
|
110
|
-
return redirectionError;
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
const tokens = collectPositionalPathTokens(params.segment, params.allowlist);
|
|
114
|
-
for (const token of tokens) {
|
|
115
|
-
if (token === "__INLINE_EVAL__") {
|
|
116
|
-
return "inline interpreter evaluation is not allowed";
|
|
117
|
-
}
|
|
118
|
-
const candidate = candidatePathFromToken(token, params.cwd);
|
|
119
|
-
const tokenError = validatePath(candidate, params.allowedRoot, params.pathPolicy);
|
|
120
|
-
if (tokenError) {
|
|
121
|
-
return tokenError;
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
return null;
|
|
125
|
-
}
|
|
126
|
-
//# sourceMappingURL=command-path-guard.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"command-path-guard.js","sourceRoot":"","sources":["../../src/security/command-path-guard.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import type { CommandPolicyConfig } from "./command-policy-types.js";
|
|
2
|
-
export declare function getDefaultCommandPolicyPath(): string;
|
|
3
|
-
export declare function getDefaultCommandPolicy(): CommandPolicyConfig;
|
|
4
|
-
export declare function loadCommandPolicy(configPath?: string): CommandPolicyConfig;
|
|
5
|
-
//# sourceMappingURL=command-policy-config.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"command-policy-config.d.ts","sourceRoot":"","sources":["../../src/security/command-policy-config.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAgJrE,wBAAgB,2BAA2B,IAAI,MAAM,CAEpD;AAED,wBAAgB,uBAAuB,IAAI,mBAAmB,CAE7D;AAED,wBAAgB,iBAAiB,CAAC,UAAU,SAAsB,GAAG,mBAAmB,CAqFvF"}
|
|
@@ -1,212 +0,0 @@
|
|
|
1
|
-
import fs from "node:fs";
|
|
2
|
-
import path from "node:path";
|
|
3
|
-
const DEFAULT_POLICY_PATH = process.env.PINGCLAW_COMMAND_POLICY_PATH?.trim() || "/pingclaw/command-policy.json";
|
|
4
|
-
const DEFAULT_POLICY = {
|
|
5
|
-
version: 1,
|
|
6
|
-
dataRoot: "/data",
|
|
7
|
-
security: {
|
|
8
|
-
defaultMode: "allowlist",
|
|
9
|
-
approvalMode: "off",
|
|
10
|
-
},
|
|
11
|
-
exec: {
|
|
12
|
-
allowShell: true,
|
|
13
|
-
allowPty: true,
|
|
14
|
-
maxCommandLength: 8192,
|
|
15
|
-
defaultTimeoutSec: 1800,
|
|
16
|
-
},
|
|
17
|
-
pathPolicy: {
|
|
18
|
-
allowedRoots: ["/data"],
|
|
19
|
-
blockedRoots: [
|
|
20
|
-
"/",
|
|
21
|
-
"/etc",
|
|
22
|
-
"/usr",
|
|
23
|
-
"/var",
|
|
24
|
-
"/bin",
|
|
25
|
-
"/sbin",
|
|
26
|
-
"/lib",
|
|
27
|
-
"/lib64",
|
|
28
|
-
"/boot",
|
|
29
|
-
"/root",
|
|
30
|
-
"/home",
|
|
31
|
-
"/proc",
|
|
32
|
-
"/sys",
|
|
33
|
-
"/dev",
|
|
34
|
-
"/run",
|
|
35
|
-
"/mnt",
|
|
36
|
-
"/media",
|
|
37
|
-
"/tmp",
|
|
38
|
-
],
|
|
39
|
-
followSymlink: true,
|
|
40
|
-
denyPathEscape: true,
|
|
41
|
-
},
|
|
42
|
-
safeBins: {
|
|
43
|
-
enabled: true,
|
|
44
|
-
trustedDirs: ["/bin", "/usr/bin"],
|
|
45
|
-
bins: ["jq", "cut", "uniq", "head", "tail", "tr", "wc", "grep", "sort"],
|
|
46
|
-
profiles: {
|
|
47
|
-
jq: {},
|
|
48
|
-
cut: {},
|
|
49
|
-
uniq: {},
|
|
50
|
-
head: {},
|
|
51
|
-
tail: {},
|
|
52
|
-
tr: {},
|
|
53
|
-
wc: {},
|
|
54
|
-
grep: {},
|
|
55
|
-
sort: {},
|
|
56
|
-
},
|
|
57
|
-
},
|
|
58
|
-
trustedExecutables: {
|
|
59
|
-
enabled: true,
|
|
60
|
-
executables: [
|
|
61
|
-
"/usr/bin/node",
|
|
62
|
-
"/usr/bin/npm",
|
|
63
|
-
"/usr/bin/npx",
|
|
64
|
-
"/usr/bin/pnpm",
|
|
65
|
-
"/usr/bin/python",
|
|
66
|
-
"/usr/bin/python3",
|
|
67
|
-
"/usr/bin/pip",
|
|
68
|
-
"/usr/bin/pip3",
|
|
69
|
-
"/usr/bin/bash",
|
|
70
|
-
"/usr/bin/sh",
|
|
71
|
-
"/usr/bin/zsh",
|
|
72
|
-
"/usr/bin/git",
|
|
73
|
-
"/usr/bin/grep",
|
|
74
|
-
"/usr/bin/sort",
|
|
75
|
-
"/usr/bin/find",
|
|
76
|
-
"/usr/bin/cat",
|
|
77
|
-
"/usr/bin/sed",
|
|
78
|
-
"/usr/bin/awk",
|
|
79
|
-
"/usr/bin/ls",
|
|
80
|
-
"/usr/bin/env",
|
|
81
|
-
],
|
|
82
|
-
},
|
|
83
|
-
allowlist: {
|
|
84
|
-
executables: [
|
|
85
|
-
"/usr/bin/ls",
|
|
86
|
-
"/usr/bin/find",
|
|
87
|
-
"/usr/bin/cat",
|
|
88
|
-
"/usr/bin/grep",
|
|
89
|
-
"/usr/bin/sort",
|
|
90
|
-
"/usr/bin/git",
|
|
91
|
-
"/usr/bin/env",
|
|
92
|
-
],
|
|
93
|
-
wrappers: ["env", "timeout", "stdbuf", "nohup"],
|
|
94
|
-
},
|
|
95
|
-
dangerousRules: {
|
|
96
|
-
denyExecutables: [
|
|
97
|
-
"mount",
|
|
98
|
-
"umount",
|
|
99
|
-
"losetup",
|
|
100
|
-
"mkfs",
|
|
101
|
-
"fdisk",
|
|
102
|
-
"parted",
|
|
103
|
-
"fsck",
|
|
104
|
-
"swapon",
|
|
105
|
-
"swapoff",
|
|
106
|
-
"sudo",
|
|
107
|
-
"su",
|
|
108
|
-
"passwd",
|
|
109
|
-
"useradd",
|
|
110
|
-
"usermod",
|
|
111
|
-
"groupadd",
|
|
112
|
-
"shutdown",
|
|
113
|
-
"reboot",
|
|
114
|
-
"poweroff",
|
|
115
|
-
"systemctl",
|
|
116
|
-
"service",
|
|
117
|
-
"iptables",
|
|
118
|
-
"nft",
|
|
119
|
-
"ufw",
|
|
120
|
-
"route",
|
|
121
|
-
"ip",
|
|
122
|
-
"docker",
|
|
123
|
-
"podman",
|
|
124
|
-
"nsenter",
|
|
125
|
-
"unshare",
|
|
126
|
-
"chroot",
|
|
127
|
-
],
|
|
128
|
-
denyShellPatterns: ["curl|sh", "wget|sh", "curl|bash", "wget|bash", "nc -e", "bash -i", "/dev/tcp/"],
|
|
129
|
-
requireApprovalExecutables: [],
|
|
130
|
-
requireApprovalShellPatterns: [],
|
|
131
|
-
},
|
|
132
|
-
};
|
|
133
|
-
function normalizeStringArray(value, fallback) {
|
|
134
|
-
if (!Array.isArray(value)) {
|
|
135
|
-
return [...fallback];
|
|
136
|
-
}
|
|
137
|
-
const normalized = value
|
|
138
|
-
.map((entry) => (typeof entry === "string" ? entry.trim() : ""))
|
|
139
|
-
.filter((entry) => entry.length > 0);
|
|
140
|
-
return normalized.length > 0 ? normalized : [...fallback];
|
|
141
|
-
}
|
|
142
|
-
export function getDefaultCommandPolicyPath() {
|
|
143
|
-
return DEFAULT_POLICY_PATH;
|
|
144
|
-
}
|
|
145
|
-
export function getDefaultCommandPolicy() {
|
|
146
|
-
return JSON.parse(JSON.stringify(DEFAULT_POLICY));
|
|
147
|
-
}
|
|
148
|
-
export function loadCommandPolicy(configPath = DEFAULT_POLICY_PATH) {
|
|
149
|
-
if (!fs.existsSync(configPath)) {
|
|
150
|
-
return getDefaultCommandPolicy();
|
|
151
|
-
}
|
|
152
|
-
const raw = JSON.parse(fs.readFileSync(configPath, "utf8"));
|
|
153
|
-
const defaults = getDefaultCommandPolicy();
|
|
154
|
-
const dataRoot = typeof raw.dataRoot === "string" && raw.dataRoot.trim().length > 0
|
|
155
|
-
? path.posix.normalize(raw.dataRoot.trim())
|
|
156
|
-
: defaults.dataRoot;
|
|
157
|
-
return {
|
|
158
|
-
version: typeof raw.version === "number" ? raw.version : defaults.version,
|
|
159
|
-
dataRoot,
|
|
160
|
-
security: {
|
|
161
|
-
defaultMode: raw.security?.defaultMode === "deny" ||
|
|
162
|
-
raw.security?.defaultMode === "allowlist" ||
|
|
163
|
-
raw.security?.defaultMode === "full"
|
|
164
|
-
? raw.security.defaultMode
|
|
165
|
-
: defaults.security.defaultMode,
|
|
166
|
-
approvalMode: raw.security?.approvalMode === "off" ||
|
|
167
|
-
raw.security?.approvalMode === "on-miss" ||
|
|
168
|
-
raw.security?.approvalMode === "always"
|
|
169
|
-
? raw.security.approvalMode
|
|
170
|
-
: defaults.security.approvalMode,
|
|
171
|
-
},
|
|
172
|
-
exec: {
|
|
173
|
-
allowShell: raw.exec?.allowShell ?? defaults.exec.allowShell,
|
|
174
|
-
allowPty: raw.exec?.allowPty ?? defaults.exec.allowPty,
|
|
175
|
-
maxCommandLength: typeof raw.exec?.maxCommandLength === "number"
|
|
176
|
-
? raw.exec.maxCommandLength
|
|
177
|
-
: defaults.exec.maxCommandLength,
|
|
178
|
-
defaultTimeoutSec: typeof raw.exec?.defaultTimeoutSec === "number"
|
|
179
|
-
? raw.exec.defaultTimeoutSec
|
|
180
|
-
: defaults.exec.defaultTimeoutSec,
|
|
181
|
-
},
|
|
182
|
-
pathPolicy: {
|
|
183
|
-
allowedRoots: normalizeStringArray(raw.pathPolicy?.allowedRoots, [dataRoot]),
|
|
184
|
-
blockedRoots: normalizeStringArray(raw.pathPolicy?.blockedRoots, defaults.pathPolicy.blockedRoots),
|
|
185
|
-
followSymlink: raw.pathPolicy?.followSymlink ?? defaults.pathPolicy.followSymlink,
|
|
186
|
-
denyPathEscape: raw.pathPolicy?.denyPathEscape ?? defaults.pathPolicy.denyPathEscape,
|
|
187
|
-
},
|
|
188
|
-
safeBins: {
|
|
189
|
-
enabled: raw.safeBins?.enabled ?? defaults.safeBins.enabled,
|
|
190
|
-
trustedDirs: normalizeStringArray(raw.safeBins?.trustedDirs, defaults.safeBins.trustedDirs),
|
|
191
|
-
bins: normalizeStringArray(raw.safeBins?.bins, defaults.safeBins.bins),
|
|
192
|
-
profiles: raw.safeBins?.profiles && typeof raw.safeBins.profiles === "object"
|
|
193
|
-
? raw.safeBins.profiles
|
|
194
|
-
: defaults.safeBins.profiles,
|
|
195
|
-
},
|
|
196
|
-
trustedExecutables: {
|
|
197
|
-
enabled: raw.trustedExecutables?.enabled ?? defaults.trustedExecutables.enabled,
|
|
198
|
-
executables: normalizeStringArray(raw.trustedExecutables?.executables, defaults.trustedExecutables.executables),
|
|
199
|
-
},
|
|
200
|
-
allowlist: {
|
|
201
|
-
executables: normalizeStringArray(raw.allowlist?.executables, defaults.allowlist.executables),
|
|
202
|
-
wrappers: normalizeStringArray(raw.allowlist?.wrappers, defaults.allowlist.wrappers),
|
|
203
|
-
},
|
|
204
|
-
dangerousRules: {
|
|
205
|
-
denyExecutables: normalizeStringArray(raw.dangerousRules?.denyExecutables, defaults.dangerousRules.denyExecutables),
|
|
206
|
-
denyShellPatterns: normalizeStringArray(raw.dangerousRules?.denyShellPatterns, defaults.dangerousRules.denyShellPatterns),
|
|
207
|
-
requireApprovalExecutables: normalizeStringArray(raw.dangerousRules?.requireApprovalExecutables, defaults.dangerousRules.requireApprovalExecutables),
|
|
208
|
-
requireApprovalShellPatterns: normalizeStringArray(raw.dangerousRules?.requireApprovalShellPatterns, defaults.dangerousRules.requireApprovalShellPatterns),
|
|
209
|
-
},
|
|
210
|
-
};
|
|
211
|
-
}
|
|
212
|
-
//# sourceMappingURL=command-policy-config.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"command-policy-config.js","sourceRoot":"","sources":["../../src/security/command-policy-config.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import type { CommandPolicyConfig, CommandPolicyResult } from "./command-policy-types.js";
|
|
2
|
-
export declare function evaluateCommandPolicy(params: {
|
|
3
|
-
command: string;
|
|
4
|
-
cwd: string;
|
|
5
|
-
allowedRoot: string;
|
|
6
|
-
policy: CommandPolicyConfig;
|
|
7
|
-
}): CommandPolicyResult;
|
|
8
|
-
//# sourceMappingURL=command-policy-engine.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"command-policy-engine.d.ts","sourceRoot":"","sources":["../../src/security/command-policy-engine.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAO1F,wBAAgB,qBAAqB,CAAC,MAAM,EAAE;IAC5C,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;IACZ,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,mBAAmB,CAAC;CAC7B,GAAG,mBAAmB,CAgItB"}
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
import { parseCommand } from "./command-parser.js";
|
|
2
|
-
import { matchDangerousExecutable, matchDangerousShellPattern } from "./command-dangerous-rules.js";
|
|
3
|
-
import { matchAllowlistExecutable, matchTrustedExecutable } from "./command-trusted-executables.js";
|
|
4
|
-
import { validateCommandPaths } from "./command-path-guard.js";
|
|
5
|
-
import { matchSafeBin } from "./command-safe-bins.js";
|
|
6
|
-
export function evaluateCommandPolicy(params) {
|
|
7
|
-
const normalizedCommand = params.command.trim();
|
|
8
|
-
if (!normalizedCommand) {
|
|
9
|
-
return {
|
|
10
|
-
decision: "deny",
|
|
11
|
-
reason: "empty_command",
|
|
12
|
-
normalizedCommand,
|
|
13
|
-
parsedSegments: [],
|
|
14
|
-
};
|
|
15
|
-
}
|
|
16
|
-
if (normalizedCommand.length > params.policy.exec.maxCommandLength) {
|
|
17
|
-
return {
|
|
18
|
-
decision: "deny",
|
|
19
|
-
reason: "parse_error",
|
|
20
|
-
normalizedCommand,
|
|
21
|
-
parsedSegments: [],
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
const dangerousPattern = matchDangerousShellPattern(normalizedCommand, params.policy.dangerousRules);
|
|
25
|
-
if (dangerousPattern) {
|
|
26
|
-
return {
|
|
27
|
-
decision: "deny",
|
|
28
|
-
reason: "dangerous_shell_pattern",
|
|
29
|
-
matchedRuleId: dangerousPattern,
|
|
30
|
-
normalizedCommand,
|
|
31
|
-
parsedSegments: [],
|
|
32
|
-
};
|
|
33
|
-
}
|
|
34
|
-
const parsed = parseCommand(normalizedCommand);
|
|
35
|
-
if (!parsed) {
|
|
36
|
-
return {
|
|
37
|
-
decision: "deny",
|
|
38
|
-
reason: "parse_error",
|
|
39
|
-
normalizedCommand,
|
|
40
|
-
parsedSegments: [],
|
|
41
|
-
};
|
|
42
|
-
}
|
|
43
|
-
let matchedTrusted = null;
|
|
44
|
-
let matchedAllowlist = null;
|
|
45
|
-
let matchedSafeBin = null;
|
|
46
|
-
for (const segment of parsed.segments) {
|
|
47
|
-
const dangerousExecutable = matchDangerousExecutable(segment, params.policy.dangerousRules);
|
|
48
|
-
if (dangerousExecutable) {
|
|
49
|
-
return {
|
|
50
|
-
decision: "deny",
|
|
51
|
-
reason: "dangerous_executable",
|
|
52
|
-
matchedRuleId: dangerousExecutable,
|
|
53
|
-
normalizedCommand,
|
|
54
|
-
parsedSegments: parsed.segments,
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
const pathError = validateCommandPaths({
|
|
58
|
-
cwd: params.cwd,
|
|
59
|
-
allowedRoot: params.allowedRoot,
|
|
60
|
-
pathPolicy: params.policy.pathPolicy,
|
|
61
|
-
segment,
|
|
62
|
-
allowlist: params.policy.allowlist,
|
|
63
|
-
});
|
|
64
|
-
if (pathError) {
|
|
65
|
-
return {
|
|
66
|
-
decision: "deny",
|
|
67
|
-
reason: "path_escape",
|
|
68
|
-
matchedRuleId: pathError,
|
|
69
|
-
normalizedCommand,
|
|
70
|
-
parsedSegments: parsed.segments,
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
const trusted = matchTrustedExecutable(segment, params.policy.trustedExecutables, params.policy.allowlist);
|
|
74
|
-
const safeBin = matchSafeBin(segment, params.policy.safeBins, params.policy.allowlist);
|
|
75
|
-
const allowed = matchAllowlistExecutable(segment, params.policy.allowlist);
|
|
76
|
-
matchedSafeBin ||= safeBin;
|
|
77
|
-
matchedTrusted ||= trusted;
|
|
78
|
-
matchedAllowlist ||= allowed;
|
|
79
|
-
if (!safeBin && !trusted && !allowed) {
|
|
80
|
-
return {
|
|
81
|
-
decision: "deny",
|
|
82
|
-
reason: "allowlist_miss",
|
|
83
|
-
normalizedCommand,
|
|
84
|
-
parsedSegments: parsed.segments,
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
if (matchedSafeBin) {
|
|
89
|
-
return {
|
|
90
|
-
decision: "allow",
|
|
91
|
-
reason: "safe_bin_match",
|
|
92
|
-
matchedRuleId: matchedSafeBin,
|
|
93
|
-
normalizedCommand,
|
|
94
|
-
parsedSegments: parsed.segments,
|
|
95
|
-
};
|
|
96
|
-
}
|
|
97
|
-
if (matchedTrusted) {
|
|
98
|
-
return {
|
|
99
|
-
decision: "allow",
|
|
100
|
-
reason: "trusted_executable_match",
|
|
101
|
-
matchedRuleId: matchedTrusted,
|
|
102
|
-
normalizedCommand,
|
|
103
|
-
parsedSegments: parsed.segments,
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
if (matchedAllowlist) {
|
|
107
|
-
return {
|
|
108
|
-
decision: "allow",
|
|
109
|
-
reason: "allowlist_match",
|
|
110
|
-
matchedRuleId: matchedAllowlist,
|
|
111
|
-
normalizedCommand,
|
|
112
|
-
parsedSegments: parsed.segments,
|
|
113
|
-
};
|
|
114
|
-
}
|
|
115
|
-
return {
|
|
116
|
-
decision: "deny",
|
|
117
|
-
reason: "allowlist_miss",
|
|
118
|
-
normalizedCommand,
|
|
119
|
-
parsedSegments: parsed.segments,
|
|
120
|
-
};
|
|
121
|
-
}
|
|
122
|
-
//# sourceMappingURL=command-policy-engine.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"command-policy-engine.js","sourceRoot":"","sources":["../../src/security/command-policy-engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
export type CommandDecision = "allow" | "deny" | "require_approval";
|
|
2
|
-
export type CommandDecisionReason = "empty_command" | "parse_error" | "dangerous_executable" | "dangerous_shell_pattern" | "path_escape" | "blocked_root" | "allowlist_match" | "trusted_executable_match" | "safe_bin_match" | "allowlist_miss" | "approval_required";
|
|
3
|
-
export type CommandPathPolicy = {
|
|
4
|
-
allowedRoots: string[];
|
|
5
|
-
blockedRoots: string[];
|
|
6
|
-
followSymlink: boolean;
|
|
7
|
-
denyPathEscape: boolean;
|
|
8
|
-
};
|
|
9
|
-
export type CommandSafeBinsPolicy = {
|
|
10
|
-
enabled: boolean;
|
|
11
|
-
trustedDirs: string[];
|
|
12
|
-
bins: string[];
|
|
13
|
-
profiles: Record<string, Record<string, unknown>>;
|
|
14
|
-
};
|
|
15
|
-
export type CommandTrustedExecutablesPolicy = {
|
|
16
|
-
enabled: boolean;
|
|
17
|
-
executables: string[];
|
|
18
|
-
};
|
|
19
|
-
export type CommandAllowlistPolicy = {
|
|
20
|
-
executables: string[];
|
|
21
|
-
wrappers: string[];
|
|
22
|
-
};
|
|
23
|
-
export type CommandDangerousRulesPolicy = {
|
|
24
|
-
denyExecutables: string[];
|
|
25
|
-
denyShellPatterns: string[];
|
|
26
|
-
requireApprovalExecutables: string[];
|
|
27
|
-
requireApprovalShellPatterns: string[];
|
|
28
|
-
};
|
|
29
|
-
export type CommandPolicyConfig = {
|
|
30
|
-
version: number;
|
|
31
|
-
dataRoot: string;
|
|
32
|
-
security: {
|
|
33
|
-
defaultMode: "deny" | "allowlist" | "full";
|
|
34
|
-
approvalMode: "off" | "on-miss" | "always";
|
|
35
|
-
};
|
|
36
|
-
exec: {
|
|
37
|
-
allowShell: boolean;
|
|
38
|
-
allowPty: boolean;
|
|
39
|
-
maxCommandLength: number;
|
|
40
|
-
defaultTimeoutSec: number;
|
|
41
|
-
};
|
|
42
|
-
pathPolicy: CommandPathPolicy;
|
|
43
|
-
safeBins: CommandSafeBinsPolicy;
|
|
44
|
-
trustedExecutables: CommandTrustedExecutablesPolicy;
|
|
45
|
-
allowlist: CommandAllowlistPolicy;
|
|
46
|
-
dangerousRules: CommandDangerousRulesPolicy;
|
|
47
|
-
};
|
|
48
|
-
export type ParsedCommandSegment = {
|
|
49
|
-
raw: string;
|
|
50
|
-
argv: string[];
|
|
51
|
-
executable: string | null;
|
|
52
|
-
redirections: Array<{
|
|
53
|
-
operator: string;
|
|
54
|
-
target: string;
|
|
55
|
-
}>;
|
|
56
|
-
};
|
|
57
|
-
export type ParsedCommand = {
|
|
58
|
-
segments: ParsedCommandSegment[];
|
|
59
|
-
};
|
|
60
|
-
export type CommandPolicyResult = {
|
|
61
|
-
decision: CommandDecision;
|
|
62
|
-
reason: CommandDecisionReason;
|
|
63
|
-
matchedRuleId?: string;
|
|
64
|
-
normalizedCommand: string;
|
|
65
|
-
parsedSegments: ParsedCommandSegment[];
|
|
66
|
-
};
|
|
67
|
-
//# sourceMappingURL=command-policy-types.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"command-policy-types.d.ts","sourceRoot":"","sources":["../../src/security/command-policy-types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,eAAe,GAAG,OAAO,GAAG,MAAM,GAAG,kBAAkB,CAAC;AAEpE,MAAM,MAAM,qBAAqB,GAC7B,eAAe,GACf,aAAa,GACb,sBAAsB,GACtB,yBAAyB,GACzB,aAAa,GACb,cAAc,GACd,iBAAiB,GACjB,0BAA0B,GAC1B,gBAAgB,GAChB,gBAAgB,GAChB,mBAAmB,CAAC;AAExB,MAAM,MAAM,iBAAiB,GAAG;IAC9B,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,aAAa,EAAE,OAAO,CAAC;IACvB,cAAc,EAAE,OAAO,CAAC;CACzB,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,OAAO,EAAE,OAAO,CAAC;IACjB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;CACnD,CAAC;AAEF,MAAM,MAAM,+BAA+B,GAAG;IAC5C,OAAO,EAAE,OAAO,CAAC;IACjB,WAAW,EAAE,MAAM,EAAE,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG;IACnC,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,2BAA2B,GAAG;IACxC,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,0BAA0B,EAAE,MAAM,EAAE,CAAC;IACrC,4BAA4B,EAAE,MAAM,EAAE,CAAC;CACxC,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE;QACR,WAAW,EAAE,MAAM,GAAG,WAAW,GAAG,MAAM,CAAC;QAC3C,YAAY,EAAE,KAAK,GAAG,SAAS,GAAG,QAAQ,CAAC;KAC5C,CAAC;IACF,IAAI,EAAE;QACJ,UAAU,EAAE,OAAO,CAAC;QACpB,QAAQ,EAAE,OAAO,CAAC;QAClB,gBAAgB,EAAE,MAAM,CAAC;QACzB,iBAAiB,EAAE,MAAM,CAAC;KAC3B,CAAC;IACF,UAAU,EAAE,iBAAiB,CAAC;IAC9B,QAAQ,EAAE,qBAAqB,CAAC;IAChC,kBAAkB,EAAE,+BAA+B,CAAC;IACpD,SAAS,EAAE,sBAAsB,CAAC;IAClC,cAAc,EAAE,2BAA2B,CAAC;CAC7C,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG;IACjC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,YAAY,EAAE,KAAK,CAAC;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAC3D,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,QAAQ,EAAE,oBAAoB,EAAE,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,QAAQ,EAAE,eAAe,CAAC;IAC1B,MAAM,EAAE,qBAAqB,CAAC;IAC9B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,cAAc,EAAE,oBAAoB,EAAE,CAAC;CACxC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"command-policy-types.js","sourceRoot":"","sources":["../../src/security/command-policy-types.ts"],"names":[],"mappings":""}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import type { CommandSafeBinsPolicy, ParsedCommandSegment } from "./command-policy-types.js";
|
|
2
|
-
import type { CommandAllowlistPolicy } from "./command-policy-types.js";
|
|
3
|
-
export declare function matchSafeBin(segment: ParsedCommandSegment, safeBins: CommandSafeBinsPolicy, allowlist: CommandAllowlistPolicy): string | null;
|
|
4
|
-
//# sourceMappingURL=command-safe-bins.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"command-safe-bins.d.ts","sourceRoot":"","sources":["../../src/security/command-safe-bins.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,qBAAqB,EACrB,oBAAoB,EACrB,MAAM,2BAA2B,CAAC;AAEnC,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAyExE,wBAAgB,YAAY,CAC1B,OAAO,EAAE,oBAAoB,EAC7B,QAAQ,EAAE,qBAAqB,EAC/B,SAAS,EAAE,sBAAsB,GAChC,MAAM,GAAG,IAAI,CAgBf"}
|