@nerdvana/parism 0.3.0 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/README.en.md +144 -43
  2. package/README.md +125 -51
  3. package/dist/cli/add.d.ts +9 -0
  4. package/dist/cli/add.d.ts.map +1 -0
  5. package/dist/cli/add.js +25 -0
  6. package/dist/cli/add.js.map +1 -0
  7. package/dist/cli/auto-loader.d.ts +7 -0
  8. package/dist/cli/auto-loader.d.ts.map +1 -0
  9. package/dist/cli/auto-loader.js +33 -0
  10. package/dist/cli/auto-loader.js.map +1 -0
  11. package/dist/cli/capture.d.ts +9 -0
  12. package/dist/cli/capture.d.ts.map +1 -0
  13. package/dist/cli/capture.js +50 -0
  14. package/dist/cli/capture.js.map +1 -0
  15. package/dist/cli/init-parser.d.ts +9 -0
  16. package/dist/cli/init-parser.d.ts.map +1 -0
  17. package/dist/cli/init-parser.js +66 -0
  18. package/dist/cli/init-parser.js.map +1 -0
  19. package/dist/cli/inspect.d.ts +16 -0
  20. package/dist/cli/inspect.d.ts.map +1 -0
  21. package/dist/cli/inspect.js +28 -0
  22. package/dist/cli/inspect.js.map +1 -0
  23. package/dist/cli/loader.d.ts +6 -0
  24. package/dist/cli/loader.d.ts.map +1 -0
  25. package/dist/cli/loader.js +19 -0
  26. package/dist/cli/loader.js.map +1 -0
  27. package/dist/cli/paths.d.ts +9 -0
  28. package/dist/cli/paths.d.ts.map +1 -0
  29. package/dist/cli/paths.js +19 -0
  30. package/dist/cli/paths.js.map +1 -0
  31. package/dist/cli/test-runner.d.ts +21 -0
  32. package/dist/cli/test-runner.d.ts.map +1 -0
  33. package/dist/cli/test-runner.js +36 -0
  34. package/dist/cli/test-runner.js.map +1 -0
  35. package/dist/cli.d.ts +6 -0
  36. package/dist/cli.d.ts.map +1 -0
  37. package/dist/cli.js +81 -0
  38. package/dist/cli.js.map +1 -0
  39. package/dist/engine/executor.d.ts +3 -1
  40. package/dist/engine/executor.d.ts.map +1 -1
  41. package/dist/engine/executor.js +8 -6
  42. package/dist/engine/executor.js.map +1 -1
  43. package/dist/engine/guard.d.ts.map +1 -1
  44. package/dist/engine/guard.js +20 -2
  45. package/dist/engine/guard.js.map +1 -1
  46. package/dist/index.js +28 -2
  47. package/dist/index.js.map +1 -1
  48. package/dist/parsers/index.d.ts +7 -1
  49. package/dist/parsers/index.d.ts.map +1 -1
  50. package/dist/parsers/index.js +66 -57
  51. package/dist/parsers/index.js.map +1 -1
  52. package/dist/parsers/registry.d.ts +52 -3
  53. package/dist/parsers/registry.d.ts.map +1 -1
  54. package/dist/parsers/registry.js +28 -6
  55. package/dist/parsers/registry.js.map +1 -1
  56. package/dist/server.d.ts +5 -4
  57. package/dist/server.d.ts.map +1 -1
  58. package/dist/server.js +18 -14
  59. package/dist/server.js.map +1 -1
  60. package/dist/types/envelope.d.ts +9 -0
  61. package/dist/types/envelope.d.ts.map +1 -1
  62. package/package.json +6 -1
  63. package/prism.config.json +5 -2
