@gencode/agents 0.0.2 → 0.0.4

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 (69) hide show
  1. package/dist/commands/help.js +6 -6
  2. package/dist/commands/help.js.map +1 -1
  3. package/dist/commands/new.d.ts.map +1 -1
  4. package/dist/commands/new.js +12 -1
  5. package/dist/commands/new.js.map +1 -1
  6. package/dist/commands/registry.js +5 -5
  7. package/dist/commands/registry.js.map +1 -1
  8. package/dist/config-DJX-VM7S.js +198 -0
  9. package/dist/config-DJX-VM7S.js.map +1 -0
  10. package/dist/index-JD6Ye-N5.d.ts +149 -0
  11. package/dist/index-JD6Ye-N5.d.ts.map +1 -0
  12. package/dist/manager-qXa-NP0p.js +1651 -0
  13. package/dist/manager-qXa-NP0p.js.map +1 -0
  14. package/dist/message.d.ts +11 -0
  15. package/dist/message.d.ts.map +1 -0
  16. package/dist/message.js +46 -0
  17. package/dist/message.js.map +1 -0
  18. package/dist/plugins/loader.js +1 -1
  19. package/dist/plugins/loader.js.map +1 -1
  20. package/dist/plugins/runtime.d.ts +9 -1
  21. package/dist/plugins/runtime.d.ts.map +1 -1
  22. package/dist/plugins/runtime.js +24 -4
  23. package/dist/plugins/runtime.js.map +1 -1
  24. package/dist/runner/runner.d.ts.map +1 -1
  25. package/dist/runner/runner.js +48 -13
  26. package/dist/runner/runner.js.map +1 -1
  27. package/dist/runner/skill-usage.d.ts +29 -0
  28. package/dist/runner/skill-usage.d.ts.map +1 -0
  29. package/dist/runner/skill-usage.js +65 -0
  30. package/dist/runner/skill-usage.js.map +1 -0
  31. package/dist/security/command-dangerous-rules.d.ts +4 -0
  32. package/dist/security/command-dangerous-rules.d.ts.map +1 -0
  33. package/dist/security/command-dangerous-rules.js +26 -0
  34. package/dist/security/command-dangerous-rules.js.map +1 -0
  35. package/dist/security/command-parser.d.ts +3 -0
  36. package/dist/security/command-parser.d.ts.map +1 -0
  37. package/dist/security/command-parser.js +191 -0
  38. package/dist/security/command-parser.js.map +1 -0
  39. package/dist/security/command-path-guard.d.ts +10 -0
  40. package/dist/security/command-path-guard.d.ts.map +1 -0
  41. package/dist/security/command-path-guard.js +126 -0
  42. package/dist/security/command-path-guard.js.map +1 -0
  43. package/dist/security/command-policy-config.d.ts +5 -0
  44. package/dist/security/command-policy-config.d.ts.map +1 -0
  45. package/dist/security/command-policy-config.js +212 -0
  46. package/dist/security/command-policy-config.js.map +1 -0
  47. package/dist/security/command-policy-engine.d.ts +8 -0
  48. package/dist/security/command-policy-engine.d.ts.map +1 -0
  49. package/dist/security/command-policy-engine.js +122 -0
  50. package/dist/security/command-policy-engine.js.map +1 -0
  51. package/dist/security/command-policy-types.d.ts +67 -0
  52. package/dist/security/command-policy-types.d.ts.map +1 -0
  53. package/dist/security/command-policy-types.js +2 -0
  54. package/dist/security/command-policy-types.js.map +1 -0
  55. package/dist/security/command-safe-bins.d.ts +4 -0
  56. package/dist/security/command-safe-bins.d.ts.map +1 -0
  57. package/dist/security/command-safe-bins.js +84 -0
  58. package/dist/security/command-safe-bins.js.map +1 -0
  59. package/dist/security/command-trusted-executables.d.ts +6 -0
  60. package/dist/security/command-trusted-executables.d.ts.map +1 -0
  61. package/dist/security/command-trusted-executables.js +57 -0
  62. package/dist/security/command-trusted-executables.js.map +1 -0
  63. package/dist/tools/cron.d.ts +22 -15
  64. package/dist/tools/cron.d.ts.map +1 -1
  65. package/dist/tools/cron.js +40 -20
  66. package/dist/tools/cron.js.map +1 -1
  67. package/dist/types.d.ts +5 -0
  68. package/dist/types.d.ts.map +1 -1
  69. package/package.json +1 -1
