@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.
- package/package.json +3 -1
- package/src/agents/tools/executeScript/README.md +78 -0
- package/src/agents/tools/executeScript/definition.ts +73 -0
- package/src/agents/tools/executeScript/examples/quick-test.ts +80 -0
- package/src/agents/tools/executeScript/examples/serialization-test.ts +309 -0
- package/src/agents/tools/executeScript/examples/test-runner.ts +204 -0
- package/src/agents/tools/executeScript/index.ts +74 -0
- package/src/agents/tools/index.ts +1 -0
- package/src/agents/tools/list.ts +2 -1
- package/src/cli.ts +2 -6
- package/src/clients/index.ts +23 -9
- package/src/services/Tools.ts +19 -3
- package/src/services/script-execution/SandboxContext.ts +278 -0
- package/src/services/script-execution/ScriptExecutor.ts +337 -0
- package/src/services/script-execution/ScriptPolicy.ts +236 -0
- package/src/services/script-execution/ScriptTracer.ts +249 -0
- package/src/services/script-execution/types.ts +134 -0
- package/ts_build/src/agents/tools/executeScript/definition.d.ts +2 -0
- package/ts_build/src/agents/tools/executeScript/definition.js +70 -0
- package/ts_build/src/agents/tools/executeScript/definition.js.map +1 -0
- package/ts_build/src/agents/tools/executeScript/examples/quick-test.d.ts +3 -0
- package/ts_build/src/agents/tools/executeScript/examples/quick-test.js +68 -0
- package/ts_build/src/agents/tools/executeScript/examples/quick-test.js.map +1 -0
- package/ts_build/src/agents/tools/executeScript/examples/serialization-test.d.ts +15 -0
- package/ts_build/src/agents/tools/executeScript/examples/serialization-test.js +267 -0
- package/ts_build/src/agents/tools/executeScript/examples/serialization-test.js.map +1 -0
- package/ts_build/src/agents/tools/executeScript/examples/simple-example.d.ts +20 -0
- package/ts_build/src/agents/tools/executeScript/examples/simple-example.js +35 -0
- package/ts_build/src/agents/tools/executeScript/examples/simple-example.js.map +1 -0
- package/ts_build/src/agents/tools/executeScript/examples/test-runner.d.ts +4 -0
- package/ts_build/src/agents/tools/executeScript/examples/test-runner.js +202 -0
- package/ts_build/src/agents/tools/executeScript/examples/test-runner.js.map +1 -0
- package/ts_build/src/agents/tools/executeScript/handler.d.ts +27 -0
- package/ts_build/src/agents/tools/executeScript/handler.js +64 -0
- package/ts_build/src/agents/tools/executeScript/handler.js.map +1 -0
- package/ts_build/src/agents/tools/executeScript/index.d.ts +27 -0
- package/ts_build/src/agents/tools/executeScript/index.js +64 -0
- package/ts_build/src/agents/tools/executeScript/index.js.map +1 -0
- package/ts_build/src/agents/tools/executeScript.d.ts +29 -0
- package/ts_build/src/agents/tools/executeScript.js +124 -0
- package/ts_build/src/agents/tools/executeScript.js.map +1 -0
- package/ts_build/src/agents/tools/index.d.ts +1 -0
- package/ts_build/src/agents/tools/index.js +1 -0
- package/ts_build/src/agents/tools/index.js.map +1 -1
- package/ts_build/src/agents/tools/list.js +2 -0
- package/ts_build/src/agents/tools/list.js.map +1 -1
- package/ts_build/src/cli.js +2 -6
- package/ts_build/src/cli.js.map +1 -1
- package/ts_build/src/clients/index.d.ts +9 -2
- package/ts_build/src/clients/index.js +17 -4
- package/ts_build/src/clients/index.js.map +1 -1
- package/ts_build/src/services/Tools.d.ts +3 -0
- package/ts_build/src/services/Tools.js +10 -2
- package/ts_build/src/services/Tools.js.map +1 -1
- package/ts_build/src/services/script-execution/SandboxContext.d.ts +34 -0
- package/ts_build/src/services/script-execution/SandboxContext.js +188 -0
- package/ts_build/src/services/script-execution/SandboxContext.js.map +1 -0
- package/ts_build/src/services/script-execution/ScriptExecutor.d.ts +17 -0
- package/ts_build/src/services/script-execution/ScriptExecutor.js +207 -0
- package/ts_build/src/services/script-execution/ScriptExecutor.js.map +1 -0
- package/ts_build/src/services/script-execution/ScriptPolicy.d.ts +27 -0
- package/ts_build/src/services/script-execution/ScriptPolicy.js +150 -0
- package/ts_build/src/services/script-execution/ScriptPolicy.js.map +1 -0
- package/ts_build/src/services/script-execution/ScriptTracer.d.ts +19 -0
- package/ts_build/src/services/script-execution/ScriptTracer.js +186 -0
- package/ts_build/src/services/script-execution/ScriptTracer.js.map +1 -0
- package/ts_build/src/services/script-execution/types.d.ts +108 -0
- package/ts_build/src/services/script-execution/types.js +3 -0
- 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":"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"}
|
|
@@ -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 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/services/script-execution/types.ts"],"names":[],"mappings":""}
|