opc-agent 4.2.13 → 5.0.0-alpha.1

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 (188) hide show
  1. package/.opc/memory.db +0 -0
  2. package/TASK.md +49 -0
  3. package/data/brain.db/deepbrain.sqlite +0 -0
  4. package/dist/channels/api.d.ts +14 -0
  5. package/dist/channels/api.d.ts.map +1 -0
  6. package/dist/channels/api.js +58 -0
  7. package/dist/channels/api.js.map +1 -0
  8. package/dist/cli.js +144 -52
  9. package/dist/cli.js.map +1 -1
  10. package/dist/core/agent-loop.d.ts +3 -0
  11. package/dist/core/agent-loop.d.ts.map +1 -0
  12. package/dist/core/agent-loop.js +51 -0
  13. package/dist/core/agent-loop.js.map +1 -0
  14. package/dist/core/context-assembler.d.ts +12 -0
  15. package/dist/core/context-assembler.d.ts.map +1 -0
  16. package/dist/core/context-assembler.js +81 -0
  17. package/dist/core/context-assembler.js.map +1 -0
  18. package/dist/core/guardrails.d.ts +16 -0
  19. package/dist/core/guardrails.d.ts.map +1 -0
  20. package/dist/core/guardrails.js +62 -0
  21. package/dist/core/guardrails.js.map +1 -0
  22. package/dist/core/index.d.ts +1 -0
  23. package/dist/core/index.d.ts.map +1 -0
  24. package/dist/core/index.js +3 -0
  25. package/dist/core/index.js.map +1 -0
  26. package/dist/core/iteration-budget.d.ts +12 -0
  27. package/dist/core/iteration-budget.d.ts.map +1 -0
  28. package/dist/core/iteration-budget.js +26 -0
  29. package/dist/core/iteration-budget.js.map +1 -0
  30. package/dist/core/types.d.ts +412 -0
  31. package/dist/core/types.d.ts.map +1 -1
  32. package/dist/deepbrain/embedding.d.ts +7 -0
  33. package/dist/deepbrain/embedding.d.ts.map +1 -0
  34. package/dist/deepbrain/embedding.js +108 -0
  35. package/dist/deepbrain/embedding.js.map +1 -0
  36. package/dist/deepbrain/index.d.ts +8 -0
  37. package/dist/deepbrain/index.d.ts.map +1 -0
  38. package/dist/deepbrain/index.js +19 -0
  39. package/dist/deepbrain/index.js.map +1 -0
  40. package/dist/deepbrain/migrate.d.ts +2 -0
  41. package/dist/deepbrain/migrate.d.ts.map +1 -0
  42. package/dist/deepbrain/migrate.js +139 -0
  43. package/dist/deepbrain/migrate.js.map +1 -0
  44. package/dist/deepbrain/provider.d.ts +13 -0
  45. package/dist/deepbrain/provider.d.ts.map +1 -0
  46. package/dist/deepbrain/provider.js +85 -0
  47. package/dist/deepbrain/provider.js.map +1 -0
  48. package/dist/deepbrain/recall.d.ts +9 -0
  49. package/dist/deepbrain/recall.d.ts.map +1 -0
  50. package/dist/deepbrain/recall.js +48 -0
  51. package/dist/deepbrain/recall.js.map +1 -0
  52. package/dist/deepbrain/store.d.ts +36 -0
  53. package/dist/deepbrain/store.d.ts.map +1 -0
  54. package/dist/deepbrain/store.js +342 -0
  55. package/dist/deepbrain/store.js.map +1 -0
  56. package/dist/deepbrain/workspace-files.d.ts +5 -0
  57. package/dist/deepbrain/workspace-files.d.ts.map +1 -0
  58. package/dist/deepbrain/workspace-files.js +159 -0
  59. package/dist/deepbrain/workspace-files.js.map +1 -0
  60. package/dist/evolution/index.d.ts +1 -0
  61. package/dist/evolution/index.d.ts.map +1 -0
  62. package/dist/evolution/index.js +3 -0
  63. package/dist/evolution/index.js.map +1 -0
  64. package/dist/evolution/l1-experience.d.ts +5 -0
  65. package/dist/evolution/l1-experience.d.ts.map +1 -0
  66. package/dist/evolution/l1-experience.js +117 -0
  67. package/dist/evolution/l1-experience.js.map +1 -0
  68. package/dist/evolution/l2-consolidation.d.ts +4 -0
  69. package/dist/evolution/l2-consolidation.d.ts.map +1 -0
  70. package/dist/evolution/l2-consolidation.js +106 -0
  71. package/dist/evolution/l2-consolidation.js.map +1 -0
  72. package/dist/evolution/l2-memskill.d.ts +12 -0
  73. package/dist/evolution/l2-memskill.d.ts.map +1 -0
  74. package/dist/evolution/l2-memskill.js +57 -0
  75. package/dist/evolution/l2-memskill.js.map +1 -0
  76. package/dist/evolution/l3-skill-discover.d.ts +4 -0
  77. package/dist/evolution/l3-skill-discover.d.ts.map +1 -0
  78. package/dist/evolution/l3-skill-discover.js +139 -0
  79. package/dist/evolution/l3-skill-discover.js.map +1 -0
  80. package/dist/evolution/l3-skill-verify.d.ts +12 -0
  81. package/dist/evolution/l3-skill-verify.d.ts.map +1 -0
  82. package/dist/evolution/l3-skill-verify.js +122 -0
  83. package/dist/evolution/l3-skill-verify.js.map +1 -0
  84. package/dist/evolution/l4-desensitize.d.ts +7 -0
  85. package/dist/evolution/l4-desensitize.d.ts.map +1 -0
  86. package/dist/evolution/l4-desensitize.js +30 -0
  87. package/dist/evolution/l4-desensitize.js.map +1 -0
  88. package/dist/evolution/l4-group-evolve.d.ts +8 -0
  89. package/dist/evolution/l4-group-evolve.d.ts.map +1 -0
  90. package/dist/evolution/l4-group-evolve.js +15 -0
  91. package/dist/evolution/l4-group-evolve.js.map +1 -0
  92. package/dist/evolution/maturity-scorer.d.ts +11 -0
  93. package/dist/evolution/maturity-scorer.d.ts.map +1 -0
  94. package/dist/evolution/maturity-scorer.js +21 -0
  95. package/dist/evolution/maturity-scorer.js.map +1 -0
  96. package/dist/index.d.ts +7 -1
  97. package/dist/index.d.ts.map +1 -1
  98. package/dist/index.js +33 -5
  99. package/dist/index.js.map +1 -1
  100. package/dist/providers/agentkits.d.ts +20 -0
  101. package/dist/providers/agentkits.d.ts.map +1 -0
  102. package/dist/providers/agentkits.js +173 -0
  103. package/dist/providers/agentkits.js.map +1 -0
  104. package/dist/providers/model-provider.d.ts +16 -0
  105. package/dist/providers/model-provider.d.ts.map +1 -0
  106. package/dist/providers/model-provider.js +13 -0
  107. package/dist/providers/model-provider.js.map +1 -0
  108. package/dist/providers/model-recommender.d.ts +15 -0
  109. package/dist/providers/model-recommender.d.ts.map +1 -0
  110. package/dist/providers/model-recommender.js +71 -0
  111. package/dist/providers/model-recommender.js.map +1 -0
  112. package/dist/providers/ollama.d.ts +22 -0
  113. package/dist/providers/ollama.d.ts.map +1 -0
  114. package/dist/providers/ollama.js +176 -0
  115. package/dist/providers/ollama.js.map +1 -0
  116. package/dist/providers/openai-compat.d.ts +23 -0
  117. package/dist/providers/openai-compat.d.ts.map +1 -0
  118. package/dist/providers/openai-compat.js +184 -0
  119. package/dist/providers/openai-compat.js.map +1 -0
  120. package/dist/providers/router.d.ts +11 -0
  121. package/dist/providers/router.d.ts.map +1 -0
  122. package/dist/providers/router.js +48 -0
  123. package/dist/providers/router.js.map +1 -0
  124. package/dist/scheduler/cron.d.ts +19 -0
  125. package/dist/scheduler/cron.d.ts.map +1 -0
  126. package/dist/scheduler/cron.js +64 -0
  127. package/dist/scheduler/cron.js.map +1 -0
  128. package/dist/schema/oad.d.ts +72 -72
  129. package/dist/skills/loader.d.ts +16 -0
  130. package/dist/skills/loader.d.ts.map +1 -0
  131. package/dist/skills/loader.js +114 -0
  132. package/dist/skills/loader.js.map +1 -0
  133. package/dist/skills/matcher.d.ts +18 -0
  134. package/dist/skills/matcher.d.ts.map +1 -0
  135. package/dist/skills/matcher.js +70 -0
  136. package/dist/skills/matcher.js.map +1 -0
  137. package/dist/studio/agent-pool.d.ts +17 -0
  138. package/dist/studio/agent-pool.d.ts.map +1 -0
  139. package/dist/studio/agent-pool.js +35 -0
  140. package/dist/studio/agent-pool.js.map +1 -0
  141. package/dist/studio/assistant-tools.d.ts +4 -0
  142. package/dist/studio/assistant-tools.d.ts.map +1 -0
  143. package/dist/studio/assistant-tools.js +36 -0
  144. package/dist/studio/assistant-tools.js.map +1 -0
  145. package/dist/studio/index.d.ts +1 -0
  146. package/dist/studio/index.d.ts.map +1 -0
  147. package/dist/studio/index.js +3 -0
  148. package/dist/studio/index.js.map +1 -0
  149. package/dist/studio/server.d.ts.map +1 -1
  150. package/dist/studio/server.js +13 -18
  151. package/dist/studio/server.js.map +1 -1
  152. package/dist/templates/index.d.ts +1 -0
  153. package/dist/templates/index.d.ts.map +1 -0
  154. package/dist/templates/index.js +3 -0
  155. package/dist/templates/index.js.map +1 -0
  156. package/dist/templates/roles/index.d.ts +4 -0
  157. package/dist/templates/roles/index.d.ts.map +1 -0
  158. package/dist/templates/roles/index.js +46 -0
  159. package/dist/templates/roles/index.js.map +1 -0
  160. package/dist/templates/template-provider.d.ts +16 -0
  161. package/dist/templates/template-provider.d.ts.map +1 -0
  162. package/dist/templates/template-provider.js +60 -0
  163. package/dist/templates/template-provider.js.map +1 -0
  164. package/dist/tools/builtin/definitions.d.ts +7 -0
  165. package/dist/tools/builtin/definitions.d.ts.map +1 -0
  166. package/dist/tools/builtin/definitions.js +60 -0
  167. package/dist/tools/builtin/definitions.js.map +1 -0
  168. package/dist/tools/execute-code.d.ts +20 -0
  169. package/dist/tools/execute-code.d.ts.map +1 -0
  170. package/dist/tools/execute-code.js +92 -0
  171. package/dist/tools/execute-code.js.map +1 -0
  172. package/dist/tools/hooks.d.ts +47 -0
  173. package/dist/tools/hooks.d.ts.map +1 -0
  174. package/dist/tools/hooks.js +69 -0
  175. package/dist/tools/hooks.js.map +1 -0
  176. package/dist/tools/index.d.ts +9 -0
  177. package/dist/tools/index.d.ts.map +1 -0
  178. package/dist/tools/index.js +16 -0
  179. package/dist/tools/index.js.map +1 -0
  180. package/dist/tools/permission.d.ts +20 -0
  181. package/dist/tools/permission.d.ts.map +1 -0
  182. package/dist/tools/permission.js +35 -0
  183. package/dist/tools/permission.js.map +1 -0
  184. package/dist/tools/registry.d.ts +25 -0
  185. package/dist/tools/registry.d.ts.map +1 -0
  186. package/dist/tools/registry.js +42 -0
  187. package/dist/tools/registry.js.map +1 -0
  188. package/package.json +1 -1
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BUILTIN_DEFINITIONS = exports.shellCommandTool = exports.webSearchTool = exports.writeFileTool = exports.readFileTool = void 0;
4
+ exports.readFileTool = {
5
+ name: 'read_file',
6
+ description: 'Read the contents of a file at a given path',
7
+ parameters: {
8
+ type: 'object',
9
+ properties: {
10
+ path: { type: 'string', description: 'Relative or absolute path to the file' },
11
+ encoding: { type: 'string', enum: ['utf-8', 'base64'], default: 'utf-8' },
12
+ },
13
+ required: ['path'],
14
+ },
15
+ };
16
+ exports.writeFileTool = {
17
+ name: 'write_file',
18
+ description: 'Write or overwrite content to a file at a given path',
19
+ parameters: {
20
+ type: 'object',
21
+ properties: {
22
+ path: { type: 'string', description: 'Relative or absolute path to the file' },
23
+ content: { type: 'string', description: 'Content to write' },
24
+ encoding: { type: 'string', enum: ['utf-8', 'base64'], default: 'utf-8' },
25
+ },
26
+ required: ['path', 'content'],
27
+ },
28
+ };
29
+ exports.webSearchTool = {
30
+ name: 'web_search',
31
+ description: 'Search the web and return a list of results with titles, URLs, and snippets',
32
+ parameters: {
33
+ type: 'object',
34
+ properties: {
35
+ query: { type: 'string', description: 'The search query' },
36
+ numResults: { type: 'number', description: 'Max results to return (default 5)', default: 5 },
37
+ },
38
+ required: ['query'],
39
+ },
40
+ };
41
+ exports.shellCommandTool = {
42
+ name: 'shell_command',
43
+ description: 'Run a shell command and return stdout/stderr (requires explicit permission)',
44
+ parameters: {
45
+ type: 'object',
46
+ properties: {
47
+ command: { type: 'string', description: 'Shell command to execute' },
48
+ cwd: { type: 'string', description: 'Working directory for the command' },
49
+ timeoutMs: { type: 'number', description: 'Timeout in milliseconds (default 30000)', default: 30000 },
50
+ },
51
+ required: ['command'],
52
+ },
53
+ };
54
+ exports.BUILTIN_DEFINITIONS = [
55
+ exports.readFileTool,
56
+ exports.writeFileTool,
57
+ exports.webSearchTool,
58
+ exports.shellCommandTool,
59
+ ];
60
+ //# sourceMappingURL=definitions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"definitions.js","sourceRoot":"","sources":["../../../src/tools/builtin/definitions.ts"],"names":[],"mappings":";;;AAEa,QAAA,YAAY,GAAmB;IAC1C,IAAI,EAAE,WAAW;IACjB,WAAW,EAAE,6CAA6C;IAC1D,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,uCAAuC,EAAE;YAC9E,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE;SAC1E;QACD,QAAQ,EAAE,CAAC,MAAM,CAAC;KACnB;CACF,CAAC;AAEW,QAAA,aAAa,GAAmB;IAC3C,IAAI,EAAE,YAAY;IAClB,WAAW,EAAE,sDAAsD;IACnE,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,uCAAuC,EAAE;YAC9E,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,kBAAkB,EAAE;YAC5D,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE;SAC1E;QACD,QAAQ,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC;KAC9B;CACF,CAAC;AAEW,QAAA,aAAa,GAAmB;IAC3C,IAAI,EAAE,YAAY;IAClB,WAAW,EAAE,6EAA6E;IAC1F,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,kBAAkB,EAAE;YAC1D,UAAU,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,mCAAmC,EAAE,OAAO,EAAE,CAAC,EAAE;SAC7F;QACD,QAAQ,EAAE,CAAC,OAAO,CAAC;KACpB;CACF,CAAC;AAEW,QAAA,gBAAgB,GAAmB;IAC9C,IAAI,EAAE,eAAe;IACrB,WAAW,EAAE,6EAA6E;IAC1F,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,0BAA0B,EAAE;YACpE,GAAG,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,mCAAmC,EAAE;YACzE,SAAS,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,yCAAyC,EAAE,OAAO,EAAE,KAAK,EAAE;SACtG;QACD,QAAQ,EAAE,CAAC,SAAS,CAAC;KACtB;CACF,CAAC;AAEW,QAAA,mBAAmB,GAAqB;IACnD,oBAAY;IACZ,qBAAa;IACb,qBAAa;IACb,wBAAgB;CACjB,CAAC"}
@@ -0,0 +1,20 @@
1
+ export interface CodeExecutionRequest {
2
+ code: string;
3
+ language: 'javascript' | 'typescript' | 'python' | 'bash';
4
+ timeoutMs?: number;
5
+ env?: Record<string, string>;
6
+ }
7
+ export interface CodeExecutionResult {
8
+ stdout: string;
9
+ stderr: string;
10
+ exitCode: number;
11
+ timedOut: boolean;
12
+ elapsedMs: number;
13
+ }
14
+ export declare function executeCode(code: string, lang: 'js' | 'ts' | 'python' | 'shell', timeout?: number): Promise<{
15
+ stdout: string;
16
+ stderr: string;
17
+ exitCode: number;
18
+ }>;
19
+ export declare function executeCodeRequest(req: CodeExecutionRequest): Promise<CodeExecutionResult>;
20
+ //# sourceMappingURL=execute-code.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"execute-code.d.ts","sourceRoot":"","sources":["../../src/tools/execute-code.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,YAAY,GAAG,YAAY,GAAG,QAAQ,GAAG,MAAM,CAAC;IAC1D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC9B;AAED,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAGD,wBAAsB,WAAW,CAC/B,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,QAAQ,GAAG,OAAO,EACtC,OAAO,SAAS,GACf,OAAO,CAAC;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC,CAG/D;AAGD,wBAAsB,kBAAkB,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAGhG"}
@@ -0,0 +1,92 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.executeCode = executeCode;
37
+ exports.executeCodeRequest = executeCodeRequest;
38
+ // v2 execute-code tool — runs code snippets in a sandboxed subprocess
39
+ const child_process_1 = require("child_process");
40
+ const os = __importStar(require("os"));
41
+ // Simple API: executeCode(code, lang, timeout)
42
+ async function executeCode(code, lang, timeout = 30_000) {
43
+ const result = await runSubprocess(buildArgs(lang, code), {}, timeout);
44
+ return { stdout: result.stdout, stderr: result.stderr, exitCode: result.exitCode };
45
+ }
46
+ // Full API: executeCodeRequest(req) — supports env vars, timedOut flag
47
+ async function executeCodeRequest(req) {
48
+ const lang = mapLanguage(req.language);
49
+ return runSubprocess(buildArgs(lang, req.code), req.env ?? {}, req.timeoutMs ?? 10_000);
50
+ }
51
+ function mapLanguage(lang) {
52
+ switch (lang) {
53
+ case 'javascript': return 'js';
54
+ case 'typescript': return 'ts';
55
+ case 'python': return 'python';
56
+ case 'bash': return 'shell';
57
+ }
58
+ }
59
+ function buildArgs(lang, code) {
60
+ switch (lang) {
61
+ case 'js': return ['node', '-e', code];
62
+ case 'ts': return ['npx', 'ts-node', '-e', code];
63
+ case 'python': return ['python3', '-c', code];
64
+ case 'shell':
65
+ return os.platform() === 'win32'
66
+ ? ['powershell', '-Command', code]
67
+ : ['sh', '-c', code];
68
+ }
69
+ }
70
+ function runSubprocess(args, env, timeout) {
71
+ const start = Date.now();
72
+ return new Promise((resolve) => {
73
+ const proc = (0, child_process_1.spawn)(args[0], args.slice(1), {
74
+ env: { ...process.env, ...env },
75
+ shell: false,
76
+ });
77
+ let stdout = '';
78
+ let stderr = '';
79
+ let timedOut = false;
80
+ const timer = setTimeout(() => {
81
+ timedOut = true;
82
+ proc.kill('SIGKILL');
83
+ }, timeout);
84
+ proc.stdout.on('data', (d) => { stdout += d.toString(); });
85
+ proc.stderr.on('data', (d) => { stderr += d.toString(); });
86
+ proc.on('close', (exitCode) => {
87
+ clearTimeout(timer);
88
+ resolve({ stdout, stderr, exitCode: exitCode ?? 1, timedOut, elapsedMs: Date.now() - start });
89
+ });
90
+ });
91
+ }
92
+ //# sourceMappingURL=execute-code.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"execute-code.js","sourceRoot":"","sources":["../../src/tools/execute-code.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,47 @@
1
+ import type { ToolCall } from '../core/types';
2
+ export interface SimpleHookContext {
3
+ toolName: string;
4
+ args: Record<string, unknown>;
5
+ }
6
+ export type BeforeHook = (ctx: SimpleHookContext) => {
7
+ allow: boolean;
8
+ reason?: string;
9
+ modifiedArgs?: Record<string, unknown>;
10
+ };
11
+ export type AfterHook = (ctx: SimpleHookContext, result: string) => string;
12
+ export declare class ToolHooks {
13
+ private beforeHooks;
14
+ private afterHooks;
15
+ addBefore(hook: BeforeHook): void;
16
+ addAfter(hook: AfterHook): void;
17
+ runBefore(ctx: SimpleHookContext): {
18
+ allow: boolean;
19
+ reason?: string;
20
+ modifiedArgs?: Record<string, unknown>;
21
+ };
22
+ runAfter(ctx: SimpleHookContext, result: string): string;
23
+ }
24
+ export declare const dangerousCommandBlocker: BeforeHook;
25
+ export type HookPhase = 'before' | 'after' | 'error';
26
+ export interface ToolHook {
27
+ id: string;
28
+ phase: HookPhase;
29
+ tools?: string[];
30
+ fn: (ctx: ToolHookContext) => Promise<void>;
31
+ }
32
+ export interface ToolHookContext {
33
+ call: ToolCall;
34
+ args: Record<string, unknown>;
35
+ result?: unknown;
36
+ error?: Error;
37
+ startedAt: number;
38
+ }
39
+ export declare class ToolHookRunner {
40
+ private hooks;
41
+ add(hook: ToolHook): void;
42
+ remove(id: string): void;
43
+ runBefore(ctx: ToolHookContext): Promise<void>;
44
+ runAfter(ctx: ToolHookContext): Promise<void>;
45
+ runError(ctx: ToolHookContext): Promise<void>;
46
+ }
47
+ //# sourceMappingURL=hooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../src/tools/hooks.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAI9C,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC/B;AAED,MAAM,MAAM,UAAU,GAAG,CAAC,GAAG,EAAE,iBAAiB,KAAK;IACnD,KAAK,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACxC,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG,CAAC,GAAG,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,KAAK,MAAM,CAAC;AAE3E,qBAAa,SAAS;IACpB,OAAO,CAAC,WAAW,CAAoB;IACvC,OAAO,CAAC,UAAU,CAAmB;IAErC,SAAS,CAAC,IAAI,EAAE,UAAU,GAAG,IAAI;IACjC,QAAQ,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI;IAE/B,SAAS,CAAC,GAAG,EAAE,iBAAiB,GAAG;QAAE,KAAK,EAAE,OAAO,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE;IAU9G,QAAQ,CAAC,GAAG,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM;CAOzD;AAGD,eAAO,MAAM,uBAAuB,EAAE,UAQrC,CAAC;AAIF,MAAM,MAAM,SAAS,GAAG,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAC;AAErD,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,SAAS,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;IACjB,EAAE,EAAE,CAAC,GAAG,EAAE,eAAe,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7C;AAED,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,QAAQ,CAAC;IACf,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,cAAc;IACzB,OAAO,CAAC,KAAK,CAAkB;IAE/B,GAAG,CAAC,IAAI,EAAE,QAAQ,GAAG,IAAI;IAIzB,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI;IAIlB,SAAS,CAAC,GAAG,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ9C,QAAQ,CAAC,GAAG,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ7C,QAAQ,CAAC,GAAG,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAOpD"}
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ToolHookRunner = exports.dangerousCommandBlocker = exports.ToolHooks = void 0;
4
+ class ToolHooks {
5
+ beforeHooks = [];
6
+ afterHooks = [];
7
+ addBefore(hook) { this.beforeHooks.push(hook); }
8
+ addAfter(hook) { this.afterHooks.push(hook); }
9
+ runBefore(ctx) {
10
+ let modifiedArgs = ctx.args;
11
+ for (const hook of this.beforeHooks) {
12
+ const result = hook({ ...ctx, args: modifiedArgs });
13
+ if (!result.allow)
14
+ return result;
15
+ if (result.modifiedArgs)
16
+ modifiedArgs = result.modifiedArgs;
17
+ }
18
+ return { allow: true, modifiedArgs };
19
+ }
20
+ runAfter(ctx, result) {
21
+ let out = result;
22
+ for (const hook of this.afterHooks) {
23
+ out = hook(ctx, out);
24
+ }
25
+ return out;
26
+ }
27
+ }
28
+ exports.ToolHooks = ToolHooks;
29
+ // Built-in guard: block destructive shell commands before execution
30
+ const dangerousCommandBlocker = (ctx) => {
31
+ if (ctx.toolName === 'shell' &&
32
+ /rm\s+-rf|format\s+[c-z]:|DROP\s+TABLE/i.test(ctx.args['command'] ?? '')) {
33
+ return { allow: false, reason: 'Dangerous command blocked' };
34
+ }
35
+ return { allow: true };
36
+ };
37
+ exports.dangerousCommandBlocker = dangerousCommandBlocker;
38
+ class ToolHookRunner {
39
+ hooks = [];
40
+ add(hook) {
41
+ this.hooks.push(hook);
42
+ }
43
+ remove(id) {
44
+ this.hooks = this.hooks.filter((h) => h.id !== id);
45
+ }
46
+ async runBefore(ctx) {
47
+ for (const hook of this.hooks.filter((h) => h.phase === 'before')) {
48
+ if (!hook.tools || hook.tools.includes(ctx.call.name)) {
49
+ await hook.fn(ctx);
50
+ }
51
+ }
52
+ }
53
+ async runAfter(ctx) {
54
+ for (const hook of this.hooks.filter((h) => h.phase === 'after')) {
55
+ if (!hook.tools || hook.tools.includes(ctx.call.name)) {
56
+ await hook.fn(ctx);
57
+ }
58
+ }
59
+ }
60
+ async runError(ctx) {
61
+ for (const hook of this.hooks.filter((h) => h.phase === 'error')) {
62
+ if (!hook.tools || hook.tools.includes(ctx.call.name)) {
63
+ await hook.fn(ctx);
64
+ }
65
+ }
66
+ }
67
+ }
68
+ exports.ToolHookRunner = ToolHookRunner;
69
+ //# sourceMappingURL=hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../src/tools/hooks.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ export { ToolRegistry } from './registry';
2
+ export type { RegisteredTool } from './registry';
3
+ export { ToolHookRunner, ToolHooks, dangerousCommandBlocker } from './hooks';
4
+ export type { ToolHook, ToolHookContext, HookPhase, SimpleHookContext, BeforeHook, AfterHook } from './hooks';
5
+ export { PermissionResolver, checkPermission } from './permission';
6
+ export type { PermissionRequest, PermissionDecision } from './permission';
7
+ export { executeCode, executeCodeRequest } from './execute-code';
8
+ export type { CodeExecutionRequest, CodeExecutionResult } from './execute-code';
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,YAAY,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAEjD,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAC;AAC7E,YAAY,EAAE,QAAQ,EAAE,eAAe,EAAE,SAAS,EAAE,iBAAiB,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAE9G,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AACnE,YAAY,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAE1E,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACjE,YAAY,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC"}
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.executeCodeRequest = exports.executeCode = exports.checkPermission = exports.PermissionResolver = exports.dangerousCommandBlocker = exports.ToolHooks = exports.ToolHookRunner = exports.ToolRegistry = void 0;
4
+ var registry_1 = require("./registry");
5
+ Object.defineProperty(exports, "ToolRegistry", { enumerable: true, get: function () { return registry_1.ToolRegistry; } });
6
+ var hooks_1 = require("./hooks");
7
+ Object.defineProperty(exports, "ToolHookRunner", { enumerable: true, get: function () { return hooks_1.ToolHookRunner; } });
8
+ Object.defineProperty(exports, "ToolHooks", { enumerable: true, get: function () { return hooks_1.ToolHooks; } });
9
+ Object.defineProperty(exports, "dangerousCommandBlocker", { enumerable: true, get: function () { return hooks_1.dangerousCommandBlocker; } });
10
+ var permission_1 = require("./permission");
11
+ Object.defineProperty(exports, "PermissionResolver", { enumerable: true, get: function () { return permission_1.PermissionResolver; } });
12
+ Object.defineProperty(exports, "checkPermission", { enumerable: true, get: function () { return permission_1.checkPermission; } });
13
+ var execute_code_1 = require("./execute-code");
14
+ Object.defineProperty(exports, "executeCode", { enumerable: true, get: function () { return execute_code_1.executeCode; } });
15
+ Object.defineProperty(exports, "executeCodeRequest", { enumerable: true, get: function () { return execute_code_1.executeCodeRequest; } });
16
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":";;;AAAA,uCAA0C;AAAjC,wGAAA,YAAY,OAAA;AAGrB,iCAA6E;AAApE,uGAAA,cAAc,OAAA;AAAE,kGAAA,SAAS,OAAA;AAAE,gHAAA,uBAAuB,OAAA;AAG3D,2CAAmE;AAA1D,gHAAA,kBAAkB,OAAA;AAAE,6GAAA,eAAe,OAAA;AAG5C,+CAAiE;AAAxD,2GAAA,WAAW,OAAA;AAAE,kHAAA,kBAAkB,OAAA"}
@@ -0,0 +1,20 @@
1
+ import type { PermissionLevel, ToolConfig } from '../core/types';
2
+ type PermissionConfig = Record<string, PermissionLevel>;
3
+ export declare function checkPermission(toolName: string, config?: PermissionConfig): PermissionLevel;
4
+ export interface PermissionRequest {
5
+ tool: string;
6
+ args: Record<string, unknown>;
7
+ sessionId?: string;
8
+ }
9
+ export interface PermissionDecision {
10
+ level: PermissionLevel;
11
+ reason?: string;
12
+ }
13
+ export declare class PermissionResolver {
14
+ private config;
15
+ constructor(config: ToolConfig);
16
+ resolve(req: PermissionRequest): PermissionDecision;
17
+ isAllowed(req: PermissionRequest): boolean;
18
+ }
19
+ export {};
20
+ //# sourceMappingURL=permission.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"permission.d.ts","sourceRoot":"","sources":["../../src/tools/permission.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAIjE,KAAK,gBAAgB,GAAG,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;AAWxD,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,gBAAgB,GAAG,eAAe,CAE5F;AAID,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,eAAe,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,kBAAkB;IACjB,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,UAAU;IAEtC,OAAO,CAAC,GAAG,EAAE,iBAAiB,GAAG,kBAAkB;IAWnD,SAAS,CAAC,GAAG,EAAE,iBAAiB,GAAG,OAAO;CAG3C"}
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PermissionResolver = void 0;
4
+ exports.checkPermission = checkPermission;
5
+ const DEFAULTS = {
6
+ read_file: 'allow',
7
+ write_file: 'allow',
8
+ web_search: 'allow',
9
+ execute_code: 'ask',
10
+ shell_command: 'ask',
11
+ delete_file: 'ask',
12
+ };
13
+ function checkPermission(toolName, config) {
14
+ return config?.[toolName] ?? DEFAULTS[toolName] ?? 'ask';
15
+ }
16
+ class PermissionResolver {
17
+ config;
18
+ constructor(config) {
19
+ this.config = config;
20
+ }
21
+ resolve(req) {
22
+ const explicit = this.config.permissions[req.tool];
23
+ if (explicit)
24
+ return { level: explicit };
25
+ if (this.config.builtin.includes(req.tool)) {
26
+ return { level: 'allow', reason: 'builtin_tool' };
27
+ }
28
+ return { level: 'ask', reason: 'default_policy' };
29
+ }
30
+ isAllowed(req) {
31
+ return this.resolve(req).level === 'allow';
32
+ }
33
+ }
34
+ exports.PermissionResolver = PermissionResolver;
35
+ //# sourceMappingURL=permission.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"permission.js","sourceRoot":"","sources":["../../src/tools/permission.ts"],"names":[],"mappings":";;;AAgBA,0CAEC;AAXD,MAAM,QAAQ,GAAqB;IACjC,SAAS,EAAE,OAAO;IAClB,UAAU,EAAE,OAAO;IACnB,UAAU,EAAE,OAAO;IACnB,YAAY,EAAE,KAAK;IACnB,aAAa,EAAE,KAAK;IACpB,WAAW,EAAE,KAAK;CACnB,CAAC;AAEF,SAAgB,eAAe,CAAC,QAAgB,EAAE,MAAyB;IACzE,OAAO,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC;AAC3D,CAAC;AAeD,MAAa,kBAAkB;IACT;IAApB,YAAoB,MAAkB;QAAlB,WAAM,GAAN,MAAM,CAAY;IAAG,CAAC;IAE1C,OAAO,CAAC,GAAsB;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnD,IAAI,QAAQ;YAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;QAEzC,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YAC3C,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC;QACpD,CAAC;QAED,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,gBAAgB,EAAE,CAAC;IACpD,CAAC;IAED,SAAS,CAAC,GAAsB;QAC9B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,OAAO,CAAC;IAC7C,CAAC;CACF;AAjBD,gDAiBC"}
@@ -0,0 +1,25 @@
1
+ import type { ToolDefinition } from '../core/types';
2
+ export interface RegisteredTool {
3
+ definition: ToolDefinition;
4
+ handler: (args: Record<string, unknown>) => Promise<unknown>;
5
+ category?: string;
6
+ enabled: boolean;
7
+ }
8
+ export declare class ToolRegistry {
9
+ private tools;
10
+ register(tool: RegisteredTool): void;
11
+ unregister(name: string): void;
12
+ get(name: string): RegisteredTool | undefined;
13
+ list(enabled?: boolean): RegisteredTool[];
14
+ definitions(): ToolDefinition[];
15
+ execute(name: string, args: Record<string, unknown>): Promise<unknown>;
16
+ toOpenAIFormat(): {
17
+ type: string;
18
+ function: {
19
+ name: string;
20
+ description: string;
21
+ parameters: Record<string, unknown>;
22
+ };
23
+ }[];
24
+ }
25
+ //# sourceMappingURL=registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/tools/registry.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEpD,MAAM,WAAW,cAAc;IAC7B,UAAU,EAAE,cAAc,CAAC;IAC3B,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IAC7D,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,KAAK,CAAqC;IAElD,QAAQ,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAIpC,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAI9B,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,cAAc,GAAG,SAAS;IAI7C,IAAI,CAAC,OAAO,CAAC,EAAE,OAAO,GAAG,cAAc,EAAE;IAKzC,WAAW,IAAI,cAAc,EAAE;IAIzB,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC;IAO5E,cAAc,IAAI;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,WAAW,EAAE,MAAM,CAAC;YAAC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;SAAE,CAAA;KAAE,EAAE;CAU3H"}
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ToolRegistry = void 0;
4
+ class ToolRegistry {
5
+ tools = new Map();
6
+ register(tool) {
7
+ this.tools.set(tool.definition.name, tool);
8
+ }
9
+ unregister(name) {
10
+ this.tools.delete(name);
11
+ }
12
+ get(name) {
13
+ return this.tools.get(name);
14
+ }
15
+ list(enabled) {
16
+ const all = Array.from(this.tools.values());
17
+ return enabled !== undefined ? all.filter((t) => t.enabled === enabled) : all;
18
+ }
19
+ definitions() {
20
+ return this.list(true).map((t) => t.definition);
21
+ }
22
+ async execute(name, args) {
23
+ const tool = this.tools.get(name);
24
+ if (!tool)
25
+ throw new Error(`unknown tool: ${name}`);
26
+ if (!tool.enabled)
27
+ throw new Error(`tool disabled: ${name}`);
28
+ return tool.handler(args);
29
+ }
30
+ toOpenAIFormat() {
31
+ return this.list(true).map((t) => ({
32
+ type: 'function',
33
+ function: {
34
+ name: t.definition.name,
35
+ description: t.definition.description,
36
+ parameters: t.definition.parameters,
37
+ },
38
+ }));
39
+ }
40
+ }
41
+ exports.ToolRegistry = ToolRegistry;
42
+ //# sourceMappingURL=registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/tools/registry.ts"],"names":[],"mappings":";;;AAUA,MAAa,YAAY;IACf,KAAK,GAAG,IAAI,GAAG,EAA0B,CAAC;IAElD,QAAQ,CAAC,IAAoB;QAC3B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC7C,CAAC;IAED,UAAU,CAAC,IAAY;QACrB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,GAAG,CAAC,IAAY;QACd,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,IAAI,CAAC,OAAiB;QACpB,MAAM,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;QAC5C,OAAO,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;IAChF,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;IAClD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,IAAY,EAAE,IAA6B;QACvD,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,IAAI;YAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,IAAI,EAAE,CAAC,CAAC;QACpD,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,IAAI,EAAE,CAAC,CAAC;QAC7D,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACjC,IAAI,EAAE,UAAU;YAChB,QAAQ,EAAE;gBACR,IAAI,EAAE,CAAC,CAAC,UAAU,CAAC,IAAI;gBACvB,WAAW,EAAE,CAAC,CAAC,UAAU,CAAC,WAAW;gBACrC,UAAU,EAAE,CAAC,CAAC,UAAU,CAAC,UAAqC;aAC/D;SACF,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AAzCD,oCAyCC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "opc-agent",
3
- "version": "4.2.13",
3
+ "version": "5.0.0-alpha.1",
4
4
  "description": "Open Agent Framework — Build, test, and run AI Agents for business workstations",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",