@@ -0,0 +1,50 @@
1
+ import { execFile } from "node:child_process";
2
+ import { writeFileSync, mkdirSync } from "node:fs";
3
+ import { join } from "node:path";
4
+ import { promisify } from "node:util";
5
+ import { parismHome } from "./paths.js";
6
+ const execFileAsync = promisify(execFile);
7
+ function timestamp() {
8
+ const d = new Date();
9
+ const pad = (n) => String(n).padStart(2, "0");
10
+ return `${d.getFullYear()}${pad(d.getMonth() + 1)}${pad(d.getDate())}-` +
11
+ `${pad(d.getHours())}${pad(d.getMinutes())}${pad(d.getSeconds())}`;
12
+ }
13
+ /**
14
+ * 명령어를 실행하고 stdout/stderr/exitCode를 fixture JSON으로 저장한다.
15
+ */
16
+ export async function captureCommand(cmd, args, fixturesDir) {
17
+ const dir = fixturesDir ?? join(parismHome(), "fixtures");
18
+ mkdirSync(dir, { recursive: true });
19
+ let stdout;
20
+ let stderr;
21
+ let exitCode;
22
+ try {
23
+ const result = await execFileAsync(cmd, args, {
24
+ timeout: 30_000,
25
+ maxBuffer: 10 * 1024 * 1024,
26
+ });
27
+ stdout = result.stdout;
28
+ stderr = result.stderr;
29
+ exitCode = 0;
30
+ }
31
+ catch (err) {
32
+ const execErr = err;
33
+ stdout = execErr.stdout ?? "";
34
+ stderr = execErr.stderr ?? "";
35
+ exitCode = execErr.code ?? 1;
36
+ }
37
+ const fixture = {
38
+ command: cmd,
39
+ args,
40
+ stdout,
41
+ stderr,
42
+ exitCode,
43
+ captured_at: new Date().toISOString(),
44
+ };
45
+ const filename = `${cmd}-${timestamp()}.json`;
46
+ const fixturePath = join(dir, filename);
47
+ writeFileSync(fixturePath, JSON.stringify(fixture, null, 2));
48
+ return { exitCode, fixturePath };
49
+ }
50
+ //# sourceMappingURL=capture.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"capture.js","sourceRoot":"","sources":["../../src/cli/capture.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAS,oBAAoB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAa,WAAW,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAQ,WAAW,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAO,YAAY,CAAC;AAEzC,MAAM,aAAa,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;AAO1C,SAAS,SAAS;IAChB,MAAM,CAAC,GAAK,IAAI,IAAI,EAAE,CAAC;IACvB,MAAM,GAAG,GAAG,CAAC,CAAS,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACtD,OAAO,GAAG,CAAC,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,GAAG;QAChE,GAAG,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC;AAC5E,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,GAAY,EACZ,IAAc,EACd,WAAoB;IAEpB,MAAM,GAAG,GAAG,WAAW,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1D,SAAS,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAEpC,IAAI,MAAgB,CAAC;IACrB,IAAI,MAAgB,CAAC;IACrB,IAAI,QAAgB,CAAC;IAErB,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,GAAG,EAAE,IAAI,EAAE;YAC5C,OAAO,EAAI,MAAM;YACjB,SAAS,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI;SAC5B,CAAC,CAAC;QACH,MAAM,GAAK,MAAM,CAAC,MAAM,CAAC;QACzB,MAAM,GAAK,MAAM,CAAC,MAAM,CAAC;QACzB,QAAQ,GAAG,CAAC,CAAC;IACf,CAAC;IAAC,OAAO,GAAY,EAAE,CAAC;QACtB,MAAM,OAAO,GAAG,GAA0D,CAAC;QAC3E,MAAM,GAAK,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC;QAChC,MAAM,GAAK,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC;QAChC,QAAQ,GAAG,OAAO,CAAC,IAAI,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,MAAM,OAAO,GAAG;QACd,OAAO,EAAM,GAAG;QAChB,IAAI;QACJ,MAAM;QACN,MAAM;QACN,QAAQ;QACR,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KACtC,CAAC;IAEF,MAAM,QAAQ,GAAM,GAAG,GAAG,IAAI,SAAS,EAAE,OAAO,CAAC;IACjD,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;IACxC,aAAa,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IAE7D,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC;AACnC,CAAC"}
@@ -0,0 +1,9 @@
1
+ export interface InitResult {
2
+ name: string;
3
+ files: string[];
4
+ }
5
+ /**
6
+ * parser pack scaffold를 생성한다.
7
+ */
8
+ export declare function initParser(name: string, baseDir: string): InitResult;
9
+ //# sourceMappingURL=init-parser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init-parser.d.ts","sourceRoot":"","sources":["../../src/cli/init-parser.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,UAAU;IACzB,IAAI,EAAG,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAoDD;;GAEG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,UAAU,CAoBpE"}
@@ -0,0 +1,66 @@
1
+ import { mkdirSync, writeFileSync, existsSync } from "node:fs";
2
+ import { join } from "node:path";
3
+ /**
4
+ * parser.ts 템플릿을 생성한다.
5
+ */
6
+ function parserTemplate(name) {
7
+ return [
8
+ 'import type { ParserPack, ParseContext } from "@nerdvana/parism";',
9
+ "",
10
+ "const pack: ParserPack = {",
11
+ ' name: "' + name + '",',
12
+ "",
13
+ " parse(raw: string, args: string[], ctx?: ParseContext): unknown {",
14
+ ' const lines = raw.trim().split("\\n").filter(Boolean);',
15
+ "",
16
+ " // TODO: implement parsing logic",
17
+ " return {",
18
+ " items: lines,",
19
+ " };",
20
+ " },",
21
+ "",
22
+ " schema: {",
23
+ ' type: "object",',
24
+ " properties: {",
25
+ ' items: { type: "array", items: { type: "string" } },',
26
+ " },",
27
+ " },",
28
+ "",
29
+ " fixtures: [],",
30
+ "};",
31
+ "",
32
+ "export default pack;",
33
+ "",
34
+ ].join("\n");
35
+ }
36
+ /**
37
+ * schema.json 내용을 생성한다.
38
+ */
39
+ function schemaTemplate() {
40
+ return JSON.stringify({
41
+ type: "object",
42
+ properties: {
43
+ items: { type: "array", items: { type: "string" } },
44
+ },
45
+ }, null, 2);
46
+ }
47
+ /**
48
+ * parser pack scaffold를 생성한다.
49
+ */
50
+ export function initParser(name, baseDir) {
51
+ const packDir = join(baseDir, name);
52
+ if (existsSync(packDir)) {
53
+ throw new Error(`Parser pack "${name}" already exists at ${packDir}`);
54
+ }
55
+ mkdirSync(packDir, { recursive: true });
56
+ mkdirSync(join(packDir, "fixtures"), { recursive: true });
57
+ const parserPath = join(packDir, "parser.ts");
58
+ const schemaPath = join(packDir, "schema.json");
59
+ writeFileSync(parserPath, parserTemplate(name));
60
+ writeFileSync(schemaPath, schemaTemplate());
61
+ return {
62
+ name,
63
+ files: [parserPath, schemaPath],
64
+ };
65
+ }
66
+ //# sourceMappingURL=init-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init-parser.js","sourceRoot":"","sources":["../../src/cli/init-parser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAOjC;;GAEG;AACH,SAAS,cAAc,CAAC,IAAY;IAClC,OAAO;QACL,mEAAmE;QACnE,EAAE;QACF,4BAA4B;QAC5B,WAAW,GAAG,IAAI,GAAG,IAAI;QACzB,EAAE;QACF,qEAAqE;QACrE,4DAA4D;QAC5D,EAAE;QACF,sCAAsC;QACtC,cAAc;QACd,qBAAqB;QACrB,QAAQ;QACR,MAAM;QACN,EAAE;QACF,aAAa;QACb,qBAAqB;QACrB,mBAAmB;QACnB,4DAA4D;QAC5D,QAAQ;QACR,MAAM;QACN,EAAE;QACF,iBAAiB;QACjB,IAAI;QACJ,EAAE;QACF,sBAAsB;QACtB,EAAE;KACH,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACf,CAAC;AAED;;GAEG;AACH,SAAS,cAAc;IACrB,OAAO,IAAI,CAAC,SAAS,CACnB;QACE,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,KAAK,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE;SACpD;KACF,EACD,IAAI,EACJ,CAAC,CACF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,UAAU,CAAC,IAAY,EAAE,OAAe;IACtD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAEpC,IAAI,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,gBAAgB,IAAI,uBAAuB,OAAO,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,SAAS,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACxC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAE1D,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;IAC9C,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IAEhD,aAAa,CAAC,UAAU,EAAE,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC;IAChD,aAAa,CAAC,UAAU,EAAE,cAAc,EAAE,CAAC,CAAC;IAE5C,OAAO;QACL,IAAI;QACJ,KAAK,EAAE,CAAC,UAAU,EAAE,UAAU,CAAC;KAChC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,16 @@
1
+ import type { ParserRegistry } from "../parsers/registry.js";
2
+ export interface InspectResult {
3
+ raw: string;
4
+ parsed: unknown | null;
5
+ compact: unknown | null;
6
+ tokens: {
7
+ raw: number;
8
+ parsed: number;
9
+ compact: number;
10
+ };
11
+ }
12
+ /**
13
+ * 명령어 raw 출력을 파싱/컴팩트 변환하고, 각 형식의 토큰 수를 추정한다.
14
+ */
15
+ export declare function inspectOutput(cmd: string, args: string[], raw: string, registry: ParserRegistry): InspectResult;
16
+ //# sourceMappingURL=inspect.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspect.d.ts","sourceRoot":"","sources":["../../src/cli/inspect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAG7D,MAAM,WAAW,aAAa;IAC5B,GAAG,EAAM,MAAM,CAAC;IAChB,MAAM,EAAG,OAAO,GAAG,IAAI,CAAC;IACxB,OAAO,EAAE,OAAO,GAAG,IAAI,CAAC;IACxB,MAAM,EAAE;QACN,GAAG,EAAM,MAAM,CAAC;QAChB,MAAM,EAAG,MAAM,CAAC;QAChB,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;CACH;AASD;;GAEG;AACH,wBAAgB,aAAa,CAC3B,GAAG,EAAO,MAAM,EAChB,IAAI,EAAM,MAAM,EAAE,EAClB,GAAG,EAAO,MAAM,EAChB,QAAQ,EAAE,cAAc,GACvB,aAAa,CAmBf"}
@@ -0,0 +1,28 @@
1
+ import { toCompact } from "../parsers/compact.js";
2
+ /**
3
+ * 토큰 수 추정. Math.ceil(text.length / 4) -- 간단한 근사.
4
+ */
5
+ function estimateTokens(text) {
6
+ return Math.ceil(text.length / 4);
7
+ }
8
+ /**
9
+ * 명령어 raw 출력을 파싱/컴팩트 변환하고, 각 형식의 토큰 수를 추정한다.
10
+ */
11
+ export function inspectOutput(cmd, args, raw, registry) {
12
+ const { parsed } = registry.parse(cmd, args, raw);
13
+ const compact = parsed != null ? toCompact(parsed) : null;
14
+ const rawTokens = estimateTokens(raw);
15
+ const parsedTokens = parsed != null ? estimateTokens(JSON.stringify(parsed, null, 2)) : 0;
16
+ const compactTokens = compact != null ? estimateTokens(JSON.stringify(compact, null, 2)) : 0;
17
+ return {
18
+ raw,
19
+ parsed,
20
+ compact,
21
+ tokens: {
22
+ raw: rawTokens,
23
+ parsed: parsedTokens,
24
+ compact: compactTokens,
25
+ },
26
+ };
27
+ }
28
+ //# sourceMappingURL=inspect.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspect.js","sourceRoot":"","sources":["../../src/cli/inspect.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAgB,uBAAuB,CAAC;AAa5D;;GAEG;AACH,SAAS,cAAc,CAAC,IAAY;IAClC,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AACpC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa,CAC3B,GAAgB,EAChB,IAAkB,EAClB,GAAgB,EAChB,QAAwB;IAExB,MAAM,EAAE,MAAM,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;IAElD,MAAM,OAAO,GAAG,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAE1D,MAAM,SAAS,GAAO,cAAc,CAAC,GAAG,CAAC,CAAC;IAC1C,MAAM,YAAY,GAAI,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3F,MAAM,aAAa,GAAG,OAAO,IAAI,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAE7F,OAAO;QACL,GAAG;QACH,MAAM;QACN,OAAO;QACP,MAAM,EAAE;YACN,GAAG,EAAM,SAAS;YAClB,MAAM,EAAG,YAAY;YACrB,OAAO,EAAE,aAAa;SACvB;KACF,CAAC;AACJ,CAAC"}
@@ -0,0 +1,6 @@
1
+ import type { ParserPack } from "../parsers/registry.js";
2
+ /**
3
+ * 디렉토리에서 parser.js를 동적 import로 로드한다.
4
+ */
5
+ export declare function loadParserPack(packDir: string): Promise<ParserPack>;
6
+ //# sourceMappingURL=loader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../src/cli/loader.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEzD;;GAEG;AACH,wBAAsB,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAezE"}
@@ -0,0 +1,19 @@
1
+ import { existsSync } from "node:fs";
2
+ import { join } from "node:path";
3
+ import { pathToFileURL } from "node:url";
4
+ /**
5
+ * 디렉토리에서 parser.js를 동적 import로 로드한다.
6
+ */
7
+ export async function loadParserPack(packDir) {
8
+ const parserPath = join(packDir, "parser.js");
9
+ if (!existsSync(parserPath)) {
10
+ throw new Error(`parser.js not found in ${packDir}`);
11
+ }
12
+ const mod = await import(pathToFileURL(parserPath).href);
13
+ const pack = mod.default;
14
+ if (!pack || typeof pack.name !== "string" || typeof pack.parse !== "function") {
15
+ throw new Error(`Invalid default export in ${parserPath} -- must be a ParserPack`);
16
+ }
17
+ return pack;
18
+ }
19
+ //# sourceMappingURL=loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/cli/loader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAS,SAAS,CAAC;AACxC,OAAO,EAAE,IAAI,EAAE,MAAe,WAAW,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAGzC;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,OAAe;IAClD,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;IAE9C,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,KAAK,CAAC,0BAA0B,OAAO,EAAE,CAAC,CAAC;IACvD,CAAC;IAED,MAAM,GAAG,GAAI,MAAM,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC;IAC1D,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,CAAC;IAEzB,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,UAAU,EAAE,CAAC;QAC/E,MAAM,IAAI,KAAK,CAAC,6BAA6B,UAAU,0BAA0B,CAAC,CAAC;IACrF,CAAC;IAED,OAAO,IAAkB,CAAC;AAC5B,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Parism 홈 디렉토리 경로. PARISM_HOME 환경변수 우선, 없으면 ~/.parism.
3
+ */
4
+ export declare function parismHome(): string;
5
+ /**
6
+ * ~/.parism/ 하위 디렉토리 구조를 보장한다.
7
+ */
8
+ export declare function ensureParismDirs(base?: string): string;
9
+ //# sourceMappingURL=paths.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"paths.d.ts","sourceRoot":"","sources":["../../src/cli/paths.ts"],"names":[],"mappings":"AAIA;;GAEG;AACH,wBAAgB,UAAU,IAAI,MAAM,CAEnC;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAKtD"}
@@ -0,0 +1,19 @@
1
+ import { mkdirSync } from "node:fs";
2
+ import { homedir } from "node:os";
3
+ import { join } from "node:path";
4
+ /**
5
+ * Parism 홈 디렉토리 경로. PARISM_HOME 환경변수 우선, 없으면 ~/.parism.
6
+ */
7
+ export function parismHome() {
8
+ return process.env.PARISM_HOME ?? join(homedir(), ".parism");
9
+ }
10
+ /**
11
+ * ~/.parism/ 하위 디렉토리 구조를 보장한다.
12
+ */
13
+ export function ensureParismDirs(base) {
14
+ const home = base ?? parismHome();
15
+ mkdirSync(join(home, "fixtures"), { recursive: true });
16
+ mkdirSync(join(home, "parsers"), { recursive: true });
17
+ return home;
18
+ }
19
+ //# sourceMappingURL=paths.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"paths.js","sourceRoot":"","sources":["../../src/cli/paths.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAQ,SAAS,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAW,WAAW,CAAC;AAEtC;;GAEG;AACH,MAAM,UAAU,UAAU;IACxB,OAAO,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,CAAC,CAAC;AAC/D,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAC,IAAa;IAC5C,MAAM,IAAI,GAAG,IAAI,IAAI,UAAU,EAAE,CAAC;IAClC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACvD,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,EAAG,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACvD,OAAO,IAAI,CAAC;AACd,CAAC"}
@@ -0,0 +1,21 @@
1
+ import type { ParserPack } from "../parsers/registry.js";
2
+ export interface FixtureTestDetail {
3
+ index: number;
4
+ status: "pass" | "fail" | "error";
5
+ expected: unknown;
6
+ actual?: unknown;
7
+ error?: string;
8
+ }
9
+ export interface FixtureTestResults {
10
+ name: string;
11
+ total: number;
12
+ passed: number;
13
+ failed: number;
14
+ errored: number;
15
+ details: FixtureTestDetail[];
16
+ }
17
+ /**
18
+ * ParserPack의 fixture를 순회하며 replay 테스트를 실행한다.
19
+ */
20
+ export declare function runFixtureTests(pack: ParserPack): FixtureTestResults;
21
+ //# sourceMappingURL=test-runner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"test-runner.d.ts","sourceRoot":"","sources":["../../src/cli/test-runner.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEzD,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAK,MAAM,CAAC;IACjB,MAAM,EAAI,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;IACpC,QAAQ,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAG,OAAO,CAAC;IAClB,KAAK,CAAC,EAAI,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAK,MAAM,CAAC;IAChB,KAAK,EAAI,MAAM,CAAC;IAChB,MAAM,EAAG,MAAM,CAAC;IAChB,MAAM,EAAG,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,iBAAiB,EAAE,CAAC;CAC9B;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,UAAU,GAAG,kBAAkB,CAkCpE"}
@@ -0,0 +1,36 @@
1
+ /**
2
+ * ParserPack의 fixture를 순회하며 replay 테스트를 실행한다.
3
+ */
4
+ export function runFixtureTests(pack) {
5
+ const details = [];
6
+ for (let i = 0; i < pack.fixtures.length; i++) {
7
+ const fixture = pack.fixtures[i];
8
+ try {
9
+ const actual = pack.parse(fixture.input, fixture.args);
10
+ const match = JSON.stringify(actual) === JSON.stringify(fixture.expected);
11
+ details.push({
12
+ index: i,
13
+ status: match ? "pass" : "fail",
14
+ expected: fixture.expected,
15
+ actual,
16
+ });
17
+ }
18
+ catch (err) {
19
+ details.push({
20
+ index: i,
21
+ status: "error",
22
+ expected: fixture.expected,
23
+ error: err instanceof Error ? err.message : String(err),
24
+ });
25
+ }
26
+ }
27
+ return {
28
+ name: pack.name,
29
+ total: details.length,
30
+ passed: details.filter(d => d.status === "pass").length,
31
+ failed: details.filter(d => d.status === "fail").length,
32
+ errored: details.filter(d => d.status === "error").length,
33
+ details,
34
+ };
35
+ }
36
+ //# sourceMappingURL=test-runner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"test-runner.js","sourceRoot":"","sources":["../../src/cli/test-runner.ts"],"names":[],"mappings":"AAmBA;;GAEG;AACH,MAAM,UAAU,eAAe,CAAC,IAAgB;IAC9C,MAAM,OAAO,GAAwB,EAAE,CAAC;IAExC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAEjC,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;YACvD,MAAM,KAAK,GAAI,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAE3E,OAAO,CAAC,IAAI,CAAC;gBACX,KAAK,EAAK,CAAC;gBACX,MAAM,EAAI,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;gBACjC,QAAQ,EAAE,OAAO,CAAC,QAAQ;gBAC1B,MAAM;aACP,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,IAAI,CAAC;gBACX,KAAK,EAAK,CAAC;gBACX,MAAM,EAAI,OAAO;gBACjB,QAAQ,EAAE,OAAO,CAAC,QAAQ;gBAC1B,KAAK,EAAK,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;aAC3D,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO;QACL,IAAI,EAAK,IAAI,CAAC,IAAI;QAClB,KAAK,EAAI,OAAO,CAAC,MAAM;QACvB,MAAM,EAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC,MAAM;QACxD,MAAM,EAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC,MAAM;QACxD,OAAO,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,MAAM;QACzD,OAAO;KACR,CAAC;AACJ,CAAC"}
package/dist/cli.d.ts ADDED
@@ -0,0 +1,6 @@
1
+ import { Command } from "commander";
2
+ /**
3
+ * CLI 프로그램을 생성한다. 명령어 핸들러는 각 모듈에서 등록.
4
+ */
5
+ export declare function createCli(): Command;
6
+ //# sourceMappingURL=cli.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC;;GAEG;AACH,wBAAgB,SAAS,IAAI,OAAO,CAoFnC"}
package/dist/cli.js ADDED
@@ -0,0 +1,81 @@
1
+ import { Command } from "commander";
2
+ /**
3
+ * CLI 프로그램을 생성한다. 명령어 핸들러는 각 모듈에서 등록.
4
+ */
5
+ export function createCli() {
6
+ const program = new Command();
7
+ program
8
+ .name("parism")
9
+ .description("Structured shell output for AI agents")
10
+ .version("0.5.0");
11
+ program
12
+ .command("capture <command>")
13
+ .description("Execute command and save raw output as fixture")
14
+ .option("-o, --output <dir>", "Output directory", "~/.parism/fixtures")
15
+ .action(async (command, options) => {
16
+ const { captureCommand } = await import("./cli/capture.js");
17
+ const parts = command.split(/\s+/);
18
+ const cmd = parts[0];
19
+ const args = parts.slice(1);
20
+ const result = await captureCommand(cmd, args, options.output);
21
+ console.log(`Fixture saved: ${result.fixturePath}`);
22
+ console.log(`Exit code: ${result.exitCode}`);
23
+ });
24
+ program
25
+ .command("init-parser <name>")
26
+ .description("Scaffold a new parser pack (TypeScript + schema + test)")
27
+ .option("-d, --dir <dir>", "Output directory", ".")
28
+ .action(async (name, options) => {
29
+ const { initParser } = await import("./cli/init-parser.js");
30
+ const result = initParser(name, options.dir ?? ".");
31
+ console.log(`Parser pack "${result.name}" created:`);
32
+ result.files.forEach(f => console.log(` ${f}`));
33
+ });
34
+ program
35
+ .command("test [parser]")
36
+ .description("Run fixture replay tests for a parser pack")
37
+ .action(async (_parser) => {
38
+ console.log("[parism] test: not yet implemented");
39
+ process.exit(1);
40
+ });
41
+ program
42
+ .command("add <path>")
43
+ .description("Register a local parser pack permanently")
44
+ .action(async (pathArg) => {
45
+ const { addParserPack } = await import("./cli/add.js");
46
+ const result = await addParserPack(pathArg);
47
+ console.log(`Parser "${result.name}" added to ${result.installedTo}`);
48
+ });
49
+ program
50
+ .command("inspect <command>")
51
+ .description("Show raw / parsed / compact output comparison")
52
+ .action(async (command) => {
53
+ const { inspectOutput } = await import("./cli/inspect.js");
54
+ const { createRegistry } = await import("./parsers/index.js");
55
+ const { execFile } = await import("node:child_process");
56
+ const { promisify } = await import("node:util");
57
+ const execFileAsync = promisify(execFile);
58
+ const parts = command.split(/\s+/);
59
+ const cmd = parts[0];
60
+ const args = parts.slice(1);
61
+ const registry = createRegistry();
62
+ let raw;
63
+ try {
64
+ const result = await execFileAsync(cmd, args, { timeout: 10_000 });
65
+ raw = result.stdout;
66
+ }
67
+ catch (err) {
68
+ raw = err.stdout ?? "";
69
+ }
70
+ const result = inspectOutput(cmd, args, raw, registry);
71
+ console.log("=== RAW ===");
72
+ console.log(result.raw);
73
+ console.log("\n=== PARSED ===");
74
+ console.log(JSON.stringify(result.parsed, null, 2));
75
+ console.log("\n=== COMPACT ===");
76
+ console.log(JSON.stringify(result.compact, null, 2));
77
+ console.log(`\nTokens: raw=${result.tokens.raw} parsed=${result.tokens.parsed} compact=${result.tokens.compact}`);
78
+ });
79
+ return program;
80
+ }
81
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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"}
@@ -4,6 +4,8 @@ import type { ResponseEnvelope } from "../types/envelope.js";
4
4
  * - 셸을 거치지 않으므로 셸 확장/인젝션 위험 없음
