@tyvm/knowhow 0.0.21 → 0.0.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/package.json +3 -1
  2. package/src/agents/tools/executeScript/README.md +78 -0
  3. package/src/agents/tools/executeScript/definition.ts +73 -0
  4. package/src/agents/tools/executeScript/examples/quick-test.ts +80 -0
  5. package/src/agents/tools/executeScript/examples/serialization-test.ts +309 -0
  6. package/src/agents/tools/executeScript/examples/test-runner.ts +204 -0
  7. package/src/agents/tools/executeScript/index.ts +74 -0
  8. package/src/agents/tools/index.ts +1 -0
  9. package/src/agents/tools/list.ts +2 -1
  10. package/src/cli.ts +2 -6
  11. package/src/clients/index.ts +23 -9
  12. package/src/services/Tools.ts +19 -3
  13. package/src/services/script-execution/SandboxContext.ts +278 -0
  14. package/src/services/script-execution/ScriptExecutor.ts +337 -0
  15. package/src/services/script-execution/ScriptPolicy.ts +236 -0
  16. package/src/services/script-execution/ScriptTracer.ts +249 -0
  17. package/src/services/script-execution/types.ts +134 -0
  18. package/ts_build/src/agents/tools/executeScript/definition.d.ts +2 -0
  19. package/ts_build/src/agents/tools/executeScript/definition.js +70 -0
  20. package/ts_build/src/agents/tools/executeScript/definition.js.map +1 -0
  21. package/ts_build/src/agents/tools/executeScript/examples/quick-test.d.ts +3 -0
  22. package/ts_build/src/agents/tools/executeScript/examples/quick-test.js +68 -0
  23. package/ts_build/src/agents/tools/executeScript/examples/quick-test.js.map +1 -0
  24. package/ts_build/src/agents/tools/executeScript/examples/serialization-test.d.ts +15 -0
  25. package/ts_build/src/agents/tools/executeScript/examples/serialization-test.js +267 -0
  26. package/ts_build/src/agents/tools/executeScript/examples/serialization-test.js.map +1 -0
  27. package/ts_build/src/agents/tools/executeScript/examples/simple-example.d.ts +20 -0
  28. package/ts_build/src/agents/tools/executeScript/examples/simple-example.js +35 -0
  29. package/ts_build/src/agents/tools/executeScript/examples/simple-example.js.map +1 -0
  30. package/ts_build/src/agents/tools/executeScript/examples/test-runner.d.ts +4 -0
  31. package/ts_build/src/agents/tools/executeScript/examples/test-runner.js +202 -0
  32. package/ts_build/src/agents/tools/executeScript/examples/test-runner.js.map +1 -0
  33. package/ts_build/src/agents/tools/executeScript/handler.d.ts +27 -0
  34. package/ts_build/src/agents/tools/executeScript/handler.js +64 -0
  35. package/ts_build/src/agents/tools/executeScript/handler.js.map +1 -0
  36. package/ts_build/src/agents/tools/executeScript/index.d.ts +27 -0
  37. package/ts_build/src/agents/tools/executeScript/index.js +64 -0
  38. package/ts_build/src/agents/tools/executeScript/index.js.map +1 -0
  39. package/ts_build/src/agents/tools/executeScript.d.ts +29 -0
  40. package/ts_build/src/agents/tools/executeScript.js +124 -0
  41. package/ts_build/src/agents/tools/executeScript.js.map +1 -0
  42. package/ts_build/src/agents/tools/index.d.ts +1 -0
  43. package/ts_build/src/agents/tools/index.js +1 -0
  44. package/ts_build/src/agents/tools/index.js.map +1 -1
  45. package/ts_build/src/agents/tools/list.js +2 -0
  46. package/ts_build/src/agents/tools/list.js.map +1 -1
  47. package/ts_build/src/cli.js +2 -6
  48. package/ts_build/src/cli.js.map +1 -1
  49. package/ts_build/src/clients/index.d.ts +9 -2
  50. package/ts_build/src/clients/index.js +17 -4
  51. package/ts_build/src/clients/index.js.map +1 -1
  52. package/ts_build/src/services/Tools.d.ts +3 -0
  53. package/ts_build/src/services/Tools.js +10 -2
  54. package/ts_build/src/services/Tools.js.map +1 -1
  55. package/ts_build/src/services/script-execution/SandboxContext.d.ts +34 -0
  56. package/ts_build/src/services/script-execution/SandboxContext.js +188 -0
  57. package/ts_build/src/services/script-execution/SandboxContext.js.map +1 -0
  58. package/ts_build/src/services/script-execution/ScriptExecutor.d.ts +17 -0
  59. package/ts_build/src/services/script-execution/ScriptExecutor.js +207 -0
  60. package/ts_build/src/services/script-execution/ScriptExecutor.js.map +1 -0
  61. package/ts_build/src/services/script-execution/ScriptPolicy.d.ts +27 -0
  62. package/ts_build/src/services/script-execution/ScriptPolicy.js +150 -0
  63. package/ts_build/src/services/script-execution/ScriptPolicy.js.map +1 -0
  64. package/ts_build/src/services/script-execution/ScriptTracer.d.ts +19 -0
  65. package/ts_build/src/services/script-execution/ScriptTracer.js +186 -0
  66. package/ts_build/src/services/script-execution/ScriptTracer.js.map +1 -0
  67. package/ts_build/src/services/script-execution/types.d.ts +108 -0
  68. package/ts_build/src/services/script-execution/types.js +3 -0
  69. package/ts_build/src/services/script-execution/types.js.map +1 -0
