@tyvm/knowhow 0.0.108-dev.c7d102c → 0.0.108-dev.ed88cf4
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 +2 -3
- package/src/agents/tools/index.ts +0 -1
- package/src/agents/tools/list.ts +0 -2
- package/src/chat/CliChatService.ts +10 -1
- package/src/chat/renderer/CompactRenderer.ts +20 -0
- package/src/chat/renderer/ConsoleRenderer.ts +19 -0
- package/src/chat/renderer/FancyRenderer.ts +19 -0
- package/src/chat/renderer/types.ts +11 -0
- package/src/cli.ts +91 -664
- package/src/clients/index.ts +6 -5
- package/src/commands/agent.ts +246 -0
- package/src/commands/misc.ts +174 -0
- package/src/commands/modules.ts +182 -0
- package/src/commands/services.ts +77 -0
- package/src/commands/workers.ts +160 -0
- package/src/config.ts +37 -0
- package/src/index.ts +1 -0
- package/src/logger.ts +197 -0
- package/src/plugins/plugins.ts +0 -21
- package/src/processors/JsonCompressor.ts +3 -3
- package/src/services/EventService.ts +61 -1
- package/src/services/modules/index.ts +70 -50
- package/src/services/modules/types.ts +4 -0
- package/src/tunnel.ts +216 -0
- package/src/types.ts +0 -1
- package/src/worker.ts +65 -336
- package/src/workers/auth/WsMiddleware.ts +99 -0
- package/src/workers/auth/authMiddleware.ts +104 -0
- package/src/workers/auth/types.ts +14 -2
- package/tests/unit/commands/github-credentials.test.ts +211 -0
- package/tests/unit/modules/moduleLoading.test.ts +39 -37
- package/tests/unit/plugins/pluginLoading.test.ts +0 -85
- package/ts_build/package.json +2 -3
- package/ts_build/src/agents/tools/index.d.ts +0 -1
- package/ts_build/src/agents/tools/index.js +0 -1
- package/ts_build/src/agents/tools/index.js.map +1 -1
- package/ts_build/src/agents/tools/list.js +0 -2
- package/ts_build/src/agents/tools/list.js.map +1 -1
- package/ts_build/src/chat/CliChatService.js +13 -1
- package/ts_build/src/chat/CliChatService.js.map +1 -1
- package/ts_build/src/chat/renderer/CompactRenderer.d.ts +4 -0
- package/ts_build/src/chat/renderer/CompactRenderer.js +16 -0
- package/ts_build/src/chat/renderer/CompactRenderer.js.map +1 -1
- package/ts_build/src/chat/renderer/ConsoleRenderer.d.ts +4 -0
- package/ts_build/src/chat/renderer/ConsoleRenderer.js +16 -0
- package/ts_build/src/chat/renderer/ConsoleRenderer.js.map +1 -1
- package/ts_build/src/chat/renderer/FancyRenderer.d.ts +4 -0
- package/ts_build/src/chat/renderer/FancyRenderer.js +16 -0
- package/ts_build/src/chat/renderer/FancyRenderer.js.map +1 -1
- package/ts_build/src/chat/renderer/types.d.ts +2 -0
- package/ts_build/src/cli.js +47 -525
- package/ts_build/src/cli.js.map +1 -1
- package/ts_build/src/clients/index.js +2 -4
- package/ts_build/src/clients/index.js.map +1 -1
- package/ts_build/src/commands/agent.d.ts +6 -0
- package/ts_build/src/commands/agent.js +229 -0
- package/ts_build/src/commands/agent.js.map +1 -0
- package/ts_build/src/commands/misc.d.ts +10 -0
- package/ts_build/src/commands/misc.js +197 -0
- package/ts_build/src/commands/misc.js.map +1 -0
- package/ts_build/src/commands/modules.d.ts +3 -0
- package/ts_build/src/commands/modules.js +160 -0
- package/ts_build/src/commands/modules.js.map +1 -0
- package/ts_build/src/commands/services.d.ts +5 -0
- package/ts_build/src/commands/services.js +87 -0
- package/ts_build/src/commands/services.js.map +1 -0
- package/ts_build/src/commands/workers.d.ts +6 -0
- package/ts_build/src/commands/workers.js +163 -0
- package/ts_build/src/commands/workers.js.map +1 -0
- package/ts_build/src/config.d.ts +1 -0
- package/ts_build/src/config.js +32 -0
- package/ts_build/src/config.js.map +1 -1
- package/ts_build/src/index.d.ts +1 -0
- package/ts_build/src/index.js +3 -1
- package/ts_build/src/index.js.map +1 -1
- package/ts_build/src/logger.d.ts +21 -0
- package/ts_build/src/logger.js +106 -0
- package/ts_build/src/logger.js.map +1 -0
- package/ts_build/src/plugins/plugins.d.ts +0 -2
- package/ts_build/src/plugins/plugins.js +0 -11
- package/ts_build/src/plugins/plugins.js.map +1 -1
- package/ts_build/src/processors/JsonCompressor.js +1 -1
- package/ts_build/src/services/EventService.d.ts +6 -1
- package/ts_build/src/services/EventService.js +29 -0
- package/ts_build/src/services/EventService.js.map +1 -1
- package/ts_build/src/services/modules/index.d.ts +33 -0
- package/ts_build/src/services/modules/index.js +46 -45
- package/ts_build/src/services/modules/index.js.map +1 -1
- package/ts_build/src/services/modules/types.d.ts +4 -0
- package/ts_build/src/tunnel.d.ts +27 -0
- package/ts_build/src/tunnel.js +112 -0
- package/ts_build/src/tunnel.js.map +1 -0
- package/ts_build/src/types.d.ts +0 -1
- package/ts_build/src/types.js.map +1 -1
- package/ts_build/src/worker.d.ts +1 -4
- package/ts_build/src/worker.js +38 -244
- package/ts_build/src/worker.js.map +1 -1
- package/ts_build/src/workers/auth/WsMiddleware.d.ts +8 -0
- package/ts_build/src/workers/auth/WsMiddleware.js +65 -0
- package/ts_build/src/workers/auth/WsMiddleware.js.map +1 -0
- package/ts_build/src/workers/auth/authMiddleware.d.ts +3 -0
- package/ts_build/src/workers/auth/authMiddleware.js +60 -0
- package/ts_build/src/workers/auth/authMiddleware.js.map +1 -0
- package/ts_build/src/workers/auth/types.d.ts +8 -1
- package/ts_build/tests/unit/commands/github-credentials.test.d.ts +1 -0
- package/ts_build/tests/unit/commands/github-credentials.test.js +146 -0
- package/ts_build/tests/unit/commands/github-credentials.test.js.map +1 -0
- package/ts_build/tests/unit/modules/moduleLoading.test.js +20 -26
- package/ts_build/tests/unit/modules/moduleLoading.test.js.map +1 -1
- package/ts_build/tests/unit/plugins/pluginLoading.test.js +0 -65
- package/ts_build/tests/unit/plugins/pluginLoading.test.js.map +1 -1
- package/src/agents/tools/executeScript/README.md +0 -94
- package/src/agents/tools/executeScript/definition.ts +0 -79
- package/src/agents/tools/executeScript/examples/dependency-injection-validation.ts +0 -272
- package/src/agents/tools/executeScript/examples/quick-test.ts +0 -74
- package/src/agents/tools/executeScript/examples/serialization-test.ts +0 -321
- package/src/agents/tools/executeScript/examples/test-runner.ts +0 -197
- package/src/agents/tools/executeScript/index.ts +0 -98
- package/src/services/script-execution/SandboxContext.ts +0 -282
- package/src/services/script-execution/ScriptExecutor.ts +0 -441
- package/src/services/script-execution/ScriptPolicy.ts +0 -194
- package/src/services/script-execution/ScriptTracer.ts +0 -249
- package/src/services/script-execution/types.ts +0 -134
- package/ts_build/src/agents/tools/executeScript/definition.d.ts +0 -2
- package/ts_build/src/agents/tools/executeScript/definition.js +0 -76
- package/ts_build/src/agents/tools/executeScript/definition.js.map +0 -1
- package/ts_build/src/agents/tools/executeScript/examples/dependency-injection-validation.d.ts +0 -18
- package/ts_build/src/agents/tools/executeScript/examples/dependency-injection-validation.js +0 -192
- package/ts_build/src/agents/tools/executeScript/examples/dependency-injection-validation.js.map +0 -1
- package/ts_build/src/agents/tools/executeScript/examples/quick-test.d.ts +0 -3
- package/ts_build/src/agents/tools/executeScript/examples/quick-test.js +0 -64
- package/ts_build/src/agents/tools/executeScript/examples/quick-test.js.map +0 -1
- package/ts_build/src/agents/tools/executeScript/examples/serialization-test.d.ts +0 -15
- package/ts_build/src/agents/tools/executeScript/examples/serialization-test.js +0 -266
- package/ts_build/src/agents/tools/executeScript/examples/serialization-test.js.map +0 -1
- package/ts_build/src/agents/tools/executeScript/examples/test-runner.d.ts +0 -4
- package/ts_build/src/agents/tools/executeScript/examples/test-runner.js +0 -208
- package/ts_build/src/agents/tools/executeScript/examples/test-runner.js.map +0 -1
- package/ts_build/src/agents/tools/executeScript/index.d.ts +0 -28
- package/ts_build/src/agents/tools/executeScript/index.js +0 -72
- package/ts_build/src/agents/tools/executeScript/index.js.map +0 -1
- package/ts_build/src/services/script-execution/SandboxContext.d.ts +0 -34
- package/ts_build/src/services/script-execution/SandboxContext.js +0 -189
- package/ts_build/src/services/script-execution/SandboxContext.js.map +0 -1
- package/ts_build/src/services/script-execution/ScriptExecutor.d.ts +0 -19
- package/ts_build/src/services/script-execution/ScriptExecutor.js +0 -269
- package/ts_build/src/services/script-execution/ScriptExecutor.js.map +0 -1
- package/ts_build/src/services/script-execution/ScriptPolicy.d.ts +0 -28
- package/ts_build/src/services/script-execution/ScriptPolicy.js +0 -115
- package/ts_build/src/services/script-execution/ScriptPolicy.js.map +0 -1
- package/ts_build/src/services/script-execution/ScriptTracer.d.ts +0 -19
- package/ts_build/src/services/script-execution/ScriptTracer.js +0 -186
- package/ts_build/src/services/script-execution/ScriptTracer.js.map +0 -1
- package/ts_build/src/services/script-execution/types.d.ts +0 -108
- package/ts_build/src/services/script-execution/types.js +0 -3
- package/ts_build/src/services/script-execution/types.js.map +0 -1
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { LogLevel } from "./services/EventService";
|
|
2
|
+
export interface BoundLogger {
|
|
3
|
+
log(message: string, level?: LogLevel): void;
|
|
4
|
+
info(message: string): void;
|
|
5
|
+
warn(message: string): void;
|
|
6
|
+
error(message: string): void;
|
|
7
|
+
}
|
|
8
|
+
export declare const logger: {
|
|
9
|
+
log(source: string, message: string, level?: LogLevel): void;
|
|
10
|
+
info(source: string, message: string): void;
|
|
11
|
+
warn(source: string, message: string): void;
|
|
12
|
+
error(source: string, message: string): void;
|
|
13
|
+
silence(): void;
|
|
14
|
+
unsilence(): void;
|
|
15
|
+
isSilenced(): boolean;
|
|
16
|
+
installConsoleOverload(): void;
|
|
17
|
+
uninstallConsoleOverload(): void;
|
|
18
|
+
};
|
|
19
|
+
export declare const Logger: {
|
|
20
|
+
of(source: string): BoundLogger;
|
|
21
|
+
};
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Logger = exports.logger = void 0;
|
|
4
|
+
let silenced = false;
|
|
5
|
+
const _originalConsole = {
|
|
6
|
+
log: console.log.bind(console),
|
|
7
|
+
warn: console.warn.bind(console),
|
|
8
|
+
error: console.error.bind(console),
|
|
9
|
+
info: console.info.bind(console),
|
|
10
|
+
};
|
|
11
|
+
let consoleOverloadInstalled = false;
|
|
12
|
+
function getEvents() {
|
|
13
|
+
try {
|
|
14
|
+
const { services } = require("./services");
|
|
15
|
+
return services().Events;
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
function emit(source, message, level) {
|
|
22
|
+
if (silenced)
|
|
23
|
+
return;
|
|
24
|
+
try {
|
|
25
|
+
const events = getEvents();
|
|
26
|
+
if (events) {
|
|
27
|
+
events.log(source, message, level);
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
catch {
|
|
32
|
+
}
|
|
33
|
+
const prefix = source ? `[${source}] ` : "";
|
|
34
|
+
if (level === "warn")
|
|
35
|
+
_originalConsole.warn(`${prefix}${message}`);
|
|
36
|
+
else if (level === "error")
|
|
37
|
+
_originalConsole.error(`${prefix}${message}`);
|
|
38
|
+
else
|
|
39
|
+
_originalConsole.log(`${prefix}${message}`);
|
|
40
|
+
}
|
|
41
|
+
function makeBoundLogger(source) {
|
|
42
|
+
return {
|
|
43
|
+
log(message, level = "info") {
|
|
44
|
+
emit(source, message, level);
|
|
45
|
+
},
|
|
46
|
+
info(message) {
|
|
47
|
+
emit(source, message, "info");
|
|
48
|
+
},
|
|
49
|
+
warn(message) {
|
|
50
|
+
emit(source, message, "warn");
|
|
51
|
+
},
|
|
52
|
+
error(message) {
|
|
53
|
+
emit(source, message, "error");
|
|
54
|
+
},
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
exports.logger = {
|
|
58
|
+
log(source, message, level = "info") {
|
|
59
|
+
emit(source, message, level);
|
|
60
|
+
},
|
|
61
|
+
info(source, message) {
|
|
62
|
+
emit(source, message, "info");
|
|
63
|
+
},
|
|
64
|
+
warn(source, message) {
|
|
65
|
+
emit(source, message, "warn");
|
|
66
|
+
},
|
|
67
|
+
error(source, message) {
|
|
68
|
+
emit(source, message, "error");
|
|
69
|
+
},
|
|
70
|
+
silence() {
|
|
71
|
+
silenced = true;
|
|
72
|
+
},
|
|
73
|
+
unsilence() {
|
|
74
|
+
silenced = false;
|
|
75
|
+
},
|
|
76
|
+
isSilenced() {
|
|
77
|
+
return silenced;
|
|
78
|
+
},
|
|
79
|
+
installConsoleOverload() {
|
|
80
|
+
if (consoleOverloadInstalled)
|
|
81
|
+
return;
|
|
82
|
+
consoleOverloadInstalled = true;
|
|
83
|
+
const route = (originalFn, args) => {
|
|
84
|
+
if (silenced)
|
|
85
|
+
return;
|
|
86
|
+
originalFn(...args);
|
|
87
|
+
};
|
|
88
|
+
console.log = (...args) => route(_originalConsole.log, args);
|
|
89
|
+
console.info = (...args) => route(_originalConsole.info, args);
|
|
90
|
+
console.warn = (...args) => route(_originalConsole.warn, args);
|
|
91
|
+
},
|
|
92
|
+
uninstallConsoleOverload() {
|
|
93
|
+
if (!consoleOverloadInstalled)
|
|
94
|
+
return;
|
|
95
|
+
console.log = _originalConsole.log;
|
|
96
|
+
console.info = _originalConsole.info;
|
|
97
|
+
console.warn = _originalConsole.warn;
|
|
98
|
+
consoleOverloadInstalled = false;
|
|
99
|
+
},
|
|
100
|
+
};
|
|
101
|
+
exports.Logger = {
|
|
102
|
+
of(source) {
|
|
103
|
+
return makeBoundLogger(source);
|
|
104
|
+
},
|
|
105
|
+
};
|
|
106
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { Plugin, PluginContext } from "./types";
|
|
2
|
-
import { Config } from "../types";
|
|
3
2
|
export declare class PluginService {
|
|
4
3
|
private pluginMap;
|
|
5
4
|
private events?;
|
|
6
5
|
constructor(context: PluginContext);
|
|
7
6
|
loadPlugin(spec: string): Promise<string>;
|
|
8
|
-
loadPluginsFromConfig(config: Config): Promise<void>;
|
|
9
7
|
disablePlugin(key: string): boolean;
|
|
10
8
|
enablePlugin(key: string): boolean;
|
|
11
9
|
listPlugins(): string[];
|
|
@@ -67,17 +67,6 @@ class PluginService {
|
|
|
67
67
|
this.pluginMap.set(instance.meta.key, instance);
|
|
68
68
|
return instance.meta.key;
|
|
69
69
|
}
|
|
70
|
-
async loadPluginsFromConfig(config) {
|
|
71
|
-
const pluginPackages = config.pluginPackages || {};
|
|
72
|
-
for (const [key, spec] of Object.entries(pluginPackages)) {
|
|
73
|
-
try {
|
|
74
|
-
await this.loadPlugin(spec);
|
|
75
|
-
}
|
|
76
|
-
catch (error) {
|
|
77
|
-
this.events?.log("PluginService", `Failed to load plugin "${key}" from "${spec}": ${error instanceof Error ? error.message : error}`, "warn");
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
70
|
disablePlugin(key) {
|
|
82
71
|
const p = this.pluginMap.get(key);
|
|
83
72
|
if (!p)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugins.js","sourceRoot":"","sources":["../../../src/plugins/plugins.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"plugins.js","sourceRoot":"","sources":["../../../src/plugins/plugins.ts"],"names":[],"mappings":"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"}
|
|
@@ -246,7 +246,7 @@ class JsonCompressor {
|
|
|
246
246
|
}
|
|
247
247
|
const seenCount = this.objectSeenCount.get(objHash) || 0;
|
|
248
248
|
this.objectSeenCount.set(objHash, seenCount + 1);
|
|
249
|
-
const isFirstOccurrence = seenCount ===
|
|
249
|
+
const isFirstOccurrence = seenCount === 0;
|
|
250
250
|
const objWithLowSignalCompressed = this.compressObjectWithLowSignalDetection(obj, path);
|
|
251
251
|
const objToProcess = objWithLowSignalCompressed !== obj ? objWithLowSignalCompressed : obj;
|
|
252
252
|
const result = {};
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { EventEmitter } from "events";
|
|
2
2
|
import { IAgent } from "../agents/interface";
|
|
3
|
+
export type LogLevel = "info" | "warn" | "error";
|
|
3
4
|
export type EventHandlerFn = (...args: any[]) => any;
|
|
4
5
|
export interface EventHandler {
|
|
5
6
|
handler: EventHandlerFn;
|
|
@@ -20,6 +21,8 @@ export interface AgentLogEvent {
|
|
|
20
21
|
export declare class EventService extends EventEmitter {
|
|
21
22
|
private blockingHandlers;
|
|
22
23
|
private managedListeners;
|
|
24
|
+
private defaultLoggerActive;
|
|
25
|
+
private boundDefaultLogHandler;
|
|
23
26
|
eventTypes: {
|
|
24
27
|
agentMsg: string;
|
|
25
28
|
agentsRegister: string;
|
|
@@ -27,6 +30,8 @@ export declare class EventService extends EventEmitter {
|
|
|
27
30
|
pluginLog: string;
|
|
28
31
|
};
|
|
29
32
|
constructor();
|
|
33
|
+
suppressDefaultLogger(): void;
|
|
34
|
+
restoreDefaultLogger(): void;
|
|
30
35
|
onBlocking(event: string, handler: EventHandlerFn): void;
|
|
31
36
|
offBlocking(event: string, handler: EventHandlerFn): void;
|
|
32
37
|
setListener(spec: ManagedListenerSpec, handler: EventHandlerFn): void;
|
|
@@ -38,5 +43,5 @@ export declare class EventService extends EventEmitter {
|
|
|
38
43
|
emitNonBlocking(event: string, ...args: any[]): Promise<any[]>;
|
|
39
44
|
registerAgent(agent: IAgent): void;
|
|
40
45
|
callAgent(name: string, query: string): Promise<string>;
|
|
41
|
-
log(source: string, message: string, level?:
|
|
46
|
+
log(source: string, message: string, level?: LogLevel): void;
|
|
42
47
|
}
|
|
@@ -2,9 +2,25 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.EventService = void 0;
|
|
4
4
|
const events_1 = require("events");
|
|
5
|
+
function defaultConsoleLogHandler(event) {
|
|
6
|
+
const prefix = event.source ? `[${event.source}] ` : "";
|
|
7
|
+
const line = `${prefix}${event.message}\n`;
|
|
8
|
+
switch (event.level) {
|
|
9
|
+
case "warn":
|
|
10
|
+
process.stderr.write(line);
|
|
11
|
+
break;
|
|
12
|
+
case "error":
|
|
13
|
+
process.stderr.write(line);
|
|
14
|
+
break;
|
|
15
|
+
default:
|
|
16
|
+
process.stdout.write(line);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
5
19
|
class EventService extends events_1.EventEmitter {
|
|
6
20
|
blockingHandlers = new Map();
|
|
7
21
|
managedListeners = new Map();
|
|
22
|
+
defaultLoggerActive = true;
|
|
23
|
+
boundDefaultLogHandler = defaultConsoleLogHandler;
|
|
8
24
|
eventTypes = {
|
|
9
25
|
agentMsg: "agent:msg",
|
|
10
26
|
agentsRegister: "agents:register",
|
|
@@ -14,6 +30,19 @@ class EventService extends events_1.EventEmitter {
|
|
|
14
30
|
constructor() {
|
|
15
31
|
super();
|
|
16
32
|
this.setMaxListeners(100);
|
|
33
|
+
this.on(this.eventTypes.pluginLog, this.boundDefaultLogHandler);
|
|
34
|
+
}
|
|
35
|
+
suppressDefaultLogger() {
|
|
36
|
+
if (this.defaultLoggerActive) {
|
|
37
|
+
this.removeListener(this.eventTypes.pluginLog, this.boundDefaultLogHandler);
|
|
38
|
+
this.defaultLoggerActive = false;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
restoreDefaultLogger() {
|
|
42
|
+
if (!this.defaultLoggerActive) {
|
|
43
|
+
this.on(this.eventTypes.pluginLog, this.boundDefaultLogHandler);
|
|
44
|
+
this.defaultLoggerActive = true;
|
|
45
|
+
}
|
|
17
46
|
}
|
|
18
47
|
onBlocking(event, handler) {
|
|
19
48
|
if (!this.blockingHandlers.has(event)) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EventService.js","sourceRoot":"","sources":["../../../src/services/EventService.ts"],"names":[],"mappings":";;;AAAA,mCAAsC;
|
|
1
|
+
{"version":3,"file":"EventService.js","sourceRoot":"","sources":["../../../src/services/EventService.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,37 @@
|
|
|
1
1
|
import { ModuleContext } from "./types";
|
|
2
2
|
export declare class ModulesService {
|
|
3
|
+
getDefaultContext(): Promise<{
|
|
4
|
+
Tools: import("../Tools").ToolsService;
|
|
5
|
+
Events: import("../EventService").EventService;
|
|
6
|
+
Agents: import("../AgentService").AgentService;
|
|
7
|
+
Embeddings: import("../EmbeddingsService").EmbeddingsService;
|
|
8
|
+
Flags: import("../flags").FlagsService;
|
|
9
|
+
Mcp: import("../Mcp").McpService;
|
|
10
|
+
AwsS3: import("../S3").S3Service;
|
|
11
|
+
Docker: import("../DockerService").DockerService;
|
|
12
|
+
knowhowApiClient: import("../KnowhowClient").KnowhowSimpleClient;
|
|
13
|
+
Plugins: import("../../plugins/plugins").PluginService;
|
|
14
|
+
Clients: import("../../clients").AIClient;
|
|
15
|
+
MediaProcessor: import("../MediaProcessorService").MediaProcessorService;
|
|
16
|
+
}>;
|
|
17
|
+
overrideDefaultContext(overrides: Partial<ModuleContext>): Promise<{
|
|
18
|
+
Agents: import("../AgentService").AgentService;
|
|
19
|
+
Embeddings: import("../EmbeddingsService").EmbeddingsService;
|
|
20
|
+
Plugins: import("../../plugins/plugins").PluginService;
|
|
21
|
+
Clients: import("../../clients").AIClient;
|
|
22
|
+
Tools: import("../Tools").ToolsService;
|
|
23
|
+
Events: import("../EventService").EventService;
|
|
24
|
+
MediaProcessor: import("../MediaProcessorService").MediaProcessorService;
|
|
25
|
+
Tunnel?: import("@tyvm/knowhow-tunnel").TunnelHandler;
|
|
26
|
+
Program?: import("node_modules/commander/typings").Command;
|
|
27
|
+
Flags: import("../flags").FlagsService;
|
|
28
|
+
Mcp: import("../Mcp").McpService;
|
|
29
|
+
AwsS3: import("../S3").S3Service;
|
|
30
|
+
Docker: import("../DockerService").DockerService;
|
|
31
|
+
knowhowApiClient: import("../KnowhowClient").KnowhowSimpleClient;
|
|
32
|
+
}>;
|
|
33
|
+
loadModulesFrom(config: {
|
|
34
|
+
modules: string[];
|
|
35
|
+
} & any, context?: Partial<ModuleContext>): Promise<void>;
|
|
3
36
|
loadModulesFromConfig(context?: ModuleContext): Promise<void>;
|
|
4
37
|
}
|
|
@@ -34,67 +34,68 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
36
|
exports.ModulesService = void 0;
|
|
37
|
+
const path = __importStar(require("path"));
|
|
37
38
|
const config_1 = require("../../config");
|
|
38
39
|
const __1 = require("../");
|
|
39
|
-
const
|
|
40
|
+
const utils_1 = require("../../utils");
|
|
40
41
|
class ModulesService {
|
|
41
|
-
async
|
|
42
|
-
|
|
42
|
+
async getDefaultContext() {
|
|
43
|
+
return { ...(0, __1.services)() };
|
|
44
|
+
}
|
|
45
|
+
async overrideDefaultContext(overrides) {
|
|
46
|
+
const defaultContext = await this.getDefaultContext();
|
|
47
|
+
return { ...defaultContext, ...overrides };
|
|
48
|
+
}
|
|
49
|
+
async loadModulesFrom(config, context) {
|
|
43
50
|
if (!context) {
|
|
44
|
-
|
|
45
|
-
context = {
|
|
46
|
-
Agents,
|
|
47
|
-
Embeddings,
|
|
48
|
-
Plugins,
|
|
49
|
-
Clients,
|
|
50
|
-
Tools,
|
|
51
|
-
MediaProcessor,
|
|
52
|
-
};
|
|
51
|
+
context = { ...(await this.getDefaultContext()) };
|
|
53
52
|
}
|
|
54
|
-
const
|
|
55
|
-
const agentService = context.Agents;
|
|
56
|
-
const pluginService = context.Plugins;
|
|
57
|
-
const clients = context.Clients;
|
|
58
|
-
const globalConfig = await (0, config_1.getGlobalConfig)();
|
|
59
|
-
const allModulePaths = [
|
|
60
|
-
...(globalConfig.modules || []),
|
|
61
|
-
...(config.modules || []),
|
|
62
|
-
];
|
|
53
|
+
const allModulePaths = config.modules;
|
|
63
54
|
for (const modulePath of allModulePaths) {
|
|
64
55
|
const resolvedPath = modulePath.startsWith(".")
|
|
65
56
|
? path.resolve(process.cwd(), modulePath)
|
|
66
57
|
: modulePath;
|
|
67
58
|
const rawModule = require(resolvedPath);
|
|
68
59
|
const importedModule = (rawModule.default || rawModule);
|
|
69
|
-
|
|
70
|
-
await importedModule.init({
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
60
|
+
context.Events?.log("ModulesService", `🔌 Loading module: ${modulePath} (resolved: ${resolvedPath})`);
|
|
61
|
+
await importedModule.init({
|
|
62
|
+
config,
|
|
63
|
+
cwd: process.cwd(),
|
|
64
|
+
context: context,
|
|
65
|
+
});
|
|
66
|
+
context.Events?.log("ModulesService", `✅ Module initialized: ${modulePath} (tools: ${importedModule.tools.length}, agents: ${importedModule.agents.length}, plugins: ${importedModule.plugins.length}, clients: ${importedModule.clients.length})`);
|
|
67
|
+
if (context.Agents) {
|
|
68
|
+
for (const agent of importedModule.agents) {
|
|
69
|
+
context.Agents.registerAgent(agent);
|
|
70
|
+
}
|
|
74
71
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
72
|
+
if (context.Tools) {
|
|
73
|
+
for (const tool of importedModule.tools) {
|
|
74
|
+
context.Tools.addTool(tool.definition);
|
|
75
|
+
context.Tools.setFunction(tool.definition.function.name, tool.handler);
|
|
76
|
+
}
|
|
78
77
|
}
|
|
79
|
-
|
|
80
|
-
const
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
Tools: toolsService,
|
|
84
|
-
Plugins: pluginService,
|
|
85
|
-
...(context.MediaProcessor ? { MediaProcessor: context.MediaProcessor } : {}),
|
|
86
|
-
};
|
|
87
|
-
pluginService.registerPlugin(plugin.name, new plugin.plugin(pluginContext));
|
|
78
|
+
if (context.Plugins) {
|
|
79
|
+
for (const plugin of importedModule.plugins) {
|
|
80
|
+
context.Plugins.registerPlugin(plugin.name, new plugin.plugin(context));
|
|
81
|
+
}
|
|
88
82
|
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
83
|
+
if (context.Clients) {
|
|
84
|
+
for (const client of importedModule.clients) {
|
|
85
|
+
context.Clients.registerClient(client.provider, client.client);
|
|
86
|
+
context.Clients.registerModels(client.provider, client.models);
|
|
87
|
+
}
|
|
92
88
|
}
|
|
93
89
|
}
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
90
|
+
}
|
|
91
|
+
async loadModulesFromConfig(context) {
|
|
92
|
+
const config = await (0, config_1.getConfig)();
|
|
93
|
+
const globalConfig = await (0, config_1.getGlobalConfig)();
|
|
94
|
+
const allModulePaths = [
|
|
95
|
+
...(globalConfig.modules || []),
|
|
96
|
+
...(config.modules || []),
|
|
97
|
+
];
|
|
98
|
+
return this.loadModulesFrom({ ...config, modules: (0, utils_1.toUniqueArray)(allModulePaths) }, context);
|
|
98
99
|
}
|
|
99
100
|
}
|
|
100
101
|
exports.ModulesService = ModulesService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/services/modules/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,yCAA0D;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/services/modules/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Plugin, PluginContext } from "../../plugins/types";
|
|
2
|
+
import { Command } from "commander";
|
|
2
3
|
import { IAgent } from "../../agents/interface";
|
|
3
4
|
import { Tool } from "../../clients/types";
|
|
4
5
|
import { Config } from "../../types";
|
|
@@ -10,6 +11,7 @@ import { AIClient } from "../../clients";
|
|
|
10
11
|
import { ToolsService } from "../Tools";
|
|
11
12
|
import { MediaProcessorService } from "../MediaProcessorService";
|
|
12
13
|
import { TunnelHandler } from "@tyvm/knowhow-tunnel";
|
|
14
|
+
import { EventService } from "../EventService";
|
|
13
15
|
export interface ModuleChatCommand {
|
|
14
16
|
name: string;
|
|
15
17
|
description: string;
|
|
@@ -42,8 +44,10 @@ export interface ModuleContext {
|
|
|
42
44
|
Plugins: PluginService;
|
|
43
45
|
Clients: AIClient;
|
|
44
46
|
Tools: ToolsService;
|
|
47
|
+
Events: EventService;
|
|
45
48
|
MediaProcessor?: MediaProcessorService;
|
|
46
49
|
Tunnel?: TunnelHandler;
|
|
50
|
+
Program?: Command;
|
|
47
51
|
}
|
|
48
52
|
export interface KnowhowModule {
|
|
49
53
|
init: (params: InitParams) => Promise<void>;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { WebSocket } from "ws";
|
|
2
|
+
import { createTunnelHandler, TunnelHandler } from "@tyvm/knowhow-tunnel";
|
|
3
|
+
import { getConfig } from "./config";
|
|
4
|
+
import { WorkerPasskeyAuthService } from "./workers/auth/WorkerPasskeyAuth";
|
|
5
|
+
export declare function extractTunnelDomain(apiUrl: string): {
|
|
6
|
+
domain: string;
|
|
7
|
+
useHttps: boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare function initTunnelHandler(tunnelConnection: WebSocket, tunnelConfig: Parameters<typeof createTunnelHandler>[1]): Promise<TunnelHandler>;
|
|
10
|
+
export declare function resolveTunnelConfig(config: Awaited<ReturnType<typeof getConfig>>, isInsideDocker: boolean): {
|
|
11
|
+
tunnelLocalHost: string;
|
|
12
|
+
portMapping: Record<string, number>;
|
|
13
|
+
};
|
|
14
|
+
export interface TunnelWebSocketOptions {
|
|
15
|
+
tunnelDomain: string;
|
|
16
|
+
tunnelUseHttps: boolean;
|
|
17
|
+
tunnelLocalHost: string;
|
|
18
|
+
portMapping: Record<string, number>;
|
|
19
|
+
config: Awaited<ReturnType<typeof getConfig>>;
|
|
20
|
+
headers: Record<string, string>;
|
|
21
|
+
onOpen?: (handler: TunnelHandler) => void;
|
|
22
|
+
onClose?: (code: number, reason: string) => void;
|
|
23
|
+
onError?: (error: Error) => void;
|
|
24
|
+
authService?: WorkerPasskeyAuthService | null;
|
|
25
|
+
}
|
|
26
|
+
export declare function connectTunnelWebSocket(options: TunnelWebSocketOptions): WebSocket;
|
|
27
|
+
export declare const TUNNEL_MINIMAL_TOOLS: string[];
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TUNNEL_MINIMAL_TOOLS = void 0;
|
|
4
|
+
exports.extractTunnelDomain = extractTunnelDomain;
|
|
5
|
+
exports.initTunnelHandler = initTunnelHandler;
|
|
6
|
+
exports.resolveTunnelConfig = resolveTunnelConfig;
|
|
7
|
+
exports.connectTunnelWebSocket = connectTunnelWebSocket;
|
|
8
|
+
const ws_1 = require("ws");
|
|
9
|
+
const knowhow_tunnel_1 = require("@tyvm/knowhow-tunnel");
|
|
10
|
+
const KnowhowClient_1 = require("./services/KnowhowClient");
|
|
11
|
+
const modules_1 = require("./services/modules");
|
|
12
|
+
const WsMiddleware_1 = require("./workers/auth/WsMiddleware");
|
|
13
|
+
const authMiddleware_1 = require("./workers/auth/authMiddleware");
|
|
14
|
+
function extractTunnelDomain(apiUrl) {
|
|
15
|
+
try {
|
|
16
|
+
const url = new URL(apiUrl);
|
|
17
|
+
const useHttps = url.protocol === "https:";
|
|
18
|
+
if (url.hostname === "localhost" || url.hostname === "127.0.0.1") {
|
|
19
|
+
return {
|
|
20
|
+
domain: `worker.${url.hostname}:${url.port || "80"}`,
|
|
21
|
+
useHttps,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
return { domain: `worker.${url.hostname}`, useHttps };
|
|
25
|
+
}
|
|
26
|
+
catch (err) {
|
|
27
|
+
console.error("Failed to parse API_URL for tunnel domain:", err);
|
|
28
|
+
return { domain: "worker.localhost:4000", useHttps: false };
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
async function initTunnelHandler(tunnelConnection, tunnelConfig) {
|
|
32
|
+
const handler = (0, knowhow_tunnel_1.createTunnelHandler)(tunnelConnection, tunnelConfig);
|
|
33
|
+
console.log("🌐 Tunnel handler initialized");
|
|
34
|
+
console.log(tunnelConfig);
|
|
35
|
+
const tunnelModuleService = new modules_1.ModulesService();
|
|
36
|
+
const tunnelContext = await tunnelModuleService.overrideDefaultContext({
|
|
37
|
+
Tunnel: handler,
|
|
38
|
+
});
|
|
39
|
+
tunnelModuleService.loadModulesFromConfig(tunnelContext).catch((err) => {
|
|
40
|
+
console.error("Failed to load tunnel modules:", err);
|
|
41
|
+
});
|
|
42
|
+
return handler;
|
|
43
|
+
}
|
|
44
|
+
function resolveTunnelConfig(config, isInsideDocker) {
|
|
45
|
+
let tunnelLocalHost = config.worker?.tunnel?.localHost;
|
|
46
|
+
if (!tunnelLocalHost) {
|
|
47
|
+
if (isInsideDocker) {
|
|
48
|
+
tunnelLocalHost = "host.docker.internal";
|
|
49
|
+
console.log("🐳 Docker detected: tunnel will use host.docker.internal to reach host services");
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
tunnelLocalHost = "127.0.0.1";
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
const portMapping = (config.worker?.tunnel?.portMapping || {});
|
|
56
|
+
if (Object.keys(portMapping).length > 0) {
|
|
57
|
+
console.log("🔀 Port mapping configured:");
|
|
58
|
+
for (const [containerPort, hostPort] of Object.entries(portMapping)) {
|
|
59
|
+
console.log(` Container port ${containerPort} → Host port ${hostPort}`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return { tunnelLocalHost, portMapping };
|
|
63
|
+
}
|
|
64
|
+
function connectTunnelWebSocket(options) {
|
|
65
|
+
const { tunnelDomain, tunnelUseHttps, tunnelLocalHost, portMapping, config, headers, onOpen, onClose, onError, authService, } = options;
|
|
66
|
+
const tunnelConnection = new ws_1.WebSocket(`${KnowhowClient_1.KNOWHOW_API_URL}/ws/tunnel`, { headers });
|
|
67
|
+
tunnelConnection.on("open", async () => {
|
|
68
|
+
console.log("Tunnel WebSocket connected");
|
|
69
|
+
if (authService) {
|
|
70
|
+
const stack = new WsMiddleware_1.WsMiddlewareStack();
|
|
71
|
+
stack.use((0, authMiddleware_1.makeAuthMiddleware)(authService));
|
|
72
|
+
stack.wrapSocket(tunnelConnection);
|
|
73
|
+
}
|
|
74
|
+
const allowedPorts = config.worker?.tunnel?.allowedPorts || [];
|
|
75
|
+
const urlRewriter = (port, metadata) => {
|
|
76
|
+
const workerId = metadata?.workerId;
|
|
77
|
+
const secret = metadata?.secret;
|
|
78
|
+
const subdomain = secret
|
|
79
|
+
? `${secret}-p${port}`
|
|
80
|
+
: `${workerId}-p${port}`;
|
|
81
|
+
return `${subdomain}.${tunnelDomain}`;
|
|
82
|
+
};
|
|
83
|
+
const tunnelConfig = {
|
|
84
|
+
allowedPorts,
|
|
85
|
+
maxConcurrentStreams: config.worker?.tunnel?.maxConcurrentStreams || 50,
|
|
86
|
+
tunnelUseHttps,
|
|
87
|
+
localHost: tunnelLocalHost,
|
|
88
|
+
urlRewriter,
|
|
89
|
+
enableUrlRewriting: config.worker?.tunnel?.enableUrlRewriting !== false,
|
|
90
|
+
portMapping,
|
|
91
|
+
logLevel: "debug",
|
|
92
|
+
};
|
|
93
|
+
const handler = await initTunnelHandler(tunnelConnection, tunnelConfig);
|
|
94
|
+
onOpen?.(handler);
|
|
95
|
+
});
|
|
96
|
+
tunnelConnection.on("close", (code, reason) => {
|
|
97
|
+
console.log(`Tunnel WebSocket closed. Code: ${code}, Reason: ${reason.toString()}`);
|
|
98
|
+
onClose?.(code, reason.toString());
|
|
99
|
+
});
|
|
100
|
+
tunnelConnection.on("error", (error) => {
|
|
101
|
+
console.error("Tunnel WebSocket error:", error);
|
|
102
|
+
onError?.(error);
|
|
103
|
+
});
|
|
104
|
+
return tunnelConnection;
|
|
105
|
+
}
|
|
106
|
+
exports.TUNNEL_MINIMAL_TOOLS = [
|
|
107
|
+
"listAllowedPorts",
|
|
108
|
+
"unlock",
|
|
109
|
+
"lock",
|
|
110
|
+
"reloadConfig",
|
|
111
|
+
];
|
|
112
|
+
//# sourceMappingURL=tunnel.js.map
|