@nahisaho/katashiro-analyzer 0.2.2 → 0.2.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 (153) hide show
  1. package/dist/factcheck/ClaimParser.d.ts +41 -0
  2. package/dist/factcheck/ClaimParser.d.ts.map +1 -0
  3. package/dist/factcheck/ClaimParser.js +149 -0
  4. package/dist/factcheck/ClaimParser.js.map +1 -0
  5. package/dist/factcheck/ConsistencyChecker.d.ts +56 -0
  6. package/dist/factcheck/ConsistencyChecker.d.ts.map +1 -0
  7. package/dist/factcheck/ConsistencyChecker.js +184 -0
  8. package/dist/factcheck/ConsistencyChecker.js.map +1 -0
  9. package/dist/factcheck/EvidenceCollector.d.ts +89 -0
  10. package/dist/factcheck/EvidenceCollector.d.ts.map +1 -0
  11. package/dist/factcheck/EvidenceCollector.js +222 -0
  12. package/dist/factcheck/EvidenceCollector.js.map +1 -0
  13. package/dist/factcheck/FactChecker.d.ts +81 -0
  14. package/dist/factcheck/FactChecker.d.ts.map +1 -0
  15. package/dist/factcheck/FactChecker.js +302 -0
  16. package/dist/factcheck/FactChecker.js.map +1 -0
  17. package/dist/factcheck/TrustedSourceRegistry.d.ts +47 -0
  18. package/dist/factcheck/TrustedSourceRegistry.d.ts.map +1 -0
  19. package/dist/factcheck/TrustedSourceRegistry.js +208 -0
  20. package/dist/factcheck/TrustedSourceRegistry.js.map +1 -0
  21. package/dist/factcheck/VerdictGenerator.d.ts +36 -0
  22. package/dist/factcheck/VerdictGenerator.d.ts.map +1 -0
  23. package/dist/factcheck/VerdictGenerator.js +154 -0
  24. package/dist/factcheck/VerdictGenerator.js.map +1 -0
  25. package/dist/factcheck/index.d.ts +15 -0
  26. package/dist/factcheck/index.d.ts.map +1 -0
  27. package/dist/factcheck/index.js +14 -0
  28. package/dist/factcheck/index.js.map +1 -0
  29. package/dist/factcheck/types.d.ts +265 -0
  30. package/dist/factcheck/types.d.ts.map +1 -0
  31. package/dist/factcheck/types.js +18 -0
  32. package/dist/factcheck/types.js.map +1 -0
  33. package/dist/index.d.ts +5 -0
  34. package/dist/index.d.ts.map +1 -1
  35. package/dist/index.js +10 -0
  36. package/dist/index.js.map +1 -1
  37. package/dist/interpreter/CodeInterpreter.d.ts +119 -0
  38. package/dist/interpreter/CodeInterpreter.d.ts.map +1 -0
  39. package/dist/interpreter/CodeInterpreter.js +241 -0
  40. package/dist/interpreter/CodeInterpreter.js.map +1 -0
  41. package/dist/interpreter/CodeValidator.d.ts +57 -0
  42. package/dist/interpreter/CodeValidator.d.ts.map +1 -0
  43. package/dist/interpreter/CodeValidator.js +283 -0
  44. package/dist/interpreter/CodeValidator.js.map +1 -0
  45. package/dist/interpreter/ExecutionEngine.d.ts +73 -0
  46. package/dist/interpreter/ExecutionEngine.d.ts.map +1 -0
  47. package/dist/interpreter/ExecutionEngine.js +273 -0
  48. package/dist/interpreter/ExecutionEngine.js.map +1 -0
  49. package/dist/interpreter/ResultFormatter.d.ts +72 -0
  50. package/dist/interpreter/ResultFormatter.d.ts.map +1 -0
  51. package/dist/interpreter/ResultFormatter.js +187 -0
  52. package/dist/interpreter/ResultFormatter.js.map +1 -0
  53. package/dist/interpreter/SandboxManager.d.ts +111 -0
  54. package/dist/interpreter/SandboxManager.d.ts.map +1 -0
  55. package/dist/interpreter/SandboxManager.js +215 -0
  56. package/dist/interpreter/SandboxManager.js.map +1 -0
  57. package/dist/interpreter/SessionManager.d.ts +101 -0
  58. package/dist/interpreter/SessionManager.d.ts.map +1 -0
  59. package/dist/interpreter/SessionManager.js +184 -0
  60. package/dist/interpreter/SessionManager.js.map +1 -0
  61. package/dist/interpreter/index.d.ts +13 -0
  62. package/dist/interpreter/index.d.ts.map +1 -0
  63. package/dist/interpreter/index.js +13 -0
  64. package/dist/interpreter/index.js.map +1 -0
  65. package/dist/interpreter/types.d.ts +311 -0
  66. package/dist/interpreter/types.d.ts.map +1 -0
  67. package/dist/interpreter/types.js +91 -0
  68. package/dist/interpreter/types.js.map +1 -0
  69. package/dist/moa/AgentOrchestrator.d.ts +53 -0
  70. package/dist/moa/AgentOrchestrator.d.ts.map +1 -0
  71. package/dist/moa/AgentOrchestrator.js +164 -0
  72. package/dist/moa/AgentOrchestrator.js.map +1 -0
  73. package/dist/moa/ConsensusCalculator.d.ts +76 -0
  74. package/dist/moa/ConsensusCalculator.d.ts.map +1 -0
  75. package/dist/moa/ConsensusCalculator.js +221 -0
  76. package/dist/moa/ConsensusCalculator.js.map +1 -0
  77. package/dist/moa/MoAEngine.d.ts +97 -0
  78. package/dist/moa/MoAEngine.d.ts.map +1 -0
  79. package/dist/moa/MoAEngine.js +303 -0
  80. package/dist/moa/MoAEngine.js.map +1 -0
  81. package/dist/moa/ResponseAggregator.d.ts +65 -0
  82. package/dist/moa/ResponseAggregator.d.ts.map +1 -0
  83. package/dist/moa/ResponseAggregator.js +274 -0
  84. package/dist/moa/ResponseAggregator.js.map +1 -0
  85. package/dist/moa/TaskAnalyzer.d.ts +30 -0
  86. package/dist/moa/TaskAnalyzer.d.ts.map +1 -0
  87. package/dist/moa/TaskAnalyzer.js +116 -0
  88. package/dist/moa/TaskAnalyzer.js.map +1 -0
  89. package/dist/moa/index.d.ts +19 -0
  90. package/dist/moa/index.d.ts.map +1 -0
  91. package/dist/moa/index.js +18 -0
  92. package/dist/moa/index.js.map +1 -0
  93. package/dist/moa/types.d.ts +261 -0
  94. package/dist/moa/types.d.ts.map +1 -0
  95. package/dist/moa/types.js +70 -0
  96. package/dist/moa/types.js.map +1 -0
  97. package/dist/research/ConvergenceDetector.d.ts +37 -0
  98. package/dist/research/ConvergenceDetector.d.ts.map +1 -0
  99. package/dist/research/ConvergenceDetector.js +62 -0
  100. package/dist/research/ConvergenceDetector.js.map +1 -0
  101. package/dist/research/DeepResearchOrchestrator.d.ts +63 -0
  102. package/dist/research/DeepResearchOrchestrator.d.ts.map +1 -0
  103. package/dist/research/DeepResearchOrchestrator.js +283 -0
  104. package/dist/research/DeepResearchOrchestrator.js.map +1 -0
  105. package/dist/research/FindingIntegrator.d.ts +42 -0
  106. package/dist/research/FindingIntegrator.d.ts.map +1 -0
  107. package/dist/research/FindingIntegrator.js +239 -0
  108. package/dist/research/FindingIntegrator.js.map +1 -0
  109. package/dist/research/GapAnalyzer.d.ts +41 -0
  110. package/dist/research/GapAnalyzer.d.ts.map +1 -0
  111. package/dist/research/GapAnalyzer.js +145 -0
  112. package/dist/research/GapAnalyzer.js.map +1 -0
  113. package/dist/research/QueryGenerator.d.ts +38 -0
  114. package/dist/research/QueryGenerator.d.ts.map +1 -0
  115. package/dist/research/QueryGenerator.js +79 -0
  116. package/dist/research/QueryGenerator.js.map +1 -0
  117. package/dist/research/index.d.ts +14 -0
  118. package/dist/research/index.d.ts.map +1 -0
  119. package/dist/research/index.js +13 -0
  120. package/dist/research/index.js.map +1 -0
  121. package/dist/research/types.d.ts +215 -0
  122. package/dist/research/types.d.ts.map +1 -0
  123. package/dist/research/types.js +18 -0
  124. package/dist/research/types.js.map +1 -0
  125. package/dist/trend/ForecastEngine.d.ts +65 -0
  126. package/dist/trend/ForecastEngine.d.ts.map +1 -0
  127. package/dist/trend/ForecastEngine.js +260 -0
  128. package/dist/trend/ForecastEngine.js.map +1 -0
  129. package/dist/trend/TimeSeriesCollector.d.ts +42 -0
  130. package/dist/trend/TimeSeriesCollector.d.ts.map +1 -0
  131. package/dist/trend/TimeSeriesCollector.js +172 -0
  132. package/dist/trend/TimeSeriesCollector.js.map +1 -0
  133. package/dist/trend/TrendAnalyzer.d.ts +72 -0
  134. package/dist/trend/TrendAnalyzer.d.ts.map +1 -0
  135. package/dist/trend/TrendAnalyzer.js +291 -0
  136. package/dist/trend/TrendAnalyzer.js.map +1 -0
  137. package/dist/trend/TrendDetector.d.ts +67 -0
  138. package/dist/trend/TrendDetector.d.ts.map +1 -0
  139. package/dist/trend/TrendDetector.js +325 -0
  140. package/dist/trend/TrendDetector.js.map +1 -0
  141. package/dist/trend/VisualizationGenerator.d.ts +75 -0
  142. package/dist/trend/VisualizationGenerator.d.ts.map +1 -0
  143. package/dist/trend/VisualizationGenerator.js +294 -0
  144. package/dist/trend/VisualizationGenerator.js.map +1 -0
  145. package/dist/trend/index.d.ts +16 -0
  146. package/dist/trend/index.d.ts.map +1 -0
  147. package/dist/trend/index.js +18 -0
  148. package/dist/trend/index.js.map +1 -0
  149. package/dist/trend/types.d.ts +279 -0
  150. package/dist/trend/types.d.ts.map +1 -0
  151. package/dist/trend/types.js +17 -0
  152. package/dist/trend/types.js.map +1 -0
  153. package/package.json +4 -2
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ExecutionEngine.d.ts","sourceRoot":"","sources":["../../src/interpreter/ExecutionEngine.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EACL,iBAAiB,EACjB,sBAAsB,EAGvB,MAAM,YAAY,CAAC;AACpB,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtE;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,kBAAkB;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,gBAAgB;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW;IACX,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC5B,YAAY;IACZ,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAClC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,qBAAa,eAAe;IACd,OAAO,CAAC,cAAc;gBAAd,cAAc,EAAE,cAAc;IAElD;;OAEG;IACG,OAAO,CACX,OAAO,EAAE,eAAe,EACxB,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,iBAAiB,EAC3B,OAAO,EAAE,gBAAgB,GACxB,OAAO,CAAC,sBAAsB,CAAC;IA8ClC;;OAEG;IACH,OAAO,CAAC,cAAc;IAkHtB;;OAEG;IACH,OAAO,CAAC,QAAQ;IAoBhB;;OAEG;IACH,OAAO,CAAC,cAAc;IAgDtB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAgC1B;;OAEG;IACH,OAAO,CAAC,aAAa;IAqBrB;;OAEG;IACH,OAAO,CAAC,GAAG;CAWZ"}
@@ -0,0 +1,273 @@
1
+ /**
2
+ * Execution Engine
3
+ * コード実行エンジン
4
+ * REQ-ANALYZE-009: コードインタープリタ機能
5
+ */
6
+ import { spawn } from 'child_process';
7
+ import { BLOCKED_PYTHON_MODULES, } from './types.js';
8
+ /**
9
+ * 実行エンジン
10
+ *
11
+ * サンドボックス内でコードを実行する。
12
+ * タイムアウト、メモリ制限などのリソース制約を適用。
13
+ *
14
+ * @example
15
+ * ```typescript
16
+ * const engine = new ExecutionEngine(sandboxManager);
17
+ *
18
+ * const result = await engine.execute(
19
+ * sandbox,
20
+ * 'print("Hello, World!")',
21
+ * 'python',
22
+ * { timeout: 30000, memoryLimit: 256, env: {} }
23
+ * );
24
+ *
25
+ * console.log(result.stdout); // "Hello, World!"
26
+ * ```
27
+ */
28
+ export class ExecutionEngine {
29
+ sandboxManager;
30
+ constructor(sandboxManager) {
31
+ this.sandboxManager = sandboxManager;
32
+ }
33
+ /**
34
+ * コードを実行
35
+ */
36
+ async execute(sandbox, code, language, options) {
37
+ const logs = [];
38
+ const startTime = Date.now();
39
+ this.log(logs, 'info', `Starting ${language} execution`);
40
+ // コードファイルを作成
41
+ const codeFileName = this.sandboxManager.getCodeFileName(language);
42
+ const wrappedCode = this.wrapCode(code, language, options.inputs);
43
+ const codeFilePath = await this.sandboxManager.writeFile(sandbox.id, codeFileName, wrappedCode);
44
+ this.log(logs, 'debug', `Code file created: ${codeFileName}`);
45
+ // 実行コマンドを取得
46
+ const [command, args] = this.sandboxManager.getExecutionCommand(language, codeFilePath);
47
+ // 実行
48
+ const result = await this.executeProcess(command, args, sandbox.workDir, options, logs);
49
+ this.log(logs, 'info', `Execution completed in ${Date.now() - startTime}ms`);
50
+ return {
51
+ ...result,
52
+ runtimeVersion: this.sandboxManager.getRuntimeVersion(language),
53
+ logs,
54
+ };
55
+ }
56
+ /**
57
+ * プロセスを実行
58
+ */
59
+ executeProcess(command, args, cwd, options, logs) {
60
+ return new Promise((resolve) => {
61
+ let stdout = '';
62
+ let stderr = '';
63
+ let timedOut = false;
64
+ const memoryExceeded = false;
65
+ let childProcess = null;
66
+ try {
67
+ childProcess = spawn(command, args, {
68
+ cwd,
69
+ env: {
70
+ PATH: globalThis.process?.env?.PATH || '/usr/bin:/bin',
71
+ ...options.env,
72
+ },
73
+ });
74
+ // stdout収集
75
+ childProcess.stdout?.on('data', (data) => {
76
+ stdout += data.toString();
77
+ // 出力サイズ制限(1MB)
78
+ if (stdout.length > 1024 * 1024) {
79
+ stdout = stdout.slice(0, 1024 * 1024) + '\n[Output truncated]';
80
+ this.log(logs, 'warn', 'Output truncated due to size limit');
81
+ }
82
+ });
83
+ // stderr収集
84
+ childProcess.stderr?.on('data', (data) => {
85
+ stderr += data.toString();
86
+ if (stderr.length > 1024 * 1024) {
87
+ stderr = stderr.slice(0, 1024 * 1024) + '\n[Error output truncated]';
88
+ }
89
+ });
90
+ // タイムアウト設定
91
+ const timeoutId = setTimeout(() => {
92
+ timedOut = true;
93
+ this.log(logs, 'error', `Execution timed out after ${options.timeout}ms`);
94
+ childProcess?.kill('SIGKILL');
95
+ }, options.timeout);
96
+ // メモリ監視(簡易版 - Node.js環境ではプロセスメモリを直接制限できないため警告のみ)
97
+ const memoryCheckInterval = setInterval(() => {
98
+ // 本格的なメモリ制限はDocker/cgroupsで実装予定
99
+ }, 1000);
100
+ // 完了時
101
+ childProcess.on('close', (exitCode) => {
102
+ clearTimeout(timeoutId);
103
+ clearInterval(memoryCheckInterval);
104
+ if (timedOut) {
105
+ resolve({
106
+ exitCode: -1,
107
+ stdout,
108
+ stderr: 'Execution timed out',
109
+ memoryUsage: 0,
110
+ });
111
+ }
112
+ else if (memoryExceeded) {
113
+ resolve({
114
+ exitCode: -1,
115
+ stdout,
116
+ stderr: 'Memory limit exceeded',
117
+ memoryUsage: options.memoryLimit,
118
+ });
119
+ }
120
+ else {
121
+ resolve({
122
+ exitCode: exitCode || 0,
123
+ stdout,
124
+ stderr,
125
+ memoryUsage: 0, // 実際の値はDocker環境で取得
126
+ });
127
+ }
128
+ });
129
+ // エラー時
130
+ childProcess.on('error', (error) => {
131
+ clearTimeout(timeoutId);
132
+ clearInterval(memoryCheckInterval);
133
+ this.log(logs, 'error', `Process error: ${error.message}`);
134
+ resolve({
135
+ exitCode: -1,
136
+ stdout: '',
137
+ stderr: error.message,
138
+ memoryUsage: 0,
139
+ });
140
+ });
141
+ }
142
+ catch (error) {
143
+ this.log(logs, 'error', `Failed to spawn process: ${error instanceof Error ? error.message : String(error)}`);
144
+ resolve({
145
+ exitCode: -1,
146
+ stdout: '',
147
+ stderr: error instanceof Error ? error.message : String(error),
148
+ memoryUsage: 0,
149
+ });
150
+ }
151
+ });
152
+ }
153
+ /**
154
+ * コードをラップ(セキュリティ制約適用)
155
+ */
156
+ wrapCode(code, language, inputs) {
157
+ if (language === 'python') {
158
+ return this.wrapPythonCode(code, inputs);
159
+ }
160
+ if (language === 'javascript' || language === 'typescript') {
161
+ return this.wrapJavaScriptCode(code, inputs);
162
+ }
163
+ if (language === 'shell') {
164
+ return this.wrapShellCode(code, inputs);
165
+ }
166
+ return code;
167
+ }
168
+ /**
169
+ * Pythonコードをラップ
170
+ */
171
+ wrapPythonCode(code, inputs) {
172
+ const blockedModulesJson = JSON.stringify([...BLOCKED_PYTHON_MODULES]);
173
+ // 入力変数の設定
174
+ const inputSetup = inputs
175
+ ? Object.entries(inputs)
176
+ .map(([k, v]) => `${k} = ${JSON.stringify(v)}`)
177
+ .join('\n')
178
+ : '';
179
+ return `
180
+ # Security restrictions
181
+ import sys
182
+
183
+ BLOCKED_MODULES = ${blockedModulesJson}
184
+
185
+ class ImportBlocker:
186
+ def find_module(self, name, path=None):
187
+ if name in BLOCKED_MODULES or name.split('.')[0] in BLOCKED_MODULES:
188
+ raise ImportError(f"Module '{name}' is blocked for security reasons")
189
+ return None
190
+
191
+ sys.meta_path.insert(0, ImportBlocker())
192
+
193
+ # Disable dangerous builtins
194
+ import builtins
195
+ _original_open = builtins.open
196
+ def _restricted_open(file, mode='r', *args, **kwargs):
197
+ # Only allow reading/writing in current directory
198
+ import os
199
+ abs_path = os.path.abspath(file)
200
+ cwd = os.getcwd()
201
+ if not abs_path.startswith(cwd):
202
+ raise PermissionError(f"Access to '{file}' is not allowed")
203
+ return _original_open(file, mode, *args, **kwargs)
204
+ builtins.open = _restricted_open
205
+
206
+ # Input variables
207
+ ${inputSetup}
208
+
209
+ # User code
210
+ ${code}
211
+ `;
212
+ }
213
+ /**
214
+ * JavaScriptコードをラップ
215
+ */
216
+ wrapJavaScriptCode(code, inputs) {
217
+ const inputSetup = inputs
218
+ ? Object.entries(inputs)
219
+ .map(([k, v]) => `const ${k} = ${JSON.stringify(v)};`)
220
+ .join('\n')
221
+ : '';
222
+ return `
223
+ // Security: Override dangerous globals
224
+ const _originalRequire = typeof require !== 'undefined' ? require : null;
225
+ const blockedModules = ['fs', 'child_process', 'net', 'dgram', 'cluster', 'vm', 'worker_threads'];
226
+
227
+ if (_originalRequire) {
228
+ global.require = function(module) {
229
+ if (blockedModules.includes(module)) {
230
+ throw new Error(\`Module '\${module}' is blocked for security reasons\`);
231
+ }
232
+ return _originalRequire(module);
233
+ };
234
+ }
235
+
236
+ // Input variables
237
+ ${inputSetup}
238
+
239
+ // User code
240
+ ${code}
241
+ `;
242
+ }
243
+ /**
244
+ * Shellコードをラップ
245
+ */
246
+ wrapShellCode(code, inputs) {
247
+ const inputSetup = inputs
248
+ ? Object.entries(inputs)
249
+ .map(([k, v]) => `export ${k}=${JSON.stringify(String(v))}`)
250
+ .join('\n')
251
+ : '';
252
+ return `#!/bin/bash
253
+ set -e
254
+
255
+ # Input variables
256
+ ${inputSetup}
257
+
258
+ # User code
259
+ ${code}
260
+ `;
261
+ }
262
+ /**
263
+ * ログを追加
264
+ */
265
+ log(logs, level, message) {
266
+ logs.push({
267
+ timestamp: new Date(),
268
+ level,
269
+ message,
270
+ });
271
+ }
272
+ }
273
+ //# sourceMappingURL=ExecutionEngine.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ExecutionEngine.js","sourceRoot":"","sources":["../../src/interpreter/ExecutionEngine.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,72 @@
1
+ /**
2
+ * Result Formatter
3
+ * 実行結果のフォーマッタ
4
+ * REQ-ANALYZE-009: コードインタープリタ機能
5
+ */
6
+ import { ExecutionResult, ErrorType, SupportedLanguage, SandboxExecutionResult } from './types.js';
7
+ /**
8
+ * フォーマットオプション
9
+ */
10
+ export interface FormatOptions {
11
+ /** 言語 */
12
+ language: SupportedLanguage;
13
+ /** 開始時刻 */
14
+ startTime: number;
15
+ /** インストールパッケージ */
16
+ packages?: string[];
17
+ /** セキュリティ設定 */
18
+ securityConfig: {
19
+ allowNetwork: boolean;
20
+ allowedHosts: string[];
21
+ timeout: number;
22
+ memoryLimit: number;
23
+ };
24
+ }
25
+ /**
26
+ * 結果フォーマッタ
27
+ *
28
+ * 実行結果を整形し、出力ファイルや画像を抽出する。
29
+ */
30
+ export declare class ResultFormatter {
31
+ /**
32
+ * 実行結果をフォーマット
33
+ */
34
+ format(execResult: SandboxExecutionResult, outputFiles: Array<{
35
+ name: string;
36
+ content: Buffer;
37
+ size: number;
38
+ }>, options: FormatOptions): ExecutionResult;
39
+ /**
40
+ * エラー結果を作成
41
+ */
42
+ createErrorResult(errorType: ErrorType, message: string, options: FormatOptions): ExecutionResult;
43
+ /**
44
+ * 出力ファイルをフォーマット
45
+ */
46
+ private formatOutputFiles;
47
+ /**
48
+ * 画像を抽出
49
+ */
50
+ private extractImages;
51
+ /**
52
+ * 画像タイプを取得
53
+ */
54
+ private getImageType;
55
+ /**
56
+ * MIMEタイプを取得
57
+ */
58
+ private getMimeType;
59
+ /**
60
+ * エラータイプを分類
61
+ */
62
+ private classifyError;
63
+ /**
64
+ * 行情報を抽出
65
+ */
66
+ private extractLineInfo;
67
+ /**
68
+ * セキュリティ制約を取得
69
+ */
70
+ private getSecurityConstraints;
71
+ }
72
+ //# sourceMappingURL=ResultFormatter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ResultFormatter.d.ts","sourceRoot":"","sources":["../../src/interpreter/ResultFormatter.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EACL,eAAe,EAGf,SAAS,EACT,iBAAiB,EAEjB,sBAAsB,EAEvB,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,SAAS;IACT,QAAQ,EAAE,iBAAiB,CAAC;IAC5B,WAAW;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,kBAAkB;IAClB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,eAAe;IACf,cAAc,EAAE;QACd,YAAY,EAAE,OAAO,CAAC;QACtB,YAAY,EAAE,MAAM,EAAE,CAAC;QACvB,OAAO,EAAE,MAAM,CAAC;QAChB,WAAW,EAAE,MAAM,CAAC;KACrB,CAAC;CACH;AAED;;;;GAIG;AACH,qBAAa,eAAe;IAC1B;;OAEG;IACH,MAAM,CACJ,UAAU,EAAE,sBAAsB,EAClC,WAAW,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,EACnE,OAAO,EAAE,aAAa,GACrB,eAAe;IAmClB;;OAEG;IACH,iBAAiB,CACf,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,aAAa,GACrB,eAAe;IAyBlB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAWzB;;OAEG;IACH,OAAO,CAAC,aAAa;IASrB;;OAEG;IACH,OAAO,CAAC,YAAY;IAOpB;;OAEG;IACH,OAAO,CAAC,WAAW;IAqBnB;;OAEG;IACH,OAAO,CAAC,aAAa;IAuBrB;;OAEG;IACH,OAAO,CAAC,eAAe;IAqBvB;;OAEG;IACH,OAAO,CAAC,sBAAsB;CAe/B"}
@@ -0,0 +1,187 @@
1
+ /**
2
+ * Result Formatter
3
+ * 実行結果のフォーマッタ
4
+ * REQ-ANALYZE-009: コードインタープリタ機能
5
+ */
6
+ import * as path from 'path';
7
+ import { BLOCKED_PYTHON_MODULES, } from './types.js';
8
+ /**
9
+ * 結果フォーマッタ
10
+ *
11
+ * 実行結果を整形し、出力ファイルや画像を抽出する。
12
+ */
13
+ export class ResultFormatter {
14
+ /**
15
+ * 実行結果をフォーマット
16
+ */
17
+ format(execResult, outputFiles, options) {
18
+ const now = Date.now();
19
+ const formattedFiles = this.formatOutputFiles(outputFiles);
20
+ const images = this.extractImages(formattedFiles);
21
+ return {
22
+ success: execResult.exitCode === 0,
23
+ stdout: execResult.stdout,
24
+ stderr: execResult.stderr,
25
+ returnValue: execResult.returnValue,
26
+ outputFiles: formattedFiles,
27
+ images,
28
+ executionTime: now - options.startTime,
29
+ memoryUsage: execResult.memoryUsage || 0,
30
+ logs: execResult.logs || [],
31
+ error: execResult.exitCode !== 0
32
+ ? {
33
+ type: this.classifyError(execResult.stderr),
34
+ message: execResult.stderr,
35
+ stack: execResult.stderr,
36
+ ...this.extractLineInfo(execResult.stderr),
37
+ }
38
+ : undefined,
39
+ metadata: {
40
+ startedAt: new Date(options.startTime),
41
+ completedAt: new Date(now),
42
+ language: options.language,
43
+ runtimeVersion: execResult.runtimeVersion || 'unknown',
44
+ installedPackages: options.packages || [],
45
+ securityConstraints: this.getSecurityConstraints(options.securityConfig),
46
+ },
47
+ };
48
+ }
49
+ /**
50
+ * エラー結果を作成
51
+ */
52
+ createErrorResult(errorType, message, options) {
53
+ const now = Date.now();
54
+ return {
55
+ success: false,
56
+ stdout: '',
57
+ stderr: message,
58
+ executionTime: now - options.startTime,
59
+ memoryUsage: 0,
60
+ logs: [],
61
+ error: {
62
+ type: errorType,
63
+ message,
64
+ },
65
+ metadata: {
66
+ startedAt: new Date(options.startTime),
67
+ completedAt: new Date(now),
68
+ language: options.language,
69
+ runtimeVersion: 'N/A',
70
+ installedPackages: [],
71
+ securityConstraints: this.getSecurityConstraints(options.securityConfig),
72
+ },
73
+ };
74
+ }
75
+ /**
76
+ * 出力ファイルをフォーマット
77
+ */
78
+ formatOutputFiles(files) {
79
+ return files.map((file) => ({
80
+ name: file.name,
81
+ content: file.content,
82
+ mimeType: this.getMimeType(file.name),
83
+ size: file.size,
84
+ }));
85
+ }
86
+ /**
87
+ * 画像を抽出
88
+ */
89
+ extractImages(files) {
90
+ return files
91
+ .filter((f) => f.mimeType.startsWith('image/'))
92
+ .map((f) => ({
93
+ type: this.getImageType(f.name),
94
+ data: f.content.toString('base64'),
95
+ }));
96
+ }
97
+ /**
98
+ * 画像タイプを取得
99
+ */
100
+ getImageType(filename) {
101
+ const ext = path.extname(filename).toLowerCase();
102
+ if (ext === '.png')
103
+ return 'png';
104
+ if (ext === '.svg')
105
+ return 'svg';
106
+ return 'jpeg';
107
+ }
108
+ /**
109
+ * MIMEタイプを取得
110
+ */
111
+ getMimeType(filename) {
112
+ const ext = path.extname(filename).toLowerCase();
113
+ const mimeTypes = {
114
+ '.png': 'image/png',
115
+ '.jpg': 'image/jpeg',
116
+ '.jpeg': 'image/jpeg',
117
+ '.gif': 'image/gif',
118
+ '.svg': 'image/svg+xml',
119
+ '.webp': 'image/webp',
120
+ '.pdf': 'application/pdf',
121
+ '.csv': 'text/csv',
122
+ '.json': 'application/json',
123
+ '.txt': 'text/plain',
124
+ '.html': 'text/html',
125
+ '.xml': 'application/xml',
126
+ '.xlsx': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
127
+ '.docx': 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
128
+ };
129
+ return mimeTypes[ext] || 'application/octet-stream';
130
+ }
131
+ /**
132
+ * エラータイプを分類
133
+ */
134
+ classifyError(stderr) {
135
+ const errorPatterns = [
136
+ { pattern: /SyntaxError/i, type: 'syntax_error' },
137
+ { pattern: /IndentationError/i, type: 'syntax_error' },
138
+ { pattern: /ImportError/i, type: 'import_error' },
139
+ { pattern: /ModuleNotFoundError/i, type: 'import_error' },
140
+ { pattern: /PermissionError/i, type: 'permission_error' },
141
+ { pattern: /blocked for security/i, type: 'permission_error' },
142
+ { pattern: /MemoryError/i, type: 'memory_error' },
143
+ { pattern: /memory limit/i, type: 'memory_error' },
144
+ { pattern: /timed out/i, type: 'timeout_error' },
145
+ { pattern: /TimeoutError/i, type: 'timeout_error' },
146
+ ];
147
+ for (const { pattern, type } of errorPatterns) {
148
+ if (pattern.test(stderr)) {
149
+ return type;
150
+ }
151
+ }
152
+ return 'runtime_error';
153
+ }
154
+ /**
155
+ * 行情報を抽出
156
+ */
157
+ extractLineInfo(stderr) {
158
+ // Python: File "script.py", line 5
159
+ const pythonMatch = stderr.match(/line (\d+)/i);
160
+ if (pythonMatch?.[1]) {
161
+ return { line: parseInt(pythonMatch[1], 10) };
162
+ }
163
+ // JavaScript: at script.js:5:10
164
+ const jsMatch = stderr.match(/:(\d+):(\d+)/);
165
+ if (jsMatch?.[1] && jsMatch?.[2]) {
166
+ return {
167
+ line: parseInt(jsMatch[1], 10),
168
+ column: parseInt(jsMatch[2], 10),
169
+ };
170
+ }
171
+ return {};
172
+ }
173
+ /**
174
+ * セキュリティ制約を取得
175
+ */
176
+ getSecurityConstraints(config) {
177
+ return {
178
+ fileSystemAccess: 'sandbox',
179
+ networkAccess: config.allowNetwork,
180
+ allowedHosts: config.allowedHosts,
181
+ timeout: config.timeout,
182
+ memoryLimit: config.memoryLimit,
183
+ blockedModules: [...BLOCKED_PYTHON_MODULES],
184
+ };
185
+ }
186
+ }
187
+ //# sourceMappingURL=ResultFormatter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ResultFormatter.js","sourceRoot":"","sources":["../../src/interpreter/ResultFormatter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,111 @@
1
+ /**
2
+ * Sandbox Manager
3
+ * サンドボックス環境の管理
4
+ * REQ-ANALYZE-009: コードインタープリタ機能
5
+ */
6
+ import { SandboxConfig, SupportedLanguage } from './types.js';
7
+ /**
8
+ * サンドボックスインスタンス
9
+ */
10
+ export interface SandboxInstance {
11
+ /** サンドボックスID */
12
+ id: string;
13
+ /** 作業ディレクトリ */
14
+ workDir: string;
15
+ /** 設定 */
16
+ config: SandboxConfig;
17
+ /** 作成日時 */
18
+ createdAt: Date;
19
+ /** アクティブか */
20
+ active: boolean;
21
+ }
22
+ /**
23
+ * サンドボックスマネージャー
24
+ *
25
+ * コード実行用のサンドボックス環境を管理する。
26
+ * 現在はファイルシステムベースの簡易サンドボックスを提供。
27
+ * 将来的にはDocker/gVisorによる本格的な分離をサポート予定。
28
+ *
29
+ * @example
30
+ * ```typescript
31
+ * const manager = new SandboxManager();
32
+ *
33
+ * // サンドボックス作成
34
+ * const sandbox = await manager.create({
35
+ * workDir: '/tmp/sandbox',
36
+ * timeout: 30000,
37
+ * memoryLimit: 256,
38
+ * allowNetwork: false,
39
+ * allowedHosts: [],
40
+ * env: {},
41
+ * });
42
+ *
43
+ * // ファイルを配置
44
+ * await manager.writeFile(sandbox.id, 'script.py', 'print("hello")');
45
+ *
46
+ * // クリーンアップ
47
+ * await manager.destroy(sandbox.id);
48
+ * ```
49
+ */
50
+ export declare class SandboxManager {
51
+ private sandboxes;
52
+ private baseDir;
53
+ constructor(baseDir?: string);
54
+ /**
55
+ * サンドボックスを作成
56
+ */
57
+ create(config: SandboxConfig): Promise<SandboxInstance>;
58
+ /**
59
+ * サンドボックスを取得
60
+ */
61
+ get(id: string): SandboxInstance | undefined;
62
+ /**
63
+ * サンドボックスを破棄
64
+ */
65
+ destroy(id: string): Promise<void>;
66
+ /**
67
+ * すべてのサンドボックスを破棄
68
+ */
69
+ destroyAll(): Promise<void>;
70
+ /**
71
+ * ファイルを書き込み
72
+ */
73
+ writeFile(sandboxId: string, filename: string, content: string | Buffer): Promise<string>;
74
+ /**
75
+ * ファイルを読み込み
76
+ */
77
+ readFile(sandboxId: string, filename: string): Promise<Buffer>;
78
+ /**
79
+ * ディレクトリ内のファイルを一覧
80
+ */
81
+ listFiles(sandboxId: string): Promise<string[]>;
82
+ /**
83
+ * ファイルを収集(出力ファイル取得用)
84
+ */
85
+ collectFiles(sandboxId: string, excludePatterns?: RegExp[]): Promise<Array<{
86
+ name: string;
87
+ content: Buffer;
88
+ size: number;
89
+ }>>;
90
+ /**
91
+ * コードファイル名を取得
92
+ */
93
+ getCodeFileName(language: SupportedLanguage): string;
94
+ /**
95
+ * 実行コマンドを取得
96
+ */
97
+ getExecutionCommand(language: SupportedLanguage, codeFile: string): [string, string[]];
98
+ /**
99
+ * ランタイムバージョンを取得
100
+ */
101
+ getRuntimeVersion(language: SupportedLanguage): string;
102
+ /**
103
+ * アクティブなサンドボックス数
104
+ */
105
+ get activeCount(): number;
106
+ /**
107
+ * IDを生成
108
+ */
109
+ private generateId;
110
+ }
111
+ //# sourceMappingURL=SandboxManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SandboxManager.d.ts","sourceRoot":"","sources":["../../src/interpreter/SandboxManager.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,OAAO,EACL,aAAa,EACb,iBAAiB,EAGlB,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,gBAAgB;IAChB,EAAE,EAAE,MAAM,CAAC;IACX,eAAe;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS;IACT,MAAM,EAAE,aAAa,CAAC;IACtB,WAAW;IACX,SAAS,EAAE,IAAI,CAAC;IAChB,aAAa;IACb,MAAM,EAAE,OAAO,CAAC;CACjB;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,SAAS,CAA2C;IAC5D,OAAO,CAAC,OAAO,CAAS;gBAEZ,OAAO,CAAC,EAAE,MAAM;IAI5B;;OAEG;IACG,MAAM,CAAC,MAAM,EAAE,aAAa,GAAG,OAAO,CAAC,eAAe,CAAC;IAmB7D;;OAEG;IACH,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,eAAe,GAAG,SAAS;IAI5C;;OAEG;IACG,OAAO,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBxC;;OAEG;IACG,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAKjC;;OAEG;IACG,SAAS,CACb,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,GAAG,MAAM,GACvB,OAAO,CAAC,MAAM,CAAC;IAiBlB;;OAEG;IACG,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAepE;;OAEG;IACG,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAiBrD;;OAEG;IACG,YAAY,CAChB,SAAS,EAAE,MAAM,EACjB,eAAe,GAAE,MAAM,EAAkB,GACxC,OAAO,CACR,KAAK,CAAC;QACJ,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,IAAI,EAAE,MAAM,CAAC;KACd,CAAC,CACH;IAiCD;;OAEG;IACH,eAAe,CAAC,QAAQ,EAAE,iBAAiB,GAAG,MAAM;IAUpD;;OAEG;IACH,mBAAmB,CACjB,QAAQ,EAAE,iBAAiB,EAC3B,QAAQ,EAAE,MAAM,GACf,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;IAUrB;;OAEG;IACH,iBAAiB,CAAC,QAAQ,EAAE,iBAAiB,GAAG,MAAM;IAUtD;;OAEG;IACH,IAAI,WAAW,IAAI,MAAM,CAExB;IAED;;OAEG;IACH,OAAO,CAAC,UAAU;CAGnB"}