joonecli 0.1.0
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/AGENTS.md +56 -0
- package/Handover.md +115 -0
- package/LICENSE +201 -0
- package/PROGRESS.md +160 -0
- package/README.md +114 -0
- package/dist/__tests__/bootstrap.test.d.ts +1 -0
- package/dist/__tests__/bootstrap.test.js +76 -0
- package/dist/__tests__/bootstrap.test.js.map +1 -0
- package/dist/__tests__/config.test.d.ts +1 -0
- package/dist/__tests__/config.test.js +84 -0
- package/dist/__tests__/config.test.js.map +1 -0
- package/dist/__tests__/m55.test.d.ts +1 -0
- package/dist/__tests__/m55.test.js +160 -0
- package/dist/__tests__/m55.test.js.map +1 -0
- package/dist/__tests__/middleware.test.d.ts +1 -0
- package/dist/__tests__/middleware.test.js +169 -0
- package/dist/__tests__/middleware.test.js.map +1 -0
- package/dist/__tests__/modelFactory.test.d.ts +1 -0
- package/dist/__tests__/modelFactory.test.js +50 -0
- package/dist/__tests__/modelFactory.test.js.map +1 -0
- package/dist/__tests__/optimizations.test.d.ts +1 -0
- package/dist/__tests__/optimizations.test.js +136 -0
- package/dist/__tests__/optimizations.test.js.map +1 -0
- package/dist/__tests__/promptBuilder.test.d.ts +1 -0
- package/dist/__tests__/promptBuilder.test.js +108 -0
- package/dist/__tests__/promptBuilder.test.js.map +1 -0
- package/dist/__tests__/sandbox.test.d.ts +1 -0
- package/dist/__tests__/sandbox.test.js +78 -0
- package/dist/__tests__/sandbox.test.js.map +1 -0
- package/dist/__tests__/security.test.d.ts +1 -0
- package/dist/__tests__/security.test.js +86 -0
- package/dist/__tests__/security.test.js.map +1 -0
- package/dist/__tests__/streaming.test.d.ts +1 -0
- package/dist/__tests__/streaming.test.js +71 -0
- package/dist/__tests__/streaming.test.js.map +1 -0
- package/dist/__tests__/toolRouter.test.d.ts +1 -0
- package/dist/__tests__/toolRouter.test.js +37 -0
- package/dist/__tests__/toolRouter.test.js.map +1 -0
- package/dist/__tests__/tools.test.d.ts +1 -0
- package/dist/__tests__/tools.test.js +112 -0
- package/dist/__tests__/tools.test.js.map +1 -0
- package/dist/__tests__/tracing.test.d.ts +1 -0
- package/dist/__tests__/tracing.test.js +147 -0
- package/dist/__tests__/tracing.test.js.map +1 -0
- package/dist/cli/config.d.ts +49 -0
- package/dist/cli/config.js +86 -0
- package/dist/cli/config.js.map +1 -0
- package/dist/cli/index.d.ts +2 -0
- package/dist/cli/index.js +625 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/modelFactory.d.ts +9 -0
- package/dist/cli/modelFactory.js +154 -0
- package/dist/cli/modelFactory.js.map +1 -0
- package/dist/cli/providers.d.ts +18 -0
- package/dist/cli/providers.js +94 -0
- package/dist/cli/providers.js.map +1 -0
- package/dist/core/agentLoop.d.ts +43 -0
- package/dist/core/agentLoop.js +245 -0
- package/dist/core/agentLoop.js.map +1 -0
- package/dist/core/errors.d.ts +62 -0
- package/dist/core/errors.js +139 -0
- package/dist/core/errors.js.map +1 -0
- package/dist/core/promptBuilder.d.ts +49 -0
- package/dist/core/promptBuilder.js +84 -0
- package/dist/core/promptBuilder.js.map +1 -0
- package/dist/core/reasoningRouter.d.ts +62 -0
- package/dist/core/reasoningRouter.js +102 -0
- package/dist/core/reasoningRouter.js.map +1 -0
- package/dist/core/retry.d.ts +25 -0
- package/dist/core/retry.js +49 -0
- package/dist/core/retry.js.map +1 -0
- package/dist/core/sessionResumer.d.ts +17 -0
- package/dist/core/sessionResumer.js +78 -0
- package/dist/core/sessionResumer.js.map +1 -0
- package/dist/core/sessionStore.d.ts +45 -0
- package/dist/core/sessionStore.js +167 -0
- package/dist/core/sessionStore.js.map +1 -0
- package/dist/core/tokenCounter.d.ts +17 -0
- package/dist/core/tokenCounter.js +54 -0
- package/dist/core/tokenCounter.js.map +1 -0
- package/dist/evals/dataset.d.ts +4 -0
- package/dist/evals/dataset.js +61 -0
- package/dist/evals/dataset.js.map +1 -0
- package/dist/evals/evaluator.d.ts +21 -0
- package/dist/evals/evaluator.js +68 -0
- package/dist/evals/evaluator.js.map +1 -0
- package/dist/hitl/bridge.d.ts +65 -0
- package/dist/hitl/bridge.js +120 -0
- package/dist/hitl/bridge.js.map +1 -0
- package/dist/middleware/commandSanitizer.d.ts +18 -0
- package/dist/middleware/commandSanitizer.js +50 -0
- package/dist/middleware/commandSanitizer.js.map +1 -0
- package/dist/middleware/loopDetection.d.ts +28 -0
- package/dist/middleware/loopDetection.js +49 -0
- package/dist/middleware/loopDetection.js.map +1 -0
- package/dist/middleware/permission.d.ts +17 -0
- package/dist/middleware/permission.js +59 -0
- package/dist/middleware/permission.js.map +1 -0
- package/dist/middleware/pipeline.d.ts +31 -0
- package/dist/middleware/pipeline.js +62 -0
- package/dist/middleware/pipeline.js.map +1 -0
- package/dist/middleware/preCompletion.d.ts +29 -0
- package/dist/middleware/preCompletion.js +82 -0
- package/dist/middleware/preCompletion.js.map +1 -0
- package/dist/middleware/types.d.ts +40 -0
- package/dist/middleware/types.js +8 -0
- package/dist/middleware/types.js.map +1 -0
- package/dist/sandbox/bootstrap.d.ts +38 -0
- package/dist/sandbox/bootstrap.js +107 -0
- package/dist/sandbox/bootstrap.js.map +1 -0
- package/dist/sandbox/manager.d.ts +72 -0
- package/dist/sandbox/manager.js +180 -0
- package/dist/sandbox/manager.js.map +1 -0
- package/dist/sandbox/sync.d.ts +55 -0
- package/dist/sandbox/sync.js +135 -0
- package/dist/sandbox/sync.js.map +1 -0
- package/dist/skills/loader.d.ts +55 -0
- package/dist/skills/loader.js +132 -0
- package/dist/skills/loader.js.map +1 -0
- package/dist/skills/tools.d.ts +5 -0
- package/dist/skills/tools.js +78 -0
- package/dist/skills/tools.js.map +1 -0
- package/dist/skills/types.d.ts +13 -0
- package/dist/skills/types.js +2 -0
- package/dist/skills/types.js.map +1 -0
- package/dist/test_cache.d.ts +1 -0
- package/dist/test_cache.js +55 -0
- package/dist/test_cache.js.map +1 -0
- package/dist/test_google.js +93 -0
- package/dist/tools/askUser.d.ts +10 -0
- package/dist/tools/askUser.js +42 -0
- package/dist/tools/askUser.js.map +1 -0
- package/dist/tools/browser.d.ts +19 -0
- package/dist/tools/browser.js +111 -0
- package/dist/tools/browser.js.map +1 -0
- package/dist/tools/index.d.ts +27 -0
- package/dist/tools/index.js +184 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/registry.d.ts +31 -0
- package/dist/tools/registry.js +168 -0
- package/dist/tools/registry.js.map +1 -0
- package/dist/tools/router.d.ts +34 -0
- package/dist/tools/router.js +73 -0
- package/dist/tools/router.js.map +1 -0
- package/dist/tools/security.d.ts +28 -0
- package/dist/tools/security.js +183 -0
- package/dist/tools/security.js.map +1 -0
- package/dist/tools/webSearch.d.ts +6 -0
- package/dist/tools/webSearch.js +120 -0
- package/dist/tools/webSearch.js.map +1 -0
- package/dist/tracing/analyzer.d.ts +58 -0
- package/dist/tracing/analyzer.js +190 -0
- package/dist/tracing/analyzer.js.map +1 -0
- package/dist/tracing/langsmith.d.ts +38 -0
- package/dist/tracing/langsmith.js +50 -0
- package/dist/tracing/langsmith.js.map +1 -0
- package/dist/tracing/sessionTracer.d.ts +73 -0
- package/dist/tracing/sessionTracer.js +157 -0
- package/dist/tracing/sessionTracer.js.map +1 -0
- package/dist/tracing/types.d.ts +46 -0
- package/dist/tracing/types.js +5 -0
- package/dist/tracing/types.js.map +1 -0
- package/dist/ui/App.d.ts +24 -0
- package/dist/ui/App.js +172 -0
- package/dist/ui/App.js.map +1 -0
- package/dist/ui/components/HITLPrompt.d.ts +15 -0
- package/dist/ui/components/HITLPrompt.js +35 -0
- package/dist/ui/components/HITLPrompt.js.map +1 -0
- package/dist/ui/components/Header.d.ts +8 -0
- package/dist/ui/components/Header.js +6 -0
- package/dist/ui/components/Header.js.map +1 -0
- package/dist/ui/components/MessageBubble.d.ts +13 -0
- package/dist/ui/components/MessageBubble.js +17 -0
- package/dist/ui/components/MessageBubble.js.map +1 -0
- package/dist/ui/components/StatusBar.d.ts +21 -0
- package/dist/ui/components/StatusBar.js +34 -0
- package/dist/ui/components/StatusBar.js.map +1 -0
- package/dist/ui/components/StreamingText.d.ts +13 -0
- package/dist/ui/components/StreamingText.js +24 -0
- package/dist/ui/components/StreamingText.js.map +1 -0
- package/dist/ui/components/ToolCallPanel.d.ts +15 -0
- package/dist/ui/components/ToolCallPanel.js +18 -0
- package/dist/ui/components/ToolCallPanel.js.map +1 -0
- package/docs/01_insights_and_patterns.md +27 -0
- package/docs/02_edge_cases_and_mitigations.md +143 -0
- package/docs/03_initial_implementation_plan.md +66 -0
- package/docs/04_tech_stack_proposal.md +20 -0
- package/docs/05_prd.md +87 -0
- package/docs/06_user_stories.md +72 -0
- package/docs/07_system_architecture.md +138 -0
- package/docs/08_roadmap.md +200 -0
- package/e2b/Dockerfile +26 -0
- package/package.json +57 -0
- package/src/__tests__/bootstrap.test.ts +111 -0
- package/src/__tests__/config.test.ts +97 -0
- package/src/__tests__/m55.test.ts +238 -0
- package/src/__tests__/middleware.test.ts +219 -0
- package/src/__tests__/modelFactory.test.ts +63 -0
- package/src/__tests__/optimizations.test.ts +201 -0
- package/src/__tests__/promptBuilder.test.ts +141 -0
- package/src/__tests__/sandbox.test.ts +102 -0
- package/src/__tests__/security.test.ts +122 -0
- package/src/__tests__/streaming.test.ts +82 -0
- package/src/__tests__/toolRouter.test.ts +52 -0
- package/src/__tests__/tools.test.ts +146 -0
- package/src/__tests__/tracing.test.ts +196 -0
- package/src/agents/agentRegistry.ts +69 -0
- package/src/agents/agentSpec.ts +67 -0
- package/src/agents/builtinAgents.ts +142 -0
- package/src/cli/config.ts +124 -0
- package/src/cli/index.ts +730 -0
- package/src/cli/modelFactory.ts +174 -0
- package/src/cli/providers.ts +107 -0
- package/src/commands/builtinCommands.ts +293 -0
- package/src/commands/commandRegistry.ts +194 -0
- package/src/core/agentLoop.d.ts.map +1 -0
- package/src/core/agentLoop.ts +312 -0
- package/src/core/autoSave.ts +95 -0
- package/src/core/compactor.ts +252 -0
- package/src/core/contextGuard.ts +129 -0
- package/src/core/errors.ts +202 -0
- package/src/core/promptBuilder.d.ts.map +1 -0
- package/src/core/promptBuilder.ts +139 -0
- package/src/core/reasoningRouter.ts +121 -0
- package/src/core/retry.ts +75 -0
- package/src/core/sessionResumer.ts +90 -0
- package/src/core/sessionStore.ts +215 -0
- package/src/core/subAgent.ts +339 -0
- package/src/core/tokenCounter.ts +64 -0
- package/src/evals/dataset.ts +67 -0
- package/src/evals/evaluator.ts +81 -0
- package/src/hitl/bridge.ts +160 -0
- package/src/middleware/commandSanitizer.ts +60 -0
- package/src/middleware/loopDetection.ts +63 -0
- package/src/middleware/permission.ts +72 -0
- package/src/middleware/pipeline.ts +75 -0
- package/src/middleware/preCompletion.ts +94 -0
- package/src/middleware/types.ts +45 -0
- package/src/sandbox/bootstrap.ts +121 -0
- package/src/sandbox/manager.ts +239 -0
- package/src/sandbox/sync.ts +157 -0
- package/src/skills/loader.ts +143 -0
- package/src/skills/tools.ts +99 -0
- package/src/skills/types.ts +13 -0
- package/src/test_cache.ts +72 -0
- package/src/test_google.js +40 -0
- package/src/test_google.ts +40 -0
- package/src/tools/askUser.ts +47 -0
- package/src/tools/browser.ts +137 -0
- package/src/tools/index.d.ts.map +1 -0
- package/src/tools/index.ts +237 -0
- package/src/tools/registry.ts +198 -0
- package/src/tools/router.ts +78 -0
- package/src/tools/security.ts +220 -0
- package/src/tools/spawnAgent.ts +158 -0
- package/src/tools/webSearch.ts +142 -0
- package/src/tracing/analyzer.ts +265 -0
- package/src/tracing/langsmith.ts +63 -0
- package/src/tracing/sessionTracer.ts +202 -0
- package/src/tracing/types.ts +49 -0
- package/src/types/valyu.d.ts +37 -0
- package/src/ui/App.tsx +404 -0
- package/src/ui/components/HITLPrompt.tsx +119 -0
- package/src/ui/components/Header.tsx +51 -0
- package/src/ui/components/MessageBubble.tsx +46 -0
- package/src/ui/components/StatusBar.tsx +138 -0
- package/src/ui/components/StreamingText.tsx +48 -0
- package/src/ui/components/ToolCallPanel.tsx +80 -0
- package/tests/commands/commands.test.ts +356 -0
- package/tests/core/compactor.test.ts +217 -0
- package/tests/core/retryAndErrors.test.ts +164 -0
- package/tests/core/sessionResumer.test.ts +95 -0
- package/tests/core/sessionStore.test.ts +84 -0
- package/tests/core/stability.test.ts +165 -0
- package/tests/core/subAgent.test.ts +238 -0
- package/tests/hitl/hitlBridge.test.ts +115 -0
- package/tsconfig.json +16 -0
- package/vitest.config.ts +10 -0
- package/vitest.out +48 -0
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* LangSmith Integration — thin configuration layer.
|
|
3
|
+
*
|
|
4
|
+
* LangChain has built-in LangSmith tracing via environment variables.
|
|
5
|
+
* This module reads from JooneConfig and sets the required env vars
|
|
6
|
+
* so LangChain auto-traces to LangSmith when enabled.
|
|
7
|
+
*
|
|
8
|
+
* Required env vars for LangSmith:
|
|
9
|
+
* LANGCHAIN_TRACING_V2=true
|
|
10
|
+
* LANGCHAIN_API_KEY=<key>
|
|
11
|
+
* LANGCHAIN_PROJECT=<project> (optional, defaults to "joone")
|
|
12
|
+
*/
|
|
13
|
+
/**
|
|
14
|
+
* Enables LangSmith tracing by setting the required environment variables.
|
|
15
|
+
* LangChain will automatically detect these and send traces.
|
|
16
|
+
*/
|
|
17
|
+
export function enableLangSmith(config) {
|
|
18
|
+
process.env.LANGCHAIN_TRACING_V2 = "true";
|
|
19
|
+
process.env.LANGCHAIN_API_KEY = config.apiKey;
|
|
20
|
+
process.env.LANGCHAIN_PROJECT = config.project ?? "joone";
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Disables LangSmith tracing.
|
|
24
|
+
*/
|
|
25
|
+
export function disableLangSmith() {
|
|
26
|
+
delete process.env.LANGCHAIN_TRACING_V2;
|
|
27
|
+
delete process.env.LANGCHAIN_API_KEY;
|
|
28
|
+
delete process.env.LANGCHAIN_PROJECT;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Checks if LangSmith tracing is currently enabled.
|
|
32
|
+
*/
|
|
33
|
+
export function isLangSmithEnabled() {
|
|
34
|
+
return (process.env.LANGCHAIN_TRACING_V2 === "true" &&
|
|
35
|
+
!!process.env.LANGCHAIN_API_KEY);
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Attempts to enable LangSmith from JooneConfig values.
|
|
39
|
+
* Returns true if successfully enabled.
|
|
40
|
+
*/
|
|
41
|
+
export function tryEnableLangSmithFromConfig(config) {
|
|
42
|
+
if (!config.langsmithApiKey)
|
|
43
|
+
return false;
|
|
44
|
+
enableLangSmith({
|
|
45
|
+
apiKey: config.langsmithApiKey,
|
|
46
|
+
project: config.langsmithProject,
|
|
47
|
+
});
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=langsmith.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"langsmith.js","sourceRoot":"","sources":["../../src/tracing/langsmith.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAOH;;;GAGG;AACH,MAAM,UAAU,eAAe,CAAC,MAAuB;IACrD,OAAO,CAAC,GAAG,CAAC,oBAAoB,GAAG,MAAM,CAAC;IAC1C,OAAO,CAAC,GAAG,CAAC,iBAAiB,GAAG,MAAM,CAAC,MAAM,CAAC;IAC9C,OAAO,CAAC,GAAG,CAAC,iBAAiB,GAAG,MAAM,CAAC,OAAO,IAAI,OAAO,CAAC;AAC5D,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB;IAC9B,OAAO,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC;IACxC,OAAO,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;IACrC,OAAO,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;AACvC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,kBAAkB;IAChC,OAAO,CACL,OAAO,CAAC,GAAG,CAAC,oBAAoB,KAAK,MAAM;QAC3C,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAChC,CAAC;AACJ,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,4BAA4B,CAAC,MAG5C;IACC,IAAI,CAAC,MAAM,CAAC,eAAe;QAAE,OAAO,KAAK,CAAC;IAE1C,eAAe,CAAC;QACd,MAAM,EAAE,MAAM,CAAC,eAAe;QAC9B,OAAO,EAAE,MAAM,CAAC,gBAAgB;KACjC,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { TraceEvent, TraceSummary, SessionTrace } from "./types.js";
|
|
2
|
+
/**
|
|
3
|
+
* SessionTracer — records events during an agent session and computes metrics.
|
|
4
|
+
*
|
|
5
|
+
* Usage:
|
|
6
|
+
* const tracer = new SessionTracer();
|
|
7
|
+
* tracer.recordLLMCall({ promptTokens: 500, completionTokens: 100, cached: true, duration: 800 });
|
|
8
|
+
* tracer.recordToolCall({ name: "bash", args: { command: "ls" }, result: "...", duration: 50 });
|
|
9
|
+
* tracer.recordError({ message: "Timeout", tool: "bash" });
|
|
10
|
+
* const summary = tracer.getSummary();
|
|
11
|
+
* tracer.save(); // writes to ~/.joone/traces/{sessionId}.json
|
|
12
|
+
*/
|
|
13
|
+
export declare class SessionTracer {
|
|
14
|
+
private sessionId;
|
|
15
|
+
private startedAt;
|
|
16
|
+
private events;
|
|
17
|
+
constructor(sessionId?: string);
|
|
18
|
+
/**
|
|
19
|
+
* Record an LLM call with token usage and cache information.
|
|
20
|
+
*/
|
|
21
|
+
recordLLMCall(data: {
|
|
22
|
+
promptTokens: number;
|
|
23
|
+
completionTokens: number;
|
|
24
|
+
cached: boolean;
|
|
25
|
+
duration: number;
|
|
26
|
+
model?: string;
|
|
27
|
+
}): void;
|
|
28
|
+
/**
|
|
29
|
+
* Record a tool execution.
|
|
30
|
+
*/
|
|
31
|
+
recordToolCall(data: {
|
|
32
|
+
name: string;
|
|
33
|
+
args: Record<string, any>;
|
|
34
|
+
result?: string;
|
|
35
|
+
duration: number;
|
|
36
|
+
success: boolean;
|
|
37
|
+
}): void;
|
|
38
|
+
/**
|
|
39
|
+
* Record an error.
|
|
40
|
+
*/
|
|
41
|
+
recordError(data: {
|
|
42
|
+
message: string;
|
|
43
|
+
tool?: string;
|
|
44
|
+
stack?: string;
|
|
45
|
+
}): void;
|
|
46
|
+
/**
|
|
47
|
+
* Record a context compaction event.
|
|
48
|
+
*/
|
|
49
|
+
recordCompaction(data: {
|
|
50
|
+
tokensBefore: number;
|
|
51
|
+
tokensAfter: number;
|
|
52
|
+
messagesSummarized: number;
|
|
53
|
+
}): void;
|
|
54
|
+
/**
|
|
55
|
+
* Compute aggregated metrics from all recorded events.
|
|
56
|
+
*/
|
|
57
|
+
getSummary(): TraceSummary;
|
|
58
|
+
/**
|
|
59
|
+
* Returns the full session trace as a serializable object.
|
|
60
|
+
*/
|
|
61
|
+
export(): SessionTrace;
|
|
62
|
+
/**
|
|
63
|
+
* Saves the session trace to ~/.joone/traces/{sessionId}.json.
|
|
64
|
+
*/
|
|
65
|
+
save(dir?: string): string;
|
|
66
|
+
/**
|
|
67
|
+
* Loads a session trace from a JSON file.
|
|
68
|
+
*/
|
|
69
|
+
static load(filePath: string): SessionTrace;
|
|
70
|
+
getSessionId(): string;
|
|
71
|
+
getEvents(): readonly TraceEvent[];
|
|
72
|
+
getEventCount(): number;
|
|
73
|
+
}
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
import * as path from "node:path";
|
|
3
|
+
import * as os from "node:os";
|
|
4
|
+
/**
|
|
5
|
+
* SessionTracer — records events during an agent session and computes metrics.
|
|
6
|
+
*
|
|
7
|
+
* Usage:
|
|
8
|
+
* const tracer = new SessionTracer();
|
|
9
|
+
* tracer.recordLLMCall({ promptTokens: 500, completionTokens: 100, cached: true, duration: 800 });
|
|
10
|
+
* tracer.recordToolCall({ name: "bash", args: { command: "ls" }, result: "...", duration: 50 });
|
|
11
|
+
* tracer.recordError({ message: "Timeout", tool: "bash" });
|
|
12
|
+
* const summary = tracer.getSummary();
|
|
13
|
+
* tracer.save(); // writes to ~/.joone/traces/{sessionId}.json
|
|
14
|
+
*/
|
|
15
|
+
export class SessionTracer {
|
|
16
|
+
sessionId;
|
|
17
|
+
startedAt;
|
|
18
|
+
events = [];
|
|
19
|
+
constructor(sessionId) {
|
|
20
|
+
this.sessionId = sessionId ?? crypto.randomUUID();
|
|
21
|
+
this.startedAt = Date.now();
|
|
22
|
+
}
|
|
23
|
+
// ─── Recording Methods ──────────────────────────────────────────────────────
|
|
24
|
+
/**
|
|
25
|
+
* Record an LLM call with token usage and cache information.
|
|
26
|
+
*/
|
|
27
|
+
recordLLMCall(data) {
|
|
28
|
+
this.events.push({
|
|
29
|
+
type: "llm_call",
|
|
30
|
+
timestamp: Date.now(),
|
|
31
|
+
duration: data.duration,
|
|
32
|
+
data,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Record a tool execution.
|
|
37
|
+
*/
|
|
38
|
+
recordToolCall(data) {
|
|
39
|
+
this.events.push({
|
|
40
|
+
type: "tool_call",
|
|
41
|
+
timestamp: Date.now(),
|
|
42
|
+
duration: data.duration,
|
|
43
|
+
data,
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Record an error.
|
|
48
|
+
*/
|
|
49
|
+
recordError(data) {
|
|
50
|
+
this.events.push({
|
|
51
|
+
type: "error",
|
|
52
|
+
timestamp: Date.now(),
|
|
53
|
+
data,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Record a context compaction event.
|
|
58
|
+
*/
|
|
59
|
+
recordCompaction(data) {
|
|
60
|
+
this.events.push({
|
|
61
|
+
type: "compaction",
|
|
62
|
+
timestamp: Date.now(),
|
|
63
|
+
data,
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
// ─── Summary Computation ────────────────────────────────────────────────────
|
|
67
|
+
/**
|
|
68
|
+
* Compute aggregated metrics from all recorded events.
|
|
69
|
+
*/
|
|
70
|
+
getSummary() {
|
|
71
|
+
let promptTokens = 0;
|
|
72
|
+
let completionTokens = 0;
|
|
73
|
+
let cachedPromptTokens = 0;
|
|
74
|
+
let toolCallCount = 0;
|
|
75
|
+
let errorCount = 0;
|
|
76
|
+
let turnCount = 0;
|
|
77
|
+
for (const event of this.events) {
|
|
78
|
+
switch (event.type) {
|
|
79
|
+
case "llm_call":
|
|
80
|
+
promptTokens += event.data.promptTokens || 0;
|
|
81
|
+
completionTokens += event.data.completionTokens || 0;
|
|
82
|
+
if (event.data.cached) {
|
|
83
|
+
cachedPromptTokens += event.data.promptTokens || 0;
|
|
84
|
+
}
|
|
85
|
+
turnCount++;
|
|
86
|
+
break;
|
|
87
|
+
case "tool_call":
|
|
88
|
+
toolCallCount++;
|
|
89
|
+
break;
|
|
90
|
+
case "error":
|
|
91
|
+
errorCount++;
|
|
92
|
+
break;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
const totalTokens = promptTokens + completionTokens;
|
|
96
|
+
const cacheHitRate = promptTokens > 0 ? cachedPromptTokens / promptTokens : 0;
|
|
97
|
+
// Rough cost estimate: ~$3/1M input tokens, ~$15/1M output tokens (Claude Sonnet pricing)
|
|
98
|
+
const totalCost = (promptTokens / 1_000_000) * 3 + (completionTokens / 1_000_000) * 15;
|
|
99
|
+
const totalDuration = Date.now() - this.startedAt;
|
|
100
|
+
return {
|
|
101
|
+
totalTokens,
|
|
102
|
+
promptTokens,
|
|
103
|
+
completionTokens,
|
|
104
|
+
totalCost,
|
|
105
|
+
cacheHitRate,
|
|
106
|
+
toolCallCount,
|
|
107
|
+
errorCount,
|
|
108
|
+
totalDuration,
|
|
109
|
+
turnCount,
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
// ─── Export & Persistence ───────────────────────────────────────────────────
|
|
113
|
+
/**
|
|
114
|
+
* Returns the full session trace as a serializable object.
|
|
115
|
+
*/
|
|
116
|
+
export() {
|
|
117
|
+
return {
|
|
118
|
+
sessionId: this.sessionId,
|
|
119
|
+
startedAt: this.startedAt,
|
|
120
|
+
endedAt: Date.now(),
|
|
121
|
+
events: this.events,
|
|
122
|
+
summary: this.getSummary(),
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Saves the session trace to ~/.joone/traces/{sessionId}.json.
|
|
127
|
+
*/
|
|
128
|
+
save(dir) {
|
|
129
|
+
const tracesDir = dir ?? path.join(os.homedir(), ".joone", "traces");
|
|
130
|
+
if (!fs.existsSync(tracesDir)) {
|
|
131
|
+
fs.mkdirSync(tracesDir, { recursive: true });
|
|
132
|
+
}
|
|
133
|
+
// Sanitize sessionId to prevent path traversal
|
|
134
|
+
const safeSessionId = path.basename(this.sessionId);
|
|
135
|
+
const filePath = path.join(tracesDir, `${safeSessionId}.json`);
|
|
136
|
+
fs.writeFileSync(filePath, JSON.stringify(this.export(), null, 2));
|
|
137
|
+
return filePath;
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Loads a session trace from a JSON file.
|
|
141
|
+
*/
|
|
142
|
+
static load(filePath) {
|
|
143
|
+
const raw = fs.readFileSync(filePath, "utf-8");
|
|
144
|
+
return JSON.parse(raw);
|
|
145
|
+
}
|
|
146
|
+
// ─── Accessors ─────────────────────────────────────────────────────────────
|
|
147
|
+
getSessionId() {
|
|
148
|
+
return this.sessionId;
|
|
149
|
+
}
|
|
150
|
+
getEvents() {
|
|
151
|
+
return this.events;
|
|
152
|
+
}
|
|
153
|
+
getEventCount() {
|
|
154
|
+
return this.events.length;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
//# sourceMappingURL=sessionTracer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessionTracer.js","sourceRoot":"","sources":["../../src/tracing/sessionTracer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Core tracing data types for session instrumentation.
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* A single traced event during agent execution.
|
|
6
|
+
*/
|
|
7
|
+
export interface TraceEvent {
|
|
8
|
+
/** Event category. */
|
|
9
|
+
type: "llm_call" | "tool_call" | "error" | "compaction";
|
|
10
|
+
/** Unix timestamp (ms) when the event started. */
|
|
11
|
+
timestamp: number;
|
|
12
|
+
/** Duration in milliseconds (if applicable). */
|
|
13
|
+
duration?: number;
|
|
14
|
+
/** Event-specific payload. */
|
|
15
|
+
data: Record<string, any>;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Aggregated metrics for a complete session.
|
|
19
|
+
*/
|
|
20
|
+
export interface TraceSummary {
|
|
21
|
+
totalTokens: number;
|
|
22
|
+
promptTokens: number;
|
|
23
|
+
completionTokens: number;
|
|
24
|
+
/** Estimated cost in USD. */
|
|
25
|
+
totalCost: number;
|
|
26
|
+
/** Cache hit rate: 0-1 (ratio of cached prompt tokens to total prompt tokens). */
|
|
27
|
+
cacheHitRate: number;
|
|
28
|
+
/** Number of tool calls made during the session. */
|
|
29
|
+
toolCallCount: number;
|
|
30
|
+
/** Number of errors encountered. */
|
|
31
|
+
errorCount: number;
|
|
32
|
+
/** Total session duration in ms. */
|
|
33
|
+
totalDuration: number;
|
|
34
|
+
/** Number of LLM turns. */
|
|
35
|
+
turnCount: number;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Full trace for a single agent session, suitable for persistence and analysis.
|
|
39
|
+
*/
|
|
40
|
+
export interface SessionTrace {
|
|
41
|
+
sessionId: string;
|
|
42
|
+
startedAt: number;
|
|
43
|
+
endedAt?: number;
|
|
44
|
+
events: TraceEvent[];
|
|
45
|
+
summary: TraceSummary;
|
|
46
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/tracing/types.ts"],"names":[],"mappings":"AAAA;;GAEG"}
|
package/dist/ui/App.d.ts
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { ToolCallStatus } from "./components/ToolCallPanel.js";
|
|
3
|
+
import { ExecutionHarness } from "../core/agentLoop.js";
|
|
4
|
+
import { ContextState } from "../core/promptBuilder.js";
|
|
5
|
+
export interface Message {
|
|
6
|
+
role: "user" | "agent" | "system";
|
|
7
|
+
content: string;
|
|
8
|
+
}
|
|
9
|
+
export interface ActiveToolCall {
|
|
10
|
+
name: string;
|
|
11
|
+
args: Record<string, unknown>;
|
|
12
|
+
status: ToolCallStatus;
|
|
13
|
+
result?: string;
|
|
14
|
+
}
|
|
15
|
+
interface AppProps {
|
|
16
|
+
provider: string;
|
|
17
|
+
model: string;
|
|
18
|
+
streaming: boolean;
|
|
19
|
+
harness: ExecutionHarness;
|
|
20
|
+
initialState: ContextState;
|
|
21
|
+
maxTokens: number;
|
|
22
|
+
}
|
|
23
|
+
export declare const App: React.FC<AppProps>;
|
|
24
|
+
export {};
|
package/dist/ui/App.js
ADDED
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useEffect } from "react";
|
|
3
|
+
import { Box, Text, useInput, useApp } from "ink";
|
|
4
|
+
import TextInput from "ink-text-input";
|
|
5
|
+
import { Header } from "./components/Header.js";
|
|
6
|
+
import { StatusBar } from "./components/StatusBar.js";
|
|
7
|
+
import { MessageBubble } from "./components/MessageBubble.js";
|
|
8
|
+
import { StreamingText } from "./components/StreamingText.js";
|
|
9
|
+
import { ToolCallPanel } from "./components/ToolCallPanel.js";
|
|
10
|
+
import { HITLPrompt } from "./components/HITLPrompt.js";
|
|
11
|
+
import { countMessageTokens } from "../core/tokenCounter.js";
|
|
12
|
+
import { HumanMessage } from "@langchain/core/messages";
|
|
13
|
+
import { HITLBridge, } from "../hitl/bridge.js";
|
|
14
|
+
export const App = ({ provider, model, streaming, harness, initialState, maxTokens, }) => {
|
|
15
|
+
const { exit } = useApp();
|
|
16
|
+
// UI State
|
|
17
|
+
const [messages, setMessages] = useState([
|
|
18
|
+
{ role: "system", content: "Session started. Type your request below." },
|
|
19
|
+
]);
|
|
20
|
+
const [inputValue, setInputValue] = useState("");
|
|
21
|
+
const [isProcessing, setIsProcessing] = useState(false);
|
|
22
|
+
// Streaming & Tool State
|
|
23
|
+
const [streamingTokens, setStreamingTokens] = useState([]);
|
|
24
|
+
const [isStreaming, setIsStreaming] = useState(false);
|
|
25
|
+
const [activeToolCall, setActiveToolCall] = useState(null);
|
|
26
|
+
// Core Engine State
|
|
27
|
+
const [contextState, setContextState] = useState(initialState);
|
|
28
|
+
// HITL State
|
|
29
|
+
const [hitlQuestion, setHitlQuestion] = useState(undefined);
|
|
30
|
+
const [hitlPermission, setHitlPermission] = useState(undefined);
|
|
31
|
+
// Listen for HITL events from the bridge
|
|
32
|
+
useEffect(() => {
|
|
33
|
+
const bridge = HITLBridge.getInstance();
|
|
34
|
+
const onQuestion = (q) => setHitlQuestion(q);
|
|
35
|
+
const onPermission = (p) => setHitlPermission(p);
|
|
36
|
+
bridge.on("question", onQuestion);
|
|
37
|
+
bridge.on("permission", onPermission);
|
|
38
|
+
// Clear prompts when resolved
|
|
39
|
+
const origResolve = bridge.resolveAnswer.bind(bridge);
|
|
40
|
+
bridge.resolveAnswer = (id, answer) => {
|
|
41
|
+
origResolve(id, answer);
|
|
42
|
+
setHitlQuestion(undefined);
|
|
43
|
+
setHitlPermission(undefined);
|
|
44
|
+
};
|
|
45
|
+
return () => {
|
|
46
|
+
bridge.off("question", onQuestion);
|
|
47
|
+
bridge.off("permission", onPermission);
|
|
48
|
+
};
|
|
49
|
+
}, []);
|
|
50
|
+
// StatusBar Metrics
|
|
51
|
+
const [startTime] = useState(Date.now());
|
|
52
|
+
const [elapsed, setElapsed] = useState("0s");
|
|
53
|
+
// Update elapsed time
|
|
54
|
+
useEffect(() => {
|
|
55
|
+
const interval = setInterval(() => {
|
|
56
|
+
const seconds = Math.floor((Date.now() - startTime) / 1000);
|
|
57
|
+
if (seconds < 60) {
|
|
58
|
+
setElapsed(`${seconds}s`);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
const mins = Math.floor(seconds / 60);
|
|
62
|
+
const secs = seconds % 60;
|
|
63
|
+
setElapsed(`${mins}m ${secs}s`);
|
|
64
|
+
}
|
|
65
|
+
}, 1000);
|
|
66
|
+
return () => clearInterval(interval);
|
|
67
|
+
}, [startTime]);
|
|
68
|
+
// Handle Ctrl+C
|
|
69
|
+
useInput((input, key) => {
|
|
70
|
+
if (key.ctrl && input === "c") {
|
|
71
|
+
exit();
|
|
72
|
+
process.exit(0);
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
const runAgentLoop = async (currentState) => {
|
|
76
|
+
try {
|
|
77
|
+
setIsStreaming(true);
|
|
78
|
+
setStreamingTokens([]);
|
|
79
|
+
let aiResponse;
|
|
80
|
+
if (streaming) {
|
|
81
|
+
aiResponse = await harness.streamStep(currentState, {
|
|
82
|
+
onToken: (token) => {
|
|
83
|
+
setStreamingTokens((prev) => [...prev, token]);
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
aiResponse = await harness.step(currentState);
|
|
89
|
+
}
|
|
90
|
+
setIsStreaming(false);
|
|
91
|
+
// Add AI text to UI if any
|
|
92
|
+
if (aiResponse.content &&
|
|
93
|
+
typeof aiResponse.content === "string" &&
|
|
94
|
+
aiResponse.content.trim() !== "") {
|
|
95
|
+
setMessages((prev) => [
|
|
96
|
+
...prev,
|
|
97
|
+
{ role: "agent", content: aiResponse.content },
|
|
98
|
+
]);
|
|
99
|
+
}
|
|
100
|
+
// Add AI message to memory for following tools
|
|
101
|
+
let nextHistory = [...currentState.conversationHistory, aiResponse];
|
|
102
|
+
// Handle Tools
|
|
103
|
+
if (aiResponse.tool_calls && aiResponse.tool_calls.length > 0) {
|
|
104
|
+
// Execute all tool calls once
|
|
105
|
+
const toolMessages = await harness.executeToolCalls(aiResponse, currentState);
|
|
106
|
+
// Update UI sequentially for each tool call
|
|
107
|
+
for (const call of aiResponse.tool_calls) {
|
|
108
|
+
setActiveToolCall({
|
|
109
|
+
name: call.name,
|
|
110
|
+
args: call.args,
|
|
111
|
+
status: "running",
|
|
112
|
+
});
|
|
113
|
+
// Brief delay to show running state
|
|
114
|
+
await new Promise((resolve) => setTimeout(resolve, 300));
|
|
115
|
+
setActiveToolCall({
|
|
116
|
+
name: call.name,
|
|
117
|
+
args: call.args,
|
|
118
|
+
status: "success",
|
|
119
|
+
result: toolMessages.length > 0
|
|
120
|
+
? "Tool execution completed."
|
|
121
|
+
: "No output.",
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
// Add tool results to history once
|
|
125
|
+
nextHistory = [...nextHistory, ...toolMessages];
|
|
126
|
+
// Wait a sec so user sees the success state
|
|
127
|
+
await new Promise((resolve) => setTimeout(resolve, 800));
|
|
128
|
+
setActiveToolCall(null);
|
|
129
|
+
// Recurse: Agent needs to react to the tool output
|
|
130
|
+
const nextState = { ...currentState, conversationHistory: nextHistory };
|
|
131
|
+
setContextState(nextState);
|
|
132
|
+
await runAgentLoop(nextState);
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
// Turn complete
|
|
136
|
+
setContextState({ ...currentState, conversationHistory: nextHistory });
|
|
137
|
+
setIsProcessing(false);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
catch (error) {
|
|
141
|
+
setIsStreaming(false);
|
|
142
|
+
setActiveToolCall(null);
|
|
143
|
+
setIsProcessing(false);
|
|
144
|
+
setMessages((prev) => [
|
|
145
|
+
...prev,
|
|
146
|
+
{ role: "system", content: `Error: ${error.message}` },
|
|
147
|
+
]);
|
|
148
|
+
}
|
|
149
|
+
};
|
|
150
|
+
const handleSubmit = (query) => {
|
|
151
|
+
if (!query.trim() || isProcessing)
|
|
152
|
+
return;
|
|
153
|
+
const userText = query.trim();
|
|
154
|
+
setInputValue("");
|
|
155
|
+
setIsProcessing(true);
|
|
156
|
+
// 1. Update UI
|
|
157
|
+
setMessages((prev) => [...prev, { role: "user", content: userText }]);
|
|
158
|
+
// 2. Update Engine State
|
|
159
|
+
const humanMsg = new HumanMessage(userText);
|
|
160
|
+
const updatedState = {
|
|
161
|
+
...contextState,
|
|
162
|
+
conversationHistory: [...contextState.conversationHistory, humanMsg],
|
|
163
|
+
};
|
|
164
|
+
setContextState(updatedState);
|
|
165
|
+
// 3. Start Turn
|
|
166
|
+
runAgentLoop(updatedState);
|
|
167
|
+
};
|
|
168
|
+
const summary = harness.tracer.getSummary();
|
|
169
|
+
const contextTokens = countMessageTokens(contextState.conversationHistory);
|
|
170
|
+
return (_jsxs(Box, { flexDirection: "column", minHeight: 15, children: [_jsx(Header, { provider: provider, model: model, streaming: streaming }), _jsx(Box, { flexDirection: "column", paddingY: 1, children: messages.map((msg, i) => (_jsx(MessageBubble, { role: msg.role, content: msg.content }, i))) }), isStreaming && (_jsx(Box, { paddingX: 1, marginBottom: 1, children: _jsx(Box, { marginLeft: 2, children: _jsx(StreamingText, { tokens: streamingTokens, isStreaming: isStreaming }) }) })), activeToolCall && (_jsx(Box, { paddingX: 1, marginBottom: 1, children: _jsx(ToolCallPanel, { toolName: activeToolCall.name, args: activeToolCall.args, status: activeToolCall.status, result: activeToolCall.result }) })), (hitlQuestion || hitlPermission) && (_jsx(HITLPrompt, { question: hitlQuestion, permission: hitlPermission })), !isProcessing && !hitlQuestion && !hitlPermission && (_jsxs(Box, { paddingX: 1, marginBottom: 1, children: [_jsx(Box, { marginRight: 1, children: _jsx(Text, { color: "green", bold: true, children: "\u276F" }) }), _jsx(TextInput, { value: inputValue, onChange: setInputValue, onSubmit: handleSubmit, placeholder: "What should we build today?" })] })), isProcessing && !isStreaming && !activeToolCall && (_jsx(Box, { paddingX: 1, marginBottom: 1, children: _jsx(Text, { dimColor: true, children: "Thinking..." }) })), _jsx(StatusBar, { contextTokens: contextTokens, maxContextTokens: maxTokens, totalTokens: summary.totalTokens, cacheHitRate: summary.cacheHitRate, toolCalls: summary.toolCallCount, turns: summary.turnCount, cost: summary.totalCost, elapsed: elapsed })] }));
|
|
171
|
+
};
|
|
172
|
+
//# sourceMappingURL=App.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"App.js","sourceRoot":"","sources":["../../src/ui/App.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { HITLQuestion, HITLPermissionRequest } from "../../hitl/bridge.js";
|
|
3
|
+
interface HITLPromptProps {
|
|
4
|
+
/** The active HITL question or permission request. */
|
|
5
|
+
question?: HITLQuestion;
|
|
6
|
+
permission?: HITLPermissionRequest;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* HITLPrompt — renders a blocking question/permission prompt in the TUI.
|
|
10
|
+
*
|
|
11
|
+
* When a tool calls `ask_user_question` or the PermissionMiddleware fires,
|
|
12
|
+
* this component takes over the input area to capture the user's response.
|
|
13
|
+
*/
|
|
14
|
+
export declare const HITLPrompt: React.FC<HITLPromptProps>;
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from "react";
|
|
3
|
+
import { Box, Text } from "ink";
|
|
4
|
+
import TextInput from "ink-text-input";
|
|
5
|
+
import { HITLBridge, } from "../../hitl/bridge.js";
|
|
6
|
+
/**
|
|
7
|
+
* HITLPrompt — renders a blocking question/permission prompt in the TUI.
|
|
8
|
+
*
|
|
9
|
+
* When a tool calls `ask_user_question` or the PermissionMiddleware fires,
|
|
10
|
+
* this component takes over the input area to capture the user's response.
|
|
11
|
+
*/
|
|
12
|
+
export const HITLPrompt = ({ question, permission, }) => {
|
|
13
|
+
const [inputValue, setInputValue] = useState("");
|
|
14
|
+
const handleSubmit = (value) => {
|
|
15
|
+
const bridge = HITLBridge.getInstance();
|
|
16
|
+
if (question) {
|
|
17
|
+
bridge.resolveAnswer(question.id, value);
|
|
18
|
+
}
|
|
19
|
+
else if (permission) {
|
|
20
|
+
bridge.resolveAnswer(permission.id, value);
|
|
21
|
+
}
|
|
22
|
+
setInputValue("");
|
|
23
|
+
};
|
|
24
|
+
if (question) {
|
|
25
|
+
return (_jsxs(Box, { flexDirection: "column", paddingX: 1, marginBottom: 1, children: [_jsx(Box, { marginBottom: 1, children: _jsx(Text, { color: "yellow", bold: true, children: "\u2753 Agent is asking:" }) }), _jsx(Box, { marginLeft: 2, marginBottom: 1, children: _jsx(Text, { children: question.question }) }), question.options && question.options.length > 0 && (_jsx(Box, { flexDirection: "column", marginLeft: 2, marginBottom: 1, children: question.options.map((opt, i) => (_jsx(Text, { dimColor: true, children: ` ${i + 1}. ${opt}` }, i))) })), _jsxs(Box, { children: [_jsx(Box, { marginRight: 1, children: _jsx(Text, { color: "yellow", bold: true, children: "\u2192" }) }), _jsx(TextInput, { value: inputValue, onChange: setInputValue, onSubmit: handleSubmit, placeholder: "Type your answer..." })] })] }));
|
|
26
|
+
}
|
|
27
|
+
if (permission) {
|
|
28
|
+
const argsSummary = Object.entries(permission.args)
|
|
29
|
+
.map(([k, v]) => `${k}: ${typeof v === "string" ? v.substring(0, 60) : JSON.stringify(v)}`)
|
|
30
|
+
.join(", ");
|
|
31
|
+
return (_jsxs(Box, { flexDirection: "column", paddingX: 1, marginBottom: 1, children: [_jsx(Box, { marginBottom: 1, children: _jsx(Text, { color: "red", bold: true, children: "\u26A0 Permission Required:" }) }), _jsx(Box, { marginLeft: 2, marginBottom: 1, children: _jsxs(Text, { children: ["The agent wants to execute", " ", _jsx(Text, { bold: true, color: "white", children: permission.toolName })] }) }), _jsx(Box, { marginLeft: 2, marginBottom: 1, children: _jsx(Text, { dimColor: true, children: argsSummary }) }), _jsxs(Box, { children: [_jsx(Box, { marginRight: 1, children: _jsx(Text, { color: "red", bold: true, children: "Allow? (y/n):" }) }), _jsx(TextInput, { value: inputValue, onChange: setInputValue, onSubmit: handleSubmit, placeholder: "y or n" })] })] }));
|
|
32
|
+
}
|
|
33
|
+
return null;
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=HITLPrompt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HITLPrompt.js","sourceRoot":"","sources":["../../../src/ui/components/HITLPrompt.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text } from "ink";
|
|
3
|
+
export const Header = ({ provider, model, streaming, }) => {
|
|
4
|
+
return (_jsxs(Box, { flexDirection: "column", paddingX: 1, borderStyle: "round", borderColor: "cyan", children: [_jsxs(Box, { justifyContent: "space-between", children: [_jsx(Text, { bold: true, color: "cyan", children: "\u25C6 joone" }), _jsx(Text, { dimColor: true, children: "v0.1.0" })] }), _jsxs(Box, { marginTop: 0, gap: 2, children: [_jsxs(Text, { children: [_jsx(Text, { dimColor: true, children: "provider" }), " ", _jsx(Text, { color: "white", bold: true, children: provider })] }), _jsxs(Text, { children: [_jsx(Text, { dimColor: true, children: "model" }), " ", _jsx(Text, { color: "white", bold: true, children: model })] }), _jsxs(Text, { children: [_jsx(Text, { dimColor: true, children: "stream" }), " ", _jsx(Text, { color: streaming ? "green" : "yellow", children: streaming ? "on" : "off" })] })] })] }));
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=Header.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Header.js","sourceRoot":"","sources":["../../../src/ui/components/Header.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAShC,MAAM,CAAC,MAAM,MAAM,GAA0B,CAAC,EAC5C,QAAQ,EACR,KAAK,EACL,SAAS,GACV,EAAE,EAAE;IACH,OAAO,CACL,MAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,QAAQ,EAAE,CAAC,EACX,WAAW,EAAC,OAAO,EACnB,WAAW,EAAC,MAAM,aAElB,MAAC,GAAG,IAAC,cAAc,EAAC,eAAe,aACjC,KAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAC,MAAM,6BAEhB,EACP,KAAC,IAAI,IAAC,QAAQ,6BAAc,IACxB,EACN,MAAC,GAAG,IAAC,SAAS,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,aACvB,MAAC,IAAI,eACH,KAAC,IAAI,IAAC,QAAQ,+BAAgB,EAAC,GAAG,EAClC,KAAC,IAAI,IAAC,KAAK,EAAC,OAAO,EAAC,IAAI,kBACrB,QAAQ,GACJ,IACF,EACP,MAAC,IAAI,eACH,KAAC,IAAI,IAAC,QAAQ,4BAAa,EAAC,GAAG,EAC/B,KAAC,IAAI,IAAC,KAAK,EAAC,OAAO,EAAC,IAAI,kBACrB,KAAK,GACD,IACF,EACP,MAAC,IAAI,eACH,KAAC,IAAI,IAAC,QAAQ,6BAAc,EAAC,GAAG,EAChC,KAAC,IAAI,IAAC,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,YACxC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,GACpB,IACF,IACH,IACF,CACP,CAAC;AACJ,CAAC,CAAC"}
|