@@ -0,0 +1,191 @@
1
+ function hasUnsupportedShellSyntax(command) {
2
+ return (command.includes("$(") ||
3
+ command.includes("`") ||
4
+ command.includes("<<") ||
5
+ command.includes("<(") ||
6
+ command.includes(">("));
7
+ }
8
+ function splitTopLevel(command) {
9
+ const segments = [];
10
+ let current = "";
11
+ let quote = null;
12
+ let escaped = false;
13
+ for (let index = 0; index < command.length; index += 1) {
14
+ const char = command[index];
15
+ const next = command[index + 1];
16
+ if (escaped) {
17
+ current += char;
18
+ escaped = false;
19
+ continue;
20
+ }
21
+ if (char === "\\") {
22
+ current += char;
23
+ escaped = true;
24
+ continue;
25
+ }
26
+ if (quote) {
27
+ current += char;
28
+ if (char === quote) {
29
+ quote = null;
30
+ }
31
+ continue;
32
+ }
33
+ if (char === "'" || char === '"') {
34
+ quote = char;
35
+ current += char;
36
+ continue;
37
+ }
38
+ if (char === "|" && next === "|") {
39
+ segments.push(current.trim());
40
+ current = "";
41
+ index += 1;
42
+ continue;
43
+ }
44
+ if (char === "&" && next === "&") {
45
+ segments.push(current.trim());
46
+ current = "";
47
+ index += 1;
48
+ continue;
49
+ }
50
+ if (char === ";" || char === "|") {
51
+ segments.push(current.trim());
52
+ current = "";
53
+ continue;
54
+ }
55
+ current += char;
56
+ }
57
+ if (quote || escaped) {
58
+ return null;
59
+ }
60
+ if (current.trim().length > 0) {
61
+ segments.push(current.trim());
62
+ }
63
+ return segments.filter((segment) => segment.length > 0);
64
+ }
65
+ function tokenize(segment) {
66
+ const tokens = [];
67
+ let current = "";
68
+ let quote = null;
69
+ let escaped = false;
70
+ for (let index = 0; index < segment.length; index += 1) {
71
+ const char = segment[index];
72
+ if (escaped) {
73
+ current += char;
74
+ escaped = false;
75
+ continue;
76
+ }
77
+ if (char === "\\") {
78
+ escaped = true;
79
+ continue;
80
+ }
81
+ if (quote) {
82
+ if (char === quote) {
83
+ quote = null;
84
+ }
85
+ else {
86
+ current += char;
87
+ }
88
+ continue;
89
+ }
90
+ if (char === "'" || char === '"') {
91
+ quote = char;
92
+ continue;
93
+ }
94
+ if (/\s/.test(char)) {
95
+ if (current.length > 0) {
96
+ tokens.push(current);
97
+ current = "";
98
+ }
99
+ continue;
100
+ }
101
+ if (char === ">" || char === "<") {
102
+ if (current.length > 0) {
103
+ tokens.push(current);
104
+ current = "";
105
+ }
106
+ const next = segment[index + 1];
107
+ if ((char === ">" || char === "<") && next === char) {
108
+ tokens.push(char + next);
109
+ index += 1;
110
+ }
111
+ else {
112
+ tokens.push(char);
113
+ }
114
+ continue;
115
+ }
116
+ if (char === "2" && segment[index + 1] === ">") {
117
+ if (current.length > 0) {
118
+ tokens.push(current);
119
+ current = "";
120
+ }
121
+ tokens.push("2>");
122
+ index += 1;
123
+ continue;
124
+ }
125
+ current += char;
126
+ }
127
+ if (quote || escaped) {
128
+ return null;
129
+ }
130
+ if (current.length > 0) {
131
+ tokens.push(current);
132
+ }
133
+ return tokens;
134
+ }
135
+ function unwrapEnv(tokens) {
136
+ if (tokens[0] !== "env") {
137
+ return tokens;
138
+ }
139
+ let index = 1;
140
+ while (index < tokens.length && /^[A-Za-z_][A-Za-z0-9_]*=/.test(tokens[index])) {
141
+ index += 1;
142
+ }
143
+ return tokens.slice(index);
144
+ }
145
+ function buildSegment(raw) {
146
+ const tokens = tokenize(raw);
147
+ if (!tokens || tokens.length === 0) {
148
+ return null;
149
+ }
150
+ const redirections = [];
151
+ const argv = [];
152
+ for (let index = 0; index < tokens.length; index += 1) {
153
+ const token = tokens[index];
154
+ if (token === ">" || token === ">>" || token === "<" || token === "2>") {
155
+ const target = tokens[index + 1];
156
+ if (!target) {
157
+ return null;
158
+ }
159
+ redirections.push({ operator: token, target });
160
+ index += 1;
161
+ continue;
162
+ }
163
+ argv.push(token);
164
+ }
165
+ const unwrapped = unwrapEnv(argv);
166
+ return {
167
+ raw,
168
+ argv,
169
+ executable: unwrapped[0] ?? null,
170
+ redirections,
171
+ };
172
+ }
173
+ export function parseCommand(command) {
174
+ if (!command.trim() || hasUnsupportedShellSyntax(command)) {
175
+ return null;
176
+ }
177
+ const rawSegments = splitTopLevel(command);
178
+ if (!rawSegments || rawSegments.length === 0) {
179
+ return null;
180
+ }
181
+ const segments = [];
182
+ for (const raw of rawSegments) {
183
+ const segment = buildSegment(raw);
184
+ if (!segment) {
185
+ return null;
186
+ }
187
+ segments.push(segment);
188
+ }
189
+ return { segments };
190
+ }
191
+ //# sourceMappingURL=command-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-parser.js","sourceRoot":"","sources":["../../src/security/command-parser.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import type { CommandPathPolicy, ParsedCommandSegment } from "./command-policy-types.js";
2
+ import type { CommandAllowlistPolicy } from "./command-policy-types.js";
3
+ export declare function validateCommandPaths(params: {
4
+ cwd: string;
5
+ allowedRoot: string;
6
+ pathPolicy: CommandPathPolicy;
7
+ segment: ParsedCommandSegment;
8
+ allowlist: CommandAllowlistPolicy;
9
+ }): string | null;
10
+ //# sourceMappingURL=command-path-guard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-path-guard.d.ts","sourceRoot":"","sources":["../../src/security/command-path-guard.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAEzF,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAiGxE,wBAAgB,oBAAoB,CAAC,MAAM,EAAE;IAC3C,GAAG,EAAE,MAAM,CAAC;IACZ,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,oBAAoB,CAAC;IAC9B,SAAS,EAAE,sBAAsB,CAAC;CACnC,GAAG,MAAM,GAAG,IAAI,CA0ChB"}
@@ -0,0 +1,126 @@
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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-path-guard.js","sourceRoot":"","sources":["../../src/security/command-path-guard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
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
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,212 @@
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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-policy-config.js","sourceRoot":"","sources":["../../src/security/command-policy-config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
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
@@ -0,0 +1 @@
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"}