5
5
  * - secretPatterns에 해당하는 환경 변수는 자식 프로세스에 전달하지 않음
6
6
  * - 실행 실패(명령 없음 포함)는 예외 대신 ok=false 봉투로 반환
7
+ * - includeDiff=false면 파일시스템 스냅샷을 생략하여 지연을 줄인다 (MCP 고빈도 호출 권장)
7
8
  */
8
- export declare function execute(cmd: string, args: string[], cwd: string, secretPatterns?: string[], timeoutMs?: number, maxOutputBytes?: number): Promise<ResponseEnvelope>;
9
+ export declare function execute(cmd: string, args: string[], cwd: string, secretPatterns?: string[], timeoutMs?: number, maxOutputBytes?: number, // 0 = 무제한
10
+ includeDiff?: boolean): Promise<ResponseEnvelope>;
9
11
  //# sourceMappingURL=executor.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../../src/engine/executor.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAsB7D;;;;;GAKG;AACH,wBAAsB,OAAO,CAC3B,GAAG,EAAc,MAAM,EACvB,IAAI,EAAa,MAAM,EAAE,EACzB,GAAG,EAAc,MAAM,EACvB,cAAc,GAAG,MAAM,EAAO,EAC9B,SAAS,GAAQ,MAAgB,EACjC,cAAc,GAAG,MAAY,GAC5B,OAAO,CAAC,gBAAgB,CAAC,CA6D3B"}