@@ -0,0 +1,186 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ScriptTracer = void 0;
4
+ class ScriptTracer {
5
+ events = [];
6
+ metrics;
7
+ startTime;
8
+ constructor() {
9
+ this.startTime = Date.now();
10
+ this.metrics = {
11
+ executionTimeMs: 0,
12
+ toolCallCount: 0,
13
+ llmCallCount: 0,
14
+ tokenUsage: {
15
+ prompt: 0,
16
+ completion: 0,
17
+ total: 0,
18
+ },
19
+ memoryUsage: {
20
+ heapUsed: 0,
21
+ heapTotal: 0,
22
+ },
23
+ costUsd: 0,
24
+ };
25
+ }
26
+ emitEvent(type, data) {
27
+ const event = {
28
+ id: `evt-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`,
29
+ type,
30
+ timestamp: Date.now(),
31
+ data: this.sanitizeEventData(data),
32
+ };
33
+ this.events.push(event);
34
+ this.updateMetrics(event);
35
+ }
36
+ recordCost(costUsd) {
37
+ this.metrics.costUsd += costUsd;
38
+ this.emitEvent("cost_recorded", {
39
+ costUsd,
40
+ totalCost: this.metrics.costUsd,
41
+ });
42
+ }
43
+ getCurrentQuota() {
44
+ return {
45
+ toolCalls: this.metrics.toolCallCount,
46
+ tokens: this.metrics.tokenUsage.total,
47
+ executionTimeMs: Date.now() - this.startTime,
48
+ costUsd: this.metrics.costUsd,
49
+ };
50
+ }
51
+ getEvents() {
52
+ return [...this.events];
53
+ }
54
+ getMetrics() {
55
+ return {
56
+ ...this.metrics,
57
+ executionTimeMs: Date.now() - this.startTime,
58
+ };
59
+ }
60
+ getTrace() {
61
+ return {
62
+ id: `trace-${Date.now()}`,
63
+ startTime: this.startTime,
64
+ endTime: Date.now(),
65
+ events: this.getEvents(),
66
+ metrics: this.getMetrics(),
67
+ success: !this.events.some((e) => e.type.includes("error")),
68
+ error: this.getLastError(),
69
+ };
70
+ }
71
+ reset() {
72
+ this.events = [];
73
+ this.startTime = Date.now();
74
+ this.metrics = {
75
+ executionTimeMs: 0,
76
+ toolCallCount: 0,
77
+ llmCallCount: 0,
78
+ tokenUsage: {
79
+ prompt: 0,
80
+ completion: 0,
81
+ total: 0,
82
+ },
83
+ memoryUsage: {
84
+ heapUsed: 0,
85
+ heapTotal: 0,
86
+ },
87
+ costUsd: 0,
88
+ };
89
+ }
90
+ updateMetrics(event) {
91
+ switch (event.type) {
92
+ case "tool_call_start":
93
+ this.metrics.toolCallCount++;
94
+ break;
95
+ case "llm_call_start":
96
+ this.metrics.llmCallCount++;
97
+ break;
98
+ case "llm_call_success":
99
+ if (event.data && event.data.usage) {
100
+ const usage = event.data.usage;
101
+ this.metrics.tokenUsage.prompt += usage.prompt_tokens || 0;
102
+ this.metrics.tokenUsage.completion += usage.completion_tokens || 0;
103
+ this.metrics.tokenUsage.total += usage.total_tokens || 0;
104
+ }
105
+ break;
106
+ }
107
+ if (typeof process !== "undefined" && process.memoryUsage) {
108
+ const memUsage = process.memoryUsage();
109
+ this.metrics.memoryUsage.heapUsed = memUsage.heapUsed;
110
+ this.metrics.memoryUsage.heapTotal = memUsage.heapTotal;
111
+ }
112
+ }
113
+ getLastError() {
114
+ const errorEvents = this.events
115
+ .filter((e) => e.type.includes("error"))
116
+ .reverse();
117
+ if (errorEvents.length > 0) {
118
+ const lastError = errorEvents[0];
119
+ return (lastError.data?.error || lastError.data?.message || "Unknown error");
120
+ }
121
+ return undefined;
122
+ }
123
+ sanitizeEventData(data) {
124
+ if (data === null || data === undefined) {
125
+ return data;
126
+ }
127
+ if (typeof data === "string") {
128
+ return data.length > 1000
129
+ ? data.substring(0, 1000) + "...[TRUNCATED]"
130
+ : data;
131
+ }
132
+ if (Array.isArray(data)) {
133
+ return data.map((item) => this.sanitizeEventData(item));
134
+ }
135
+ if (typeof data === "object") {
136
+ const sanitized = {};
137
+ for (const [key, value] of Object.entries(data)) {
138
+ if (this.isSensitiveKey(key)) {
139
+ sanitized[key] = "[REDACTED]";
140
+ }
141
+ else if (key === "parameters" && typeof value === "object") {
142
+ sanitized[key] = this.sanitizeParameters(value);
143
+ }
144
+ else {
145
+ sanitized[key] = this.sanitizeEventData(value);
146
+ }
147
+ }
148
+ return sanitized;
149
+ }
150
+ return data;
151
+ }
152
+ isSensitiveKey(key) {
153
+ const lowerKey = key.toLowerCase();
154
+ const sensitivePatterns = [
155
+ "password",
156
+ "secret",
157
+ "token",
158
+ "key",
159
+ "auth",
160
+ "credential",
161
+ "private",
162
+ "confidential",
163
+ ];
164
+ return sensitivePatterns.some((pattern) => lowerKey.includes(pattern));
165
+ }
166
+ sanitizeParameters(params) {
167
+ if (!params || typeof params !== "object") {
168
+ return params;
169
+ }
170
+ const sanitized = {};
171
+ for (const [key, value] of Object.entries(params)) {
172
+ if (this.isSensitiveKey(key)) {
173
+ sanitized[key] = "[REDACTED]";
174
+ }
175
+ else if (typeof value === "string" && value.length > 500) {
176
+ sanitized[key] = value.substring(0, 500) + "...[TRUNCATED]";
177
+ }
178
+ else {
179
+ sanitized[key] = this.sanitizeEventData(value);
180
+ }
181
+ }
182
+ return sanitized;
183
+ }
184
+ }
185
+ exports.ScriptTracer = ScriptTracer;
186
+ //# sourceMappingURL=ScriptTracer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScriptTracer.js","sourceRoot":"","sources":["../../../../src/services/script-execution/ScriptTracer.ts"],"names":[],"mappings":";;;AAKA,MAAa,YAAY;IACf,MAAM,GAAiB,EAAE,CAAC;IAC1B,OAAO,CAAe;IACtB,SAAS,CAAS;IAE1B;QACE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC5B,IAAI,CAAC,OAAO,GAAG;YACb,eAAe,EAAE,CAAC;YAClB,aAAa,EAAE,CAAC;YAChB,YAAY,EAAE,CAAC;YACf,UAAU,EAAE;gBACV,MAAM,EAAE,CAAC;gBACT,UAAU,EAAE,CAAC;gBACb,KAAK,EAAE,CAAC;aACT;YACD,WAAW,EAAE;gBACX,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE,CAAC;aACb;YACD,OAAO,EAAE,CAAC;SACX,CAAC;IACJ,CAAC;IAKD,SAAS,CAAC,IAAY,EAAE,IAAS;QAC/B,MAAM,KAAK,GAAe;YACxB,EAAE,EAAE,OAAO,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE;YAClE,IAAI;YACJ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;SACnC,CAAC;QAEF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAKD,UAAU,CAAC,OAAe;QACxB,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC;QAChC,IAAI,CAAC,SAAS,CAAC,eAAe,EAAE;YAC9B,OAAO;YACP,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;SAChC,CAAC,CAAC;IACL,CAAC;IAKD,eAAe;QACb,OAAO;YACL,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa;YACrC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK;YACrC,eAAe,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,SAAS;YAC5C,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;SAC9B,CAAC;IACJ,CAAC;IAKD,SAAS;QACP,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;IAC1B,CAAC;IAKD,UAAU;QACR,OAAO;YACL,GAAG,IAAI,CAAC,OAAO;YACf,eAAe,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,SAAS;SAC7C,CAAC;IACJ,CAAC;IAKD,QAAQ;QACN,OAAO;YACL,EAAE,EAAE,SAAS,IAAI,CAAC,GAAG,EAAE,EAAE;YACzB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,OAAO,EAAE,IAAI,CAAC,GAAG,EAAE;YACnB,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE;YACxB,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE;YAC1B,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YAC3D,KAAK,EAAE,IAAI,CAAC,YAAY,EAAE;SAC3B,CAAC;IACJ,CAAC;IAKD,KAAK;QACH,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC5B,IAAI,CAAC,OAAO,GAAG;YACb,eAAe,EAAE,CAAC;YAClB,aAAa,EAAE,CAAC;YAChB,YAAY,EAAE,CAAC;YACf,UAAU,EAAE;gBACV,MAAM,EAAE,CAAC;gBACT,UAAU,EAAE,CAAC;gBACb,KAAK,EAAE,CAAC;aACT;YACD,WAAW,EAAE;gBACX,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE,CAAC;aACb;YACD,OAAO,EAAE,CAAC;SACX,CAAC;IACJ,CAAC;IAKO,aAAa,CAAC,KAAiB;QACrC,QAAQ,KAAK,CAAC,IAAI,EAAE;YAClB,KAAK,iBAAiB;gBACpB,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;gBAC7B,MAAM;YAER,KAAK,gBAAgB;gBACnB,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;gBAC5B,MAAM;YAER,KAAK,kBAAkB;gBACrB,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE;oBAClC,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;oBAC/B,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,IAAI,KAAK,CAAC,aAAa,IAAI,CAAC,CAAC;oBAC3D,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,UAAU,IAAI,KAAK,CAAC,iBAAiB,IAAI,CAAC,CAAC;oBACnE,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,IAAI,KAAK,CAAC,YAAY,IAAI,CAAC,CAAC;iBAC1D;gBACD,MAAM;SACT;QAGD,IAAI,OAAO,OAAO,KAAK,WAAW,IAAI,OAAO,CAAC,WAAW,EAAE;YACzD,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;YACvC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC;YACtD,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAC;SACzD;IACH,CAAC;IAKO,YAAY;QAClB,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM;aAC5B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;aACvC,OAAO,EAAE,CAAC;QAEb,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;YAC1B,MAAM,SAAS,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;YACjC,OAAO,CACL,SAAS,CAAC,IAAI,EAAE,KAAK,IAAI,SAAS,CAAC,IAAI,EAAE,OAAO,IAAI,eAAe,CACpE,CAAC;SACH;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAKO,iBAAiB,CAAC,IAAS;QACjC,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,SAAS,EAAE;YACvC,OAAO,IAAI,CAAC;SACb;QAED,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;YAE5B,OAAO,IAAI,CAAC,MAAM,GAAG,IAAI;gBACvB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,gBAAgB;gBAC5C,CAAC,CAAC,IAAI,CAAC;SACV;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACvB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC;SACzD;QAED,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;YAC5B,MAAM,SAAS,GAAQ,EAAE,CAAC;YAC1B,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBAE/C,IAAI,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;oBAC5B,SAAS,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC;iBAC/B;qBAAM,IAAI,GAAG,KAAK,YAAY,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;oBAE5D,SAAS,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;iBACjD;qBAAM;oBACL,SAAS,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;iBAChD;aACF;YACD,OAAO,SAAS,CAAC;SAClB;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAKO,cAAc,CAAC,GAAW;QAChC,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;QACnC,MAAM,iBAAiB,GAAG;YACxB,UAAU;YACV,QAAQ;YACR,OAAO;YACP,KAAK;YACL,MAAM;YACN,YAAY;YACZ,SAAS;YACT,cAAc;SACf,CAAC;QAEF,OAAO,iBAAiB,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;IACzE,CAAC;IAKO,kBAAkB,CAAC,MAAW;QACpC,IAAI,CAAC,MAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE;YACzC,OAAO,MAAM,CAAC;SACf;QAED,MAAM,SAAS,GAAQ,EAAE,CAAC;QAC1B,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACjD,IAAI,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;gBAC5B,SAAS,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC;aAC/B;iBAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,MAAM,GAAG,GAAG,EAAE;gBAC1D,SAAS,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,gBAAgB,CAAC;aAC7D;iBAAM;gBACL,SAAS,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;aAChD;SACF;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AAnPD,oCAmPC"}
@@ -0,0 +1,108 @@
1
+ import { Message } from '../../clients/types';
2
+ export interface TraceEvent {
3
+ id: string;
4
+ type: string;
5
+ timestamp: number;
6
+ data: any;
7
+ }
8
+ export interface TraceMetrics {
9
+ executionTimeMs: number;
10
+ toolCallCount: number;
11
+ llmCallCount: number;
12
+ tokenUsage: {
13
+ prompt: number;
14
+ completion: number;
15
+ total: number;
16
+ };
17
+ memoryUsage: {
18
+ heapUsed: number;
19
+ heapTotal: number;
20
+ };
21
+ costUsd: number;
22
+ }
23
+ export interface ExecutionTrace {
24
+ id: string;
25
+ startTime: number;
26
+ endTime: number;
27
+ events: TraceEvent[];
28
+ metrics: TraceMetrics;
29
+ success: boolean;
30
+ error?: string;
31
+ }
32
+ export interface ResourceQuotas {
33
+ maxToolCalls: number;
34
+ maxTokens: number;
35
+ maxExecutionTimeMs: number;
36
+ maxCostUsd: number;
37
+ maxMemoryMb: number;
38
+ }
39
+ export interface SecurityPolicy {
40
+ allowlistedTools: string[];
41
+ denylistedTools: string[];
42
+ maxScriptLength: number;
43
+ allowNetworkAccess: boolean;
44
+ allowFileSystemAccess: boolean;
45
+ }
46
+ export interface QuotaUsage {
47
+ toolCalls: number;
48
+ tokens: number;
49
+ executionTimeMs: number;
50
+ costUsd: number;
51
+ }
52
+ export interface PolicyViolation {
53
+ id: string;
54
+ type: 'quota_exceeded' | 'tool_denied' | 'tool_not_allowed' | 'script_validation';
55
+ message: string;
56
+ timestamp: number;
57
+ usage: QuotaUsage;
58
+ }
59
+ export interface ExecutionRequest {
60
+ script: string;
61
+ context?: Record<string, any>;
62
+ quotas?: Partial<ResourceQuotas>;
63
+ policy?: Partial<SecurityPolicy>;
64
+ }
65
+ export interface ExecutionResult {
66
+ success: boolean;
67
+ error: string | null;
68
+ result: any;
69
+ trace: ExecutionTrace;
70
+ artifacts: Artifact[];
71
+ consoleOutput: string[];
72
+ }
73
+ export interface Artifact {
74
+ id: string;
75
+ name: string;
76
+ type: 'text' | 'json' | 'csv' | 'html' | 'markdown';
77
+ content: string;
78
+ createdAt: string;
79
+ }
80
+ export interface ToolResult {
81
+ success: boolean;
82
+ result?: any;
83
+ error?: string;
84
+ }
85
+ export interface ToolCall {
86
+ id: string;
87
+ name: string;
88
+ args: Record<string, any>;
89
+ result?: any;
90
+ error?: string;
91
+ timestamp: number;
92
+ duration?: number;
93
+ }
94
+ export interface LLMCall {
95
+ id: string;
96
+ model: string;
97
+ messages: Message[];
98
+ response?: any;
99
+ error?: string;
100
+ timestamp: number;
101
+ duration?: number;
102
+ tokenUsage?: {
103
+ prompt: number;
104
+ completion: number;
105
+ total: number;
106
+ };
107
+ cost?: number;
108
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/services/script-execution/types.ts"],"names":[],"mappings":""}