1
+ {"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../../src/engine/executor.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAuB7D;;;;;;GAMG;AACH,wBAAsB,OAAO,CAC3B,GAAG,EAAc,MAAM,EACvB,IAAI,EAAa,MAAM,EAAE,EACzB,GAAG,EAAc,MAAM,EACvB,cAAc,GAAG,MAAM,EAAO,EAC9B,SAAS,GAAQ,MAAgB,EACjC,cAAc,GAAG,MAAY,EAAO,UAAU;AAC9C,WAAW,GAAM,OAAe,GAC/B,OAAO,CAAC,gBAAgB,CAAC,CA6D3B"}
@@ -23,10 +23,12 @@ function buildSanitizedEnv(secretPatterns) {
23
23
  * - 셸을 거치지 않으므로 셸 확장/인젝션 위험 없음
24
24
  * - secretPatterns에 해당하는 환경 변수는 자식 프로세스에 전달하지 않음
25
25
  * - 실행 실패(명령 없음 포함)는 예외 대신 ok=false 봉투로 반환
26
+ * - includeDiff=false면 파일시스템 스냅샷을 생략하여 지연을 줄인다 (MCP 고빈도 호출 권장)
26
27
  */
27
- export async function execute(cmd, args, cwd, secretPatterns = [], timeoutMs = 10000, maxOutputBytes = 0) {
28
+ export async function execute(cmd, args, cwd, secretPatterns = [], timeoutMs = 10000, maxOutputBytes = 0, // 0 = 무제한
29
+ includeDiff = true) {
28
30
  const start = Date.now();
29
- const before = await takeSnapshot(cwd);
31
+ const before = includeDiff ? await takeSnapshot(cwd) : null;
30
32
  try {
31
33
  const { stdout, stderr } = await execFileAsync(cmd, args, {
32
34
  cwd,
@@ -34,7 +36,7 @@ export async function execute(cmd, args, cwd, secretPatterns = [], timeoutMs = 1
34
36
  maxBuffer: 10 * 1024 * 1024, // 10 MB
35
37
  env: { ...buildSanitizedEnv(secretPatterns), LC_ALL: "C", LANG: "C" },
36
38
  });
37
- const after = await takeSnapshot(cwd);
39
+ const after = includeDiff ? await takeSnapshot(cwd) : null;
38
40
  // stdout 크기 제한: 초과 시 마지막 완전한 줄까지 잘라내고 truncated=true 표시
39
41
  let outRaw = stdout;
40
42
  let truncated;
@@ -55,14 +57,14 @@ export async function execute(cmd, args, cwd, secretPatterns = [], timeoutMs = 1
55
57
  duration_ms: Date.now() - start,
56
58
  stdout: { raw: outRaw, parsed: null },
57
59
  stderr: { raw: stderr, parsed: null },
58
- diff: computeDiff(before, after),
60
+ diff: before && after ? computeDiff(before, after) : null,
59
61
  truncated,
60
62
  };
61
63
  }
62
64
  catch (err) {
63
65
  const e = err;
64
66
  const exitCode = typeof e.code === "number" ? e.code : 1;
65
- const after = await takeSnapshot(cwd);
67
+ const after = includeDiff ? await takeSnapshot(cwd) : null;
66
68
  return {
67
69
  ok: false,
68
70
  exitCode,
@@ -72,7 +74,7 @@ export async function execute(cmd, args, cwd, secretPatterns = [], timeoutMs = 1
72
74
  duration_ms: Date.now() - start,
73
75
  stdout: { raw: e.stdout ?? "", parsed: null },
74
76
  stderr: { raw: e.stderr ?? e.message, parsed: null },
75
- diff: computeDiff(before, after),
77
+ diff: before && after ? computeDiff(before, after) : null,
76
78
  };
77
79
  }
78
80
  }
@@ -1 +1 @@
1
- {"version":3,"file":"executor.js","sourceRoot":"","sources":["../../src/engine/executor.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"executor.js","sourceRoot":"","sources":["../../src/engine/executor.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"guard.d.ts","sourceRoot":"","sources":["../../src/engine/guard.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAEvD;;GAEG;AACH,qBAAa,UAAW,SAAQ,KAAK;aAGjB,MAAM,EAClB,qBAAqB,GACrB,kBAAkB,GAClB,mBAAmB,GACnB,iBAAiB;gBALrB,OAAO,EAAE,MAAM,EACC,MAAM,EAClB,qBAAqB,GACrB,kBAAkB,GAClB,mBAAmB,GACnB,iBAAiB;CAKxB;AAgCD;;;;;;;;GAQG;AACH,wBAAgB,UAAU,CACxB,GAAG,EAAK,MAAM,EACd,IAAI,EAAI,MAAM,EAAE,EAChB,GAAG,EAAK,MAAM,EACd,MAAM,EAAE,WAAW,GAClB,IAAI,CAyDN"}
1
+ {"version":3,"file":"guard.d.ts","sourceRoot":"","sources":["../../src/engine/guard.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAEvD;;GAEG;AACH,qBAAa,UAAW,SAAQ,KAAK;aAGjB,MAAM,EAClB,qBAAqB,GACrB,kBAAkB,GAClB,mBAAmB,GACnB,iBAAiB;gBALrB,OAAO,EAAE,MAAM,EACC,MAAM,EAClB,qBAAqB,GACrB,kBAAkB,GAClB,mBAAmB,GACnB,iBAAiB;CAKxB;AAiDD;;;;;;;;GAQG;AACH,wBAAgB,UAAU,CACxB,GAAG,EAAK,MAAM,EACd,IAAI,EAAI,MAAM,EAAE,EAChB,GAAG,EAAK,MAAM,EACd,MAAM,EAAE,WAAW,GAClB,IAAI,CA4DN"}
@@ -28,13 +28,29 @@ function isAllowedPath(targetPath, allowedPaths) {
28
28
  });
29
29
  }
30
30
  /**
31
- * 명령 인자 중 실제 파일시스템 경로로 해석 가능한 값만 추출한다.
31
+ * 명령 인자 중 `/`, `./`, `../`로 시작하는 경로형 인자만 추출한다.
32
32
  */
33
33
  function getPathLikeArgs(args) {
34
34
  return args.filter((arg) => arg.startsWith("/") ||
35
35
  arg.startsWith("./") ||
36
36
  arg.startsWith("../"));
37
37
  }
38
+ /**
39
+ * 경로 인자를 받는 명령. 플래그가 아닌(positional) 인자를 경로 후보로 검사한다.
40
+ * find src, cat subdir/file, ls -la dir 등 상대경로(슬래시 없음)도 검사 대상.
41
+ */
42
+ const PATH_TAKING_COMMANDS = new Set([
43
+ "cat", "find", "stat", "du", "tree", "head", "tail", "ls", "grep", "wc",
44
+ ]);
45
+ /**
46
+ * 명령별로 경로로 해석되는 인자들을 수집한다.
47
+ * PATH_TAKING_COMMANDS에 있는 명령은 플래그로 시작하지 않는 인자를 경로 후보로 본다.
48
+ */
49
+ function getPathArgsFromCommand(cmd, args) {
50
+ if (!PATH_TAKING_COMMANDS.has(cmd))
51
+ return [];
52
+ return args.filter((arg) => arg !== "-" && !arg.startsWith("-"));
53
+ }
38
54
  /**
39
55
  * 명령 실행 허용 여부를 검사한다. 차단 조건 충족 시 GuardError를 던진다.
40
56
  *
@@ -72,7 +88,9 @@ export function checkGuard(cmd, args, cwd, config) {
72
88
  "Add guard.allowed_paths in prism.config.json or set [] to disable.", "path_not_allowed");
73
89
  }
74
90
  const pathLikeArgs = getPathLikeArgs(args);
75
- for (const arg of pathLikeArgs) {
91
+ const pathArgsByCmd = getPathArgsFromCommand(cmd, args);
92
+ const allPathArgs = [...new Set([...pathLikeArgs, ...pathArgsByCmd])];
93
+ for (const arg of allPathArgs) {
76
94
  const resolvedArgPath = path.resolve(cwd, arg);
77
95
  if (!isAllowedPath(resolvedArgPath, guard.allowed_paths)) {
78
96
  throw new GuardError(`Path argument '${arg}' resolves outside allowed paths. ` +
@@ -1 +1 @@
1
- {"version":3,"file":"guard.js","sourceRoot":"","sources":["../../src/engine/guard.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AAGxB;;GAEG;AACH,MAAM,OAAO,UAAW,SAAQ,KAAK;IAGjB;IAFlB,YACE,OAAe,EACC,MAIK;QAErB,KAAK,CAAC,OAAO,CAAC,CAAC;QANC,WAAM,GAAN,MAAM,CAID;QAGrB,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC;IAC3B,CAAC;CACF;AAED;;GAEG;AACH,SAAS,sBAAsB,CAAC,SAAiB;IAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACzC,OAAO,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,GAAG,GAAG,CAAC;AAC5D,CAAC;AAED;;GAEG;AACH,SAAS,aAAa,CAAC,UAAkB,EAAE,YAAsB;IAC/D,MAAM,gBAAgB,GAAG,sBAAsB,CAAC,UAAU,CAAC,CAAC;IAC5D,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE;QACvC,MAAM,iBAAiB,GAAG,sBAAsB,CAAC,WAAW,CAAC,CAAC;QAC9D,OAAO,gBAAgB,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,SAAS,eAAe,CAAC,IAAc;IACrC,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CACzB,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC;QACnB,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC;QACpB,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,CACtB,CAAC;AACJ,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,UAAU,UAAU,CACxB,GAAc,EACd,IAAgB,EAChB,GAAc,EACd,MAAmB;IAEnB,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;IAEzB,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QAC1C,MAAM,IAAI,UAAU,CAClB,YAAY,GAAG,8BAA8B,EAC7C,qBAAqB,CACtB,CAAC;IACJ,CAAC;IAED,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC/B,KAAK,MAAM,OAAO,IAAI,KAAK,CAAC,cAAc,EAAE,CAAC;QAC3C,IAAI,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YAC9B,MAAM,IAAI,UAAU,CAClB,oBAAoB,OAAO,yBAAyB,EACpD,mBAAmB,CACpB,CAAC;QACJ,CAAC;IACH,CAAC;IAED,MAAM,WAAW,GAAG,KAAK,CAAC,wBAAwB,EAAE,CAAC,GAAG,CAAC,CAAC;IAC1D,IAAI,WAAW,EAAE,CAAC;QAChB,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,+BAA+B;YAC/B,MAAM,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAE,CAAC,CAAC,CAAC,GAAG,CAAC;YACnE,IAAI,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;gBACnD,MAAM,IAAI,UAAU,CAClB,aAAa,GAAG,iCAAiC,GAAG,GAAG,EACvD,iBAAiB,CAClB,CAAC;YACJ,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACnC,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAEtC,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,KAAK,CAAC,aAAa,CAAC,EAAE,CAAC;YACrD,MAAM,IAAI,UAAU,CAClB,sBAAsB,GAAG,8BAA8B;gBACvD,oEAAoE,EACpE,kBAAkB,CACnB,CAAC;QACJ,CAAC;QAED,MAAM,YAAY,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC;QAC3C,KAAK,MAAM,GAAG,IAAI,YAAY,EAAE,CAAC;YAC/B,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;YAC/C,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,KAAK,CAAC,aAAa,CAAC,EAAE,CAAC;gBACzD,MAAM,IAAI,UAAU,CAClB,kBAAkB,GAAG,oCAAoC;oBACzD,oEAAoE,EACpE,kBAAkB,CACnB,CAAC;YACJ,CAAC;QACH,CAAC;IACH,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"guard.js","sourceRoot":"","sources":["../../src/engine/guard.ts"],"names":[],"mappings":"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"}