@ranker/raxflow 0.2.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/dashboard/index.html +420 -0
- package/dist/benchmark.d.ts.map +1 -0
- package/dist/benchmark.js +123 -0
- package/dist/benchmark.js.map +1 -0
- package/dist/bin.d.ts.map +1 -0
- package/dist/bin.js +141 -0
- package/dist/bin.js.map +1 -0
- package/dist/bootstrap.d.ts.map +1 -0
- package/dist/bootstrap.js +22 -0
- package/dist/bootstrap.js.map +1 -0
- package/dist/bridge-adapter-templates.d.ts.map +1 -0
- package/dist/bridge-adapter-templates.js +185 -0
- package/dist/bridge-adapter-templates.js.map +1 -0
- package/dist/bridge-test.d.ts.map +1 -0
- package/dist/bridge-test.js +89 -0
- package/dist/bridge-test.js.map +1 -0
- package/dist/dashboard.d.ts.map +1 -0
- package/dist/dashboard.js +49 -0
- package/dist/dashboard.js.map +1 -0
- package/dist/doctor.d.ts.map +1 -0
- package/dist/doctor.js +70 -0
- package/dist/doctor.js.map +1 -0
- package/dist/evolve.d.ts.map +1 -0
- package/dist/evolve.js +48 -0
- package/dist/evolve.js.map +1 -0
- package/dist/host-init-templates.d.ts.map +1 -0
- package/dist/host-init-templates.js +119 -0
- package/dist/host-init-templates.js.map +1 -0
- package/dist/hub/__tests__/commands.test.d.ts.map +1 -0
- package/dist/hub/__tests__/commands.test.js +72 -0
- package/dist/hub/__tests__/commands.test.js.map +1 -0
- package/dist/hub/__tests__/history.test.d.ts.map +1 -0
- package/dist/hub/__tests__/history.test.js +119 -0
- package/dist/hub/__tests__/history.test.js.map +1 -0
- package/dist/hub/__tests__/parser.test.d.ts.map +1 -0
- package/dist/hub/__tests__/parser.test.js +92 -0
- package/dist/hub/__tests__/parser.test.js.map +1 -0
- package/dist/hub/chat/ChatApp.d.ts +2 -0
- package/dist/hub/chat/ChatApp.d.ts.map +1 -0
- package/dist/hub/chat/ChatApp.js +146 -0
- package/dist/hub/chat/ChatApp.js.map +1 -0
- package/dist/hub/chat/components/ChatInput.d.ts +9 -0
- package/dist/hub/chat/components/ChatInput.d.ts.map +1 -0
- package/dist/hub/chat/components/ChatInput.js +19 -0
- package/dist/hub/chat/components/ChatInput.js.map +1 -0
- package/dist/hub/chat/components/MessageList.d.ts +7 -0
- package/dist/hub/chat/components/MessageList.d.ts.map +1 -0
- package/dist/hub/chat/components/MessageList.js +6 -0
- package/dist/hub/chat/components/MessageList.js.map +1 -0
- package/dist/hub/chat/context.d.ts.map +1 -0
- package/dist/hub/chat/context.js +42 -0
- package/dist/hub/chat/context.js.map +1 -0
- package/dist/hub/chat/hooks/useChatHistory.d.ts +7 -0
- package/dist/hub/chat/hooks/useChatHistory.d.ts.map +1 -0
- package/dist/hub/chat/hooks/useChatHistory.js +31 -0
- package/dist/hub/chat/hooks/useChatHistory.js.map +1 -0
- package/dist/hub/chat/index.d.ts.map +1 -0
- package/dist/hub/chat/index.js +7 -0
- package/dist/hub/chat/index.js.map +1 -0
- package/dist/hub/chat/intent-parser.d.ts.map +1 -0
- package/dist/hub/chat/intent-parser.js +48 -0
- package/dist/hub/chat/intent-parser.js.map +1 -0
- package/dist/hub/chat/types.d.ts.map +1 -0
- package/dist/hub/chat/types.js +2 -0
- package/dist/hub/chat/types.js.map +1 -0
- package/dist/hub/commands/agents.d.ts.map +1 -0
- package/dist/hub/commands/agents.js +36 -0
- package/dist/hub/commands/agents.js.map +1 -0
- package/dist/hub/commands/index.d.ts.map +1 -0
- package/dist/hub/commands/index.js +123 -0
- package/dist/hub/commands/index.js.map +1 -0
- package/dist/hub/commands/logs.d.ts.map +1 -0
- package/dist/hub/commands/logs.js +53 -0
- package/dist/hub/commands/logs.js.map +1 -0
- package/dist/hub/commands/memory.d.ts.map +1 -0
- package/dist/hub/commands/memory.js +40 -0
- package/dist/hub/commands/memory.js.map +1 -0
- package/dist/hub/commands/metrics.d.ts.map +1 -0
- package/dist/hub/commands/metrics.js +35 -0
- package/dist/hub/commands/metrics.js.map +1 -0
- package/dist/hub/commands/providers.d.ts.map +1 -0
- package/dist/hub/commands/providers.js +26 -0
- package/dist/hub/commands/providers.js.map +1 -0
- package/dist/hub/commands/run.d.ts.map +1 -0
- package/dist/hub/commands/run.js +31 -0
- package/dist/hub/commands/run.js.map +1 -0
- package/dist/hub/commands/status.d.ts.map +1 -0
- package/dist/hub/commands/status.js +61 -0
- package/dist/hub/commands/status.js.map +1 -0
- package/dist/hub/commands/workflows.d.ts.map +1 -0
- package/dist/hub/commands/workflows.js +45 -0
- package/dist/hub/commands/workflows.js.map +1 -0
- package/dist/hub/config-loader.d.ts.map +1 -0
- package/dist/hub/config-loader.js +27 -0
- package/dist/hub/config-loader.js.map +1 -0
- package/dist/hub/event-listener.d.ts +6 -0
- package/dist/hub/event-listener.d.ts.map +1 -0
- package/dist/hub/event-listener.js +12 -0
- package/dist/hub/event-listener.js.map +1 -0
- package/dist/hub/history.d.ts.map +1 -0
- package/dist/hub/history.js +59 -0
- package/dist/hub/history.js.map +1 -0
- package/dist/hub/index.d.ts.map +1 -0
- package/dist/hub/index.js +114 -0
- package/dist/hub/index.js.map +1 -0
- package/dist/hub/parser.d.ts.map +1 -0
- package/dist/hub/parser.js +98 -0
- package/dist/hub/parser.js.map +1 -0
- package/dist/hub/styles/borders.d.ts.map +1 -0
- package/dist/hub/styles/borders.js +64 -0
- package/dist/hub/styles/borders.js.map +1 -0
- package/dist/hub/styles/colors.d.ts.map +1 -0
- package/dist/hub/styles/colors.js +115 -0
- package/dist/hub/styles/colors.js.map +1 -0
- package/dist/hub/styles/typography.d.ts.map +1 -0
- package/dist/hub/styles/typography.js +60 -0
- package/dist/hub/styles/typography.js.map +1 -0
- package/dist/hub/tui/App.d.ts +2 -0
- package/dist/hub/tui/App.d.ts.map +1 -0
- package/dist/hub/tui/App.js +53 -0
- package/dist/hub/tui/App.js.map +1 -0
- package/dist/hub/tui/components/AgentQueue.d.ts +6 -0
- package/dist/hub/tui/components/AgentQueue.d.ts.map +1 -0
- package/dist/hub/tui/components/AgentQueue.js +20 -0
- package/dist/hub/tui/components/AgentQueue.js.map +1 -0
- package/dist/hub/tui/components/DAGPanel.d.ts +16 -0
- package/dist/hub/tui/components/DAGPanel.d.ts.map +1 -0
- package/dist/hub/tui/components/DAGPanel.js +51 -0
- package/dist/hub/tui/components/DAGPanel.js.map +1 -0
- package/dist/hub/tui/components/Header.d.ts +7 -0
- package/dist/hub/tui/components/Header.d.ts.map +1 -0
- package/dist/hub/tui/components/Header.js +17 -0
- package/dist/hub/tui/components/Header.js.map +1 -0
- package/dist/hub/tui/components/LogsPanel.d.ts +6 -0
- package/dist/hub/tui/components/LogsPanel.d.ts.map +1 -0
- package/dist/hub/tui/components/LogsPanel.js +26 -0
- package/dist/hub/tui/components/LogsPanel.js.map +1 -0
- package/dist/hub/tui/components/StatusBar.d.ts +8 -0
- package/dist/hub/tui/components/StatusBar.d.ts.map +1 -0
- package/dist/hub/tui/components/StatusBar.js +7 -0
- package/dist/hub/tui/components/StatusBar.js.map +1 -0
- package/dist/hub/tui/hooks/useEvents.d.ts +2 -0
- package/dist/hub/tui/hooks/useEvents.d.ts.map +1 -0
- package/dist/hub/tui/hooks/useEvents.js +13 -0
- package/dist/hub/tui/hooks/useEvents.js.map +1 -0
- package/dist/hub/tui/index.d.ts.map +1 -0
- package/dist/hub/tui/index.js +7 -0
- package/dist/hub/tui/index.js.map +1 -0
- package/dist/hub/tui/types.d.ts.map +1 -0
- package/dist/hub/tui/types.js +2 -0
- package/dist/hub/tui/types.js.map +1 -0
- package/dist/hub/types.d.ts.map +1 -0
- package/dist/hub/types.js +2 -0
- package/dist/hub/types.js.map +1 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -0
- package/dist/init-host.d.ts.map +1 -0
- package/dist/init-host.js +232 -0
- package/dist/init-host.js.map +1 -0
- package/dist/install.d.ts.map +1 -0
- package/dist/install.js +99 -0
- package/dist/install.js.map +1 -0
- package/dist/run.d.ts.map +1 -0
- package/dist/run.js +238 -0
- package/dist/run.js.map +1 -0
- package/dist/setup/components/ApiKeyInput.d.ts +25 -0
- package/dist/setup/components/ApiKeyInput.d.ts.map +1 -0
- package/dist/setup/components/ApiKeyInput.js +54 -0
- package/dist/setup/components/ApiKeyInput.js.map +1 -0
- package/dist/setup/components/AsciiBanner.d.ts +22 -0
- package/dist/setup/components/AsciiBanner.d.ts.map +1 -0
- package/dist/setup/components/AsciiBanner.js +55 -0
- package/dist/setup/components/AsciiBanner.js.map +1 -0
- package/dist/setup/components/CliDetector.d.ts +17 -0
- package/dist/setup/components/CliDetector.d.ts.map +1 -0
- package/dist/setup/components/CliDetector.js +79 -0
- package/dist/setup/components/CliDetector.js.map +1 -0
- package/dist/setup/components/ModeSelector.d.ts +8 -0
- package/dist/setup/components/ModeSelector.d.ts.map +1 -0
- package/dist/setup/components/ModeSelector.js +76 -0
- package/dist/setup/components/ModeSelector.js.map +1 -0
- package/dist/setup/components/ProviderSelector.d.ts +18 -0
- package/dist/setup/components/ProviderSelector.d.ts.map +1 -0
- package/dist/setup/components/ProviderSelector.js +97 -0
- package/dist/setup/components/ProviderSelector.js.map +1 -0
- package/dist/setup/components/SetupWizard.d.ts +2 -0
- package/dist/setup/components/SetupWizard.d.ts.map +1 -0
- package/dist/setup/components/SetupWizard.js +212 -0
- package/dist/setup/components/SetupWizard.js.map +1 -0
- package/dist/setup/components/StepIndicator.d.ts +13 -0
- package/dist/setup/components/StepIndicator.d.ts.map +1 -0
- package/dist/setup/components/StepIndicator.js +18 -0
- package/dist/setup/components/StepIndicator.js.map +1 -0
- package/dist/setup/components/SuccessScreen.d.ts +18 -0
- package/dist/setup/components/SuccessScreen.d.ts.map +1 -0
- package/dist/setup/components/SuccessScreen.js +38 -0
- package/dist/setup/components/SuccessScreen.js.map +1 -0
- package/dist/setup/index.d.ts +12 -0
- package/dist/setup/index.d.ts.map +1 -0
- package/dist/setup/index.js +29 -0
- package/dist/setup/index.js.map +1 -0
- package/dist/setup/utils/cli-detection.d.ts +12 -0
- package/dist/setup/utils/cli-detection.d.ts.map +1 -0
- package/dist/setup/utils/cli-detection.js +83 -0
- package/dist/setup/utils/cli-detection.js.map +1 -0
- package/dist/setup/utils/config-writer.d.ts +43 -0
- package/dist/setup/utils/config-writer.d.ts.map +1 -0
- package/dist/setup/utils/config-writer.js +180 -0
- package/dist/setup/utils/config-writer.js.map +1 -0
- package/dist/styles.d.ts.map +1 -0
- package/dist/styles.js +12 -0
- package/dist/styles.js.map +1 -0
- package/dist/tui/App.d.ts +3 -0
- package/dist/tui/App.d.ts.map +1 -0
- package/dist/tui/App.js +131 -0
- package/dist/tui/App.js.map +1 -0
- package/dist/tui/components/AgentStateIcon.d.ts +18 -0
- package/dist/tui/components/AgentStateIcon.d.ts.map +1 -0
- package/dist/tui/components/AgentStateIcon.js +57 -0
- package/dist/tui/components/AgentStateIcon.js.map +1 -0
- package/dist/tui/components/AnimatedBranch.d.ts +39 -0
- package/dist/tui/components/AnimatedBranch.d.ts.map +1 -0
- package/dist/tui/components/AnimatedBranch.js +64 -0
- package/dist/tui/components/AnimatedBranch.js.map +1 -0
- package/dist/tui/components/ChatPanel.d.ts +16 -0
- package/dist/tui/components/ChatPanel.d.ts.map +1 -0
- package/dist/tui/components/ChatPanel.js +50 -0
- package/dist/tui/components/ChatPanel.js.map +1 -0
- package/dist/tui/components/DAGPanel.d.ts +36 -0
- package/dist/tui/components/DAGPanel.d.ts.map +1 -0
- package/dist/tui/components/DAGPanel.js +51 -0
- package/dist/tui/components/DAGPanel.js.map +1 -0
- package/dist/tui/components/ExecutionTimeline.d.ts +34 -0
- package/dist/tui/components/ExecutionTimeline.d.ts.map +1 -0
- package/dist/tui/components/ExecutionTimeline.js +67 -0
- package/dist/tui/components/ExecutionTimeline.js.map +1 -0
- package/dist/tui/components/Header.d.ts +12 -0
- package/dist/tui/components/Header.d.ts.map +1 -0
- package/dist/tui/components/Header.js +32 -0
- package/dist/tui/components/Header.js.map +1 -0
- package/dist/tui/components/HelpOverlay.d.ts +7 -0
- package/dist/tui/components/HelpOverlay.d.ts.map +1 -0
- package/dist/tui/components/HelpOverlay.js +60 -0
- package/dist/tui/components/HelpOverlay.js.map +1 -0
- package/dist/tui/components/InputBar.d.ts +10 -0
- package/dist/tui/components/InputBar.d.ts.map +1 -0
- package/dist/tui/components/InputBar.js +21 -0
- package/dist/tui/components/InputBar.js.map +1 -0
- package/dist/tui/components/LogsPanel.d.ts +9 -0
- package/dist/tui/components/LogsPanel.d.ts.map +1 -0
- package/dist/tui/components/LogsPanel.js +56 -0
- package/dist/tui/components/LogsPanel.js.map +1 -0
- package/dist/tui/components/MemoryPanel.d.ts +21 -0
- package/dist/tui/components/MemoryPanel.d.ts.map +1 -0
- package/dist/tui/components/MemoryPanel.js +51 -0
- package/dist/tui/components/MemoryPanel.js.map +1 -0
- package/dist/tui/components/MetricsPanel.d.ts +18 -0
- package/dist/tui/components/MetricsPanel.d.ts.map +1 -0
- package/dist/tui/components/MetricsPanel.js +27 -0
- package/dist/tui/components/MetricsPanel.js.map +1 -0
- package/dist/tui/components/StatusPanel.d.ts +23 -0
- package/dist/tui/components/StatusPanel.d.ts.map +1 -0
- package/dist/tui/components/StatusPanel.js +23 -0
- package/dist/tui/components/StatusPanel.js.map +1 -0
- package/dist/tui/components/TaskTree.d.ts +28 -0
- package/dist/tui/components/TaskTree.d.ts.map +1 -0
- package/dist/tui/components/TaskTree.js +29 -0
- package/dist/tui/components/TaskTree.js.map +1 -0
- package/dist/tui/components/animations/ProgressBar.d.ts +39 -0
- package/dist/tui/components/animations/ProgressBar.d.ts.map +1 -0
- package/dist/tui/components/animations/ProgressBar.js +39 -0
- package/dist/tui/components/animations/ProgressBar.js.map +1 -0
- package/dist/tui/components/animations/Pulse.d.ts +17 -0
- package/dist/tui/components/animations/Pulse.d.ts.map +1 -0
- package/dist/tui/components/animations/Pulse.js +47 -0
- package/dist/tui/components/animations/Pulse.js.map +1 -0
- package/dist/tui/components/animations/Spinner.d.ts +13 -0
- package/dist/tui/components/animations/Spinner.d.ts.map +1 -0
- package/dist/tui/components/animations/Spinner.js +36 -0
- package/dist/tui/components/animations/Spinner.js.map +1 -0
- package/dist/tui/components/animations/StatusAnimator.d.ts +27 -0
- package/dist/tui/components/animations/StatusAnimator.d.ts.map +1 -0
- package/dist/tui/components/animations/StatusAnimator.js +85 -0
- package/dist/tui/components/animations/StatusAnimator.js.map +1 -0
- package/dist/tui/components/animations/TypingEffect.d.ts +26 -0
- package/dist/tui/components/animations/TypingEffect.d.ts.map +1 -0
- package/dist/tui/components/animations/TypingEffect.js +59 -0
- package/dist/tui/components/animations/TypingEffect.js.map +1 -0
- package/dist/tui/components/animations/index.d.ts +8 -0
- package/dist/tui/components/animations/index.d.ts.map +1 -0
- package/dist/tui/components/animations/index.js +6 -0
- package/dist/tui/components/animations/index.js.map +1 -0
- package/dist/tui/hooks/useAnimation.d.ts +42 -0
- package/dist/tui/hooks/useAnimation.d.ts.map +1 -0
- package/dist/tui/hooks/useAnimation.js +212 -0
- package/dist/tui/hooks/useAnimation.js.map +1 -0
- package/dist/tui/hooks/useAppState.d.ts +65 -0
- package/dist/tui/hooks/useAppState.d.ts.map +1 -0
- package/dist/tui/hooks/useAppState.js +293 -0
- package/dist/tui/hooks/useAppState.js.map +1 -0
- package/dist/tui/index.d.ts +3 -0
- package/dist/tui/index.d.ts.map +1 -0
- package/dist/tui/index.js +8 -0
- package/dist/tui/index.js.map +1 -0
- package/dist/tui/services/orchestrator.d.ts +16 -0
- package/dist/tui/services/orchestrator.d.ts.map +1 -0
- package/dist/tui/services/orchestrator.js +152 -0
- package/dist/tui/services/orchestrator.js.map +1 -0
- package/dist/tui/styles/borders.d.ts +31 -0
- package/dist/tui/styles/borders.d.ts.map +1 -0
- package/dist/tui/styles/borders.js +47 -0
- package/dist/tui/styles/borders.js.map +1 -0
- package/dist/tui/styles/colors.d.ts +18 -0
- package/dist/tui/styles/colors.d.ts.map +1 -0
- package/dist/tui/styles/colors.js +18 -0
- package/dist/tui/styles/colors.js.map +1 -0
- package/dist/tui/styles/index.d.ts +6 -0
- package/dist/tui/styles/index.d.ts.map +1 -0
- package/dist/tui/styles/index.js +6 -0
- package/dist/tui/styles/index.js.map +1 -0
- package/dist/tui/styles/indicators.d.ts +67 -0
- package/dist/tui/styles/indicators.d.ts.map +1 -0
- package/dist/tui/styles/indicators.js +42 -0
- package/dist/tui/styles/indicators.js.map +1 -0
- package/dist/tui/styles/layout.d.ts +21 -0
- package/dist/tui/styles/layout.d.ts.map +1 -0
- package/dist/tui/styles/layout.js +42 -0
- package/dist/tui/styles/layout.js.map +1 -0
- package/dist/tui/styles/providers.d.ts +77 -0
- package/dist/tui/styles/providers.d.ts.map +1 -0
- package/dist/tui/styles/providers.js +31 -0
- package/dist/tui/styles/providers.js.map +1 -0
- package/dist/tui/utils/animation.d.ts +44 -0
- package/dist/tui/utils/animation.d.ts.map +1 -0
- package/dist/tui/utils/animation.js +107 -0
- package/dist/tui/utils/animation.js.map +1 -0
- package/dist/vendor-manifests.d.ts.map +1 -0
- package/dist/vendor-manifests.js +94 -0
- package/dist/vendor-manifests.js.map +1 -0
- package/dist/ws-relay.d.ts +12 -0
- package/dist/ws-relay.d.ts.map +1 -0
- package/dist/ws-relay.js +148 -0
- package/dist/ws-relay.js.map +1 -0
- package/package.json +34 -0
- package/src/benchmark.ts +156 -0
- package/src/bin.ts +156 -0
- package/src/bootstrap.ts +36 -0
- package/src/bridge-adapter-templates.ts +181 -0
- package/src/bridge-test.ts +107 -0
- package/src/dashboard.ts +51 -0
- package/src/doctor.ts +92 -0
- package/src/evolve.ts +74 -0
- package/src/host-init-templates.ts +134 -0
- package/src/hub/__tests__/commands.test.ts +84 -0
- package/src/hub/__tests__/history.test.ts +137 -0
- package/src/hub/__tests__/parser.test.ts +105 -0
- package/src/hub/commands/agents.ts +53 -0
- package/src/hub/commands/index.ts +140 -0
- package/src/hub/commands/logs.ts +70 -0
- package/src/hub/commands/memory.ts +47 -0
- package/src/hub/commands/metrics.ts +49 -0
- package/src/hub/commands/providers.ts +39 -0
- package/src/hub/commands/run.ts +37 -0
- package/src/hub/commands/status.ts +69 -0
- package/src/hub/commands/workflows.ts +64 -0
- package/src/hub/config-loader.ts +37 -0
- package/src/hub/event-listener.ts +17 -0
- package/src/hub/history.ts +66 -0
- package/src/hub/index.ts +132 -0
- package/src/hub/parser.ts +107 -0
- package/src/hub/styles/borders.ts +74 -0
- package/src/hub/styles/colors.ts +129 -0
- package/src/hub/styles/typography.ts +68 -0
- package/src/hub/types.ts +31 -0
- package/src/index.ts +10 -0
- package/src/init-host.ts +285 -0
- package/src/install.ts +118 -0
- package/src/run.ts +317 -0
- package/src/setup/components/ApiKeyInput.tsx +158 -0
- package/src/setup/components/AsciiBanner.tsx +125 -0
- package/src/setup/components/CliDetector.tsx +230 -0
- package/src/setup/components/ModeSelector.tsx +137 -0
- package/src/setup/components/ProviderSelector.tsx +174 -0
- package/src/setup/components/SetupWizard.tsx +368 -0
- package/src/setup/components/StepIndicator.tsx +74 -0
- package/src/setup/components/SuccessScreen.tsx +229 -0
- package/src/setup/index.ts +34 -0
- package/src/setup/utils/cli-detection.ts +99 -0
- package/src/setup/utils/config-writer.ts +249 -0
- package/src/styles.ts +12 -0
- package/src/tui/App.tsx +177 -0
- package/src/tui/components/AgentStateIcon.tsx +84 -0
- package/src/tui/components/AnimatedBranch.tsx +134 -0
- package/src/tui/components/ChatPanel.tsx +125 -0
- package/src/tui/components/DAGPanel.tsx +208 -0
- package/src/tui/components/ExecutionTimeline.tsx +225 -0
- package/src/tui/components/Header.tsx +109 -0
- package/src/tui/components/HelpOverlay.tsx +140 -0
- package/src/tui/components/InputBar.tsx +69 -0
- package/src/tui/components/LogsPanel.tsx +129 -0
- package/src/tui/components/MemoryPanel.tsx +163 -0
- package/src/tui/components/MetricsPanel.tsx +149 -0
- package/src/tui/components/StatusPanel.tsx +137 -0
- package/src/tui/components/TaskTree.tsx +159 -0
- package/src/tui/components/animations/ProgressBar.tsx +160 -0
- package/src/tui/components/animations/Pulse.tsx +73 -0
- package/src/tui/components/animations/Spinner.tsx +54 -0
- package/src/tui/components/animations/StatusAnimator.tsx +153 -0
- package/src/tui/components/animations/TypingEffect.tsx +119 -0
- package/src/tui/components/animations/index.ts +16 -0
- package/src/tui/hooks/useAnimation.ts +290 -0
- package/src/tui/hooks/useAppState.ts +403 -0
- package/src/tui/index.ts +9 -0
- package/src/tui/services/orchestrator.ts +195 -0
- package/src/tui/styles/borders.ts +51 -0
- package/src/tui/styles/colors.ts +19 -0
- package/src/tui/styles/index.ts +20 -0
- package/src/tui/styles/indicators.ts +54 -0
- package/src/tui/styles/layout.ts +44 -0
- package/src/tui/styles/providers.ts +32 -0
- package/src/tui/utils/animation.ts +124 -0
- package/src/vendor-manifests.ts +113 -0
- package/src/ws-relay.ts +156 -0
- package/tsconfig.json +28 -0
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
import { HostTarget } from "./host-init-templates.js";
|
|
2
|
+
|
|
3
|
+
function vendorCallFunction(target: HostTarget): string {
|
|
4
|
+
if (target === "claude-code") return "callClaudeCodeRuntime";
|
|
5
|
+
if (target === "codex") return "callCodexRuntime";
|
|
6
|
+
if (target === "opencode") return "callOpenCodeRuntime";
|
|
7
|
+
if (target === "kilo") return "callKiloRuntime";
|
|
8
|
+
return "callGenericHostRuntime";
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
function vendorNotes(target: HostTarget): string {
|
|
12
|
+
if (target === "claude-code") {
|
|
13
|
+
return [
|
|
14
|
+
"// Claude Code integration notes:",
|
|
15
|
+
"// - Map `payload.action` to Claude Code message/runtime API.",
|
|
16
|
+
"// - Ensure structured mode returns strict JSON object, not markdown.",
|
|
17
|
+
""
|
|
18
|
+
].join("\n");
|
|
19
|
+
}
|
|
20
|
+
if (target === "codex") {
|
|
21
|
+
return [
|
|
22
|
+
"// Codex integration notes:",
|
|
23
|
+
"// - Map payload.options.model to your Codex runtime model selector.",
|
|
24
|
+
"// - For callStructured, return parsed JSON object only.",
|
|
25
|
+
""
|
|
26
|
+
].join("\n");
|
|
27
|
+
}
|
|
28
|
+
if (target === "opencode") {
|
|
29
|
+
return [
|
|
30
|
+
"// OpenCode integration notes:",
|
|
31
|
+
"// - Connect to OpenCode model invocation API/SDK.",
|
|
32
|
+
"// - Preserve latency and model name in response when possible.",
|
|
33
|
+
""
|
|
34
|
+
].join("\n");
|
|
35
|
+
}
|
|
36
|
+
if (target === "kilo") {
|
|
37
|
+
return [
|
|
38
|
+
"// Kilo integration notes:",
|
|
39
|
+
"// - Route both actions through Kilo's model runtime.",
|
|
40
|
+
"// - Handle model fallback inside runtime wrapper if supported.",
|
|
41
|
+
""
|
|
42
|
+
].join("\n");
|
|
43
|
+
}
|
|
44
|
+
return [
|
|
45
|
+
"// Generic host integration notes:",
|
|
46
|
+
"// - Replace runtime call with your environment-specific function.",
|
|
47
|
+
"// - Keep response aligned with HostBridgeResponse schema.",
|
|
48
|
+
""
|
|
49
|
+
].join("\n");
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export function renderBridgeAdapter(target: HostTarget): string {
|
|
53
|
+
const runtimeFn = vendorCallFunction(target);
|
|
54
|
+
return [
|
|
55
|
+
"#!/usr/bin/env node",
|
|
56
|
+
"",
|
|
57
|
+
"/**",
|
|
58
|
+
` * RAX-FLOW bridge adapter scaffold for ${target}.`,
|
|
59
|
+
" *",
|
|
60
|
+
" * Input : HostBridgeRequest JSON on stdin",
|
|
61
|
+
" * Output: HostBridgeResponse JSON on stdout",
|
|
62
|
+
" */",
|
|
63
|
+
"",
|
|
64
|
+
"import { readFileSync } from \"node:fs\";",
|
|
65
|
+
"import path from \"node:path\";",
|
|
66
|
+
"",
|
|
67
|
+
"function readStdin() {",
|
|
68
|
+
" return new Promise((resolve) => {",
|
|
69
|
+
" let data = \"\";",
|
|
70
|
+
" process.stdin.setEncoding(\"utf8\");",
|
|
71
|
+
" process.stdin.on(\"data\", (chunk) => { data += chunk; });",
|
|
72
|
+
" process.stdin.on(\"end\", () => resolve(data));",
|
|
73
|
+
" });",
|
|
74
|
+
"}",
|
|
75
|
+
"",
|
|
76
|
+
"function safeJsonParse(text) {",
|
|
77
|
+
" try { return JSON.parse(text); } catch { return null; }",
|
|
78
|
+
"}",
|
|
79
|
+
"",
|
|
80
|
+
"function normalizeError(error) {",
|
|
81
|
+
" if (!error) return \"unknown_error\";",
|
|
82
|
+
" if (typeof error === \"string\") return error;",
|
|
83
|
+
" return error.message || String(error);",
|
|
84
|
+
"}",
|
|
85
|
+
"",
|
|
86
|
+
"function isStructuredPayload(obj) {",
|
|
87
|
+
" return obj && typeof obj === \"object\" &&",
|
|
88
|
+
" typeof obj.agent === \"string\" &&",
|
|
89
|
+
" typeof obj.success === \"boolean\" &&",
|
|
90
|
+
" typeof obj.confidence === \"number\" &&",
|
|
91
|
+
" Array.isArray(obj.risks) &&",
|
|
92
|
+
" Array.isArray(obj.logs) &&",
|
|
93
|
+
" obj.data && typeof obj.data === \"object\";",
|
|
94
|
+
"}",
|
|
95
|
+
"",
|
|
96
|
+
"function loadRuntimeConfig() {",
|
|
97
|
+
" const file = path.join(process.cwd(), '.rax-flow', 'host-init', '" + target + "', 'bridge-runtime-config.json');",
|
|
98
|
+
" try {",
|
|
99
|
+
" return JSON.parse(readFileSync(file, 'utf8'));",
|
|
100
|
+
" } catch {",
|
|
101
|
+
" return {",
|
|
102
|
+
" vendor: '" + target + "',",
|
|
103
|
+
" model: 'host-managed',",
|
|
104
|
+
" endpoint: null,",
|
|
105
|
+
" authEnv: null,",
|
|
106
|
+
" structuredMode: 'json',",
|
|
107
|
+
" responseStrict: true,",
|
|
108
|
+
" timeoutMs: 20000",
|
|
109
|
+
" };",
|
|
110
|
+
" }",
|
|
111
|
+
"}",
|
|
112
|
+
"",
|
|
113
|
+
vendorNotes(target),
|
|
114
|
+
"// callHostModel is the bridge interface for runtime calls",
|
|
115
|
+
`async function ${runtimeFn}(payload, runtimeConfig) {`,
|
|
116
|
+
" // TODO: implement real runtime call for this vendor.",
|
|
117
|
+
" // payload.action = callModel | callStructured",
|
|
118
|
+
" // runtimeConfig can provide endpoint/auth/model/runtime settings.",
|
|
119
|
+
" if (payload.action === 'callStructured') {",
|
|
120
|
+
" return {",
|
|
121
|
+
" ok: true,",
|
|
122
|
+
" model: runtimeConfig.model || payload.options?.model || 'host-managed',",
|
|
123
|
+
" latencyMs: 8,",
|
|
124
|
+
" output: {",
|
|
125
|
+
" agent: 'VendorBridgeTemplate',",
|
|
126
|
+
" success: true,",
|
|
127
|
+
" confidence: 0.73,",
|
|
128
|
+
" risks: [],",
|
|
129
|
+
" logs: ['replace with real vendor runtime response'],",
|
|
130
|
+
" data: { summary: 'template structured output', nextAction: 'continue' }",
|
|
131
|
+
" }",
|
|
132
|
+
" };",
|
|
133
|
+
" }",
|
|
134
|
+
" return {",
|
|
135
|
+
" ok: true,",
|
|
136
|
+
" model: runtimeConfig.model || payload.options?.model || 'host-managed',",
|
|
137
|
+
" latencyMs: 8,",
|
|
138
|
+
" output: `template-text:${String(payload.prompt || '').slice(0, 220)}`",
|
|
139
|
+
" };",
|
|
140
|
+
"}",
|
|
141
|
+
"",
|
|
142
|
+
"async function main() {",
|
|
143
|
+
" const input = await readStdin();",
|
|
144
|
+
" const payload = safeJsonParse(input);",
|
|
145
|
+
" if (!payload || payload.version !== 1 || !payload.action) {",
|
|
146
|
+
" process.stdout.write(JSON.stringify({ ok: false, error: 'invalid_payload' }));",
|
|
147
|
+
" return;",
|
|
148
|
+
" }",
|
|
149
|
+
"",
|
|
150
|
+
" const runtimeConfig = loadRuntimeConfig();",
|
|
151
|
+
"",
|
|
152
|
+
" try {",
|
|
153
|
+
` const response = await ${runtimeFn}(payload, runtimeConfig);`,
|
|
154
|
+
" if (payload.action === 'callStructured' && runtimeConfig.responseStrict) {",
|
|
155
|
+
" if (!response || !isStructuredPayload(response.output)) {",
|
|
156
|
+
" process.stdout.write(JSON.stringify({",
|
|
157
|
+
" ok: false,",
|
|
158
|
+
" error: 'structured_output_invalid',",
|
|
159
|
+
" details: 'Ensure output contains agent/success/confidence/risks/logs/data',",
|
|
160
|
+
" }));",
|
|
161
|
+
" return;",
|
|
162
|
+
" }",
|
|
163
|
+
" }",
|
|
164
|
+
" process.stdout.write(JSON.stringify(response));",
|
|
165
|
+
" } catch (error) {",
|
|
166
|
+
" process.stdout.write(JSON.stringify({ ok: false, error: `bridge_exception:${normalizeError(error)}` }));",
|
|
167
|
+
" }",
|
|
168
|
+
"}",
|
|
169
|
+
"",
|
|
170
|
+
"main();",
|
|
171
|
+
""
|
|
172
|
+
].join("\n");
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
export function bridgeAdapterFilename(target: HostTarget): string {
|
|
176
|
+
if (target === "claude-code") return "bridge-adapter-claude-code.mjs";
|
|
177
|
+
if (target === "codex") return "bridge-adapter-codex.mjs";
|
|
178
|
+
if (target === "opencode") return "bridge-adapter-opencode.mjs";
|
|
179
|
+
if (target === "kilo") return "bridge-adapter-kilo.mjs";
|
|
180
|
+
return "bridge-adapter-generic.mjs";
|
|
181
|
+
}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { readFile } from "node:fs/promises";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { spawn } from "node:child_process";
|
|
4
|
+
import { c } from "./styles.js";
|
|
5
|
+
import { parseHostTarget } from "./host-init-templates.js";
|
|
6
|
+
|
|
7
|
+
interface BridgeTestOptions {
|
|
8
|
+
cwd: string;
|
|
9
|
+
target?: string;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
function parseShellCommand(input: string): { command: string; args: string[] } {
|
|
13
|
+
const parts = input.match(/(?:[^\s"]+|"[^"]*")+/g) ?? [];
|
|
14
|
+
if (parts.length === 0) {
|
|
15
|
+
throw new Error("invalid_bridge_command");
|
|
16
|
+
}
|
|
17
|
+
const [command, ...rawArgs] = parts;
|
|
18
|
+
const args = rawArgs.map((arg) => arg.replace(/^"|"$/g, ""));
|
|
19
|
+
return { command: command!, args };
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
async function runCommand(commandSpec: string, payload: unknown): Promise<{ code: number; stdout: string; stderr: string }> {
|
|
23
|
+
const { command, args } = parseShellCommand(commandSpec);
|
|
24
|
+
return await new Promise((resolve, reject) => {
|
|
25
|
+
const child = spawn(command, args, { stdio: ["pipe", "pipe", "pipe"] });
|
|
26
|
+
let stdout = "";
|
|
27
|
+
let stderr = "";
|
|
28
|
+
|
|
29
|
+
child.stdout.on("data", (chunk) => {
|
|
30
|
+
stdout += String(chunk);
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
child.stderr.on("data", (chunk) => {
|
|
34
|
+
stderr += String(chunk);
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
child.on("error", (error) => reject(error));
|
|
38
|
+
child.on("close", (code) => resolve({ code: code ?? 1, stdout, stderr }));
|
|
39
|
+
|
|
40
|
+
child.stdin.write(JSON.stringify(payload));
|
|
41
|
+
child.stdin.end();
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export async function runBridgeTest(options: BridgeTestOptions): Promise<number> {
|
|
46
|
+
const target = parseHostTarget(options.target);
|
|
47
|
+
const baseDir = path.join(options.cwd, ".rax-flow", "host-init", target);
|
|
48
|
+
const manifestFile = path.join(baseDir, "host-manifest.json");
|
|
49
|
+
const smokeFile = path.join(baseDir, "bridge-smoke-test.json");
|
|
50
|
+
|
|
51
|
+
let manifest: { bridgeCommand?: string };
|
|
52
|
+
let smokePayload: unknown;
|
|
53
|
+
|
|
54
|
+
try {
|
|
55
|
+
manifest = JSON.parse(await readFile(manifestFile, "utf8")) as { bridgeCommand?: string };
|
|
56
|
+
} catch {
|
|
57
|
+
console.error(c.red(`Missing host manifest: ${manifestFile}`));
|
|
58
|
+
return 1;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
try {
|
|
62
|
+
smokePayload = JSON.parse(await readFile(smokeFile, "utf8"));
|
|
63
|
+
} catch {
|
|
64
|
+
console.error(c.red(`Missing bridge smoke test payload: ${smokeFile}`));
|
|
65
|
+
return 1;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
if (!manifest.bridgeCommand) {
|
|
69
|
+
console.error(c.red("host-manifest.json missing bridgeCommand"));
|
|
70
|
+
return 1;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const result = await runCommand(manifest.bridgeCommand, smokePayload);
|
|
74
|
+
console.log(c.blue(`RAX-FLOW Bridge Test (${target})`));
|
|
75
|
+
console.log(`command: ${manifest.bridgeCommand}`);
|
|
76
|
+
console.log(`exitCode: ${result.code}`);
|
|
77
|
+
|
|
78
|
+
if (result.stdout.trim()) {
|
|
79
|
+
console.log("stdout:");
|
|
80
|
+
console.log(result.stdout.trim());
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
if (result.stderr.trim()) {
|
|
84
|
+
console.log("stderr:");
|
|
85
|
+
console.log(result.stderr.trim());
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
if (result.code !== 0) {
|
|
89
|
+
console.log(c.red("Bridge smoke test failed."));
|
|
90
|
+
return 1;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
try {
|
|
94
|
+
const parsed = JSON.parse(result.stdout);
|
|
95
|
+
const ok = Boolean(parsed?.ok);
|
|
96
|
+
if (!ok) {
|
|
97
|
+
console.log(c.red(`Bridge responded with ok=false: ${parsed?.error ?? "unknown"}`));
|
|
98
|
+
return 1;
|
|
99
|
+
}
|
|
100
|
+
} catch {
|
|
101
|
+
console.log(c.red("Bridge output is not valid JSON."));
|
|
102
|
+
return 1;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
console.log(c.green("Bridge smoke test passed."));
|
|
106
|
+
return 0;
|
|
107
|
+
}
|
package/src/dashboard.ts
ADDED
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import http from "node:http";
|
|
2
|
+
import { readFile } from "node:fs/promises";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { fileURLToPath } from "node:url";
|
|
5
|
+
|
|
6
|
+
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
7
|
+
|
|
8
|
+
export async function runDashboard({ port = 3003 }: { port?: number } = {}): Promise<number> {
|
|
9
|
+
const server = http.createServer(async (req, res) => {
|
|
10
|
+
// Simple static server for the dashboard
|
|
11
|
+
if (req.url === "/" || req.url === "/index.html") {
|
|
12
|
+
try {
|
|
13
|
+
// Try to find the dashboard file
|
|
14
|
+
// In the monorepo, it's in packages/cli/dashboard/index.html
|
|
15
|
+
// When installed as a package, it will be relative to this file
|
|
16
|
+
let htmlPath = path.join(process.cwd(), "packages/cli/dashboard/index.html");
|
|
17
|
+
|
|
18
|
+
// Fallback for when running from dist or installed package
|
|
19
|
+
try {
|
|
20
|
+
await readFile(htmlPath);
|
|
21
|
+
} catch {
|
|
22
|
+
htmlPath = path.join(__dirname, "..", "dashboard", "index.html");
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const content = await readFile(htmlPath, "utf8");
|
|
26
|
+
res.writeHead(200, { "Content-Type": "text/html" });
|
|
27
|
+
res.end(content);
|
|
28
|
+
} catch (err) {
|
|
29
|
+
console.error("[UI] Error loading dashboard:", err);
|
|
30
|
+
res.writeHead(500);
|
|
31
|
+
res.end("Error loading dashboard. Please ensure you are running from the project root.");
|
|
32
|
+
}
|
|
33
|
+
} else {
|
|
34
|
+
res.writeHead(404);
|
|
35
|
+
res.end("Not Found");
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
return new Promise((resolve) => {
|
|
40
|
+
server.listen(port, () => {
|
|
41
|
+
console.log(`\n[UI] 🚀 RAX Dashboard started on http://localhost:${port}`);
|
|
42
|
+
console.log(`[UI] Monitoring kernel evolution and workflow health.`);
|
|
43
|
+
console.log(`[UI] Press Ctrl+C to stop.`);
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
process.on("SIGINT", () => {
|
|
47
|
+
server.close();
|
|
48
|
+
resolve(0);
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
}
|
package/src/doctor.ts
ADDED
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { readFile } from "node:fs/promises";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { HostBridgeAdapter } from "rax-flow-providers";
|
|
4
|
+
import { c } from "./styles.js";
|
|
5
|
+
|
|
6
|
+
interface DoctorOptions {
|
|
7
|
+
cwd: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
interface RaxConfig {
|
|
11
|
+
defaultProvider?: string;
|
|
12
|
+
strongProvider?: string;
|
|
13
|
+
providers?: {
|
|
14
|
+
host?: { model?: string; mode?: "auto" | "bridge-only" | "mock"; bridgeCommandEnv?: string; timeoutMs?: number };
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
async function loadConfig(cwd: string): Promise<RaxConfig | null> {
|
|
19
|
+
const file = path.join(cwd, ".raxrc");
|
|
20
|
+
try {
|
|
21
|
+
const raw = await readFile(file, "utf8");
|
|
22
|
+
return JSON.parse(raw) as RaxConfig;
|
|
23
|
+
} catch {
|
|
24
|
+
return null;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
function printLine(ok: boolean, label: string, details?: string) {
|
|
29
|
+
const icon = ok ? c.green("[ok]") : c.red("[fail]");
|
|
30
|
+
console.log(`${icon} ${label}${details ? ` - ${details}` : ""}`);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
export async function runDoctor(options: DoctorOptions): Promise<number> {
|
|
34
|
+
console.log(c.blue("RAXFLOW Doctor"));
|
|
35
|
+
|
|
36
|
+
const config = await loadConfig(options.cwd);
|
|
37
|
+
if (!config) {
|
|
38
|
+
printLine(false, "Missing .raxrc", "run `raxflow install` first");
|
|
39
|
+
return 1;
|
|
40
|
+
}
|
|
41
|
+
printLine(true, "Found .raxrc");
|
|
42
|
+
|
|
43
|
+
const hostCfg = config.providers?.host;
|
|
44
|
+
const bridgeCommandEnv = hostCfg?.bridgeCommandEnv ?? "RAX_HOST_BRIDGE_COMMAND";
|
|
45
|
+
const bridgeCommand = process.env[bridgeCommandEnv];
|
|
46
|
+
const provider = new HostBridgeAdapter({
|
|
47
|
+
model: hostCfg?.model ?? "host-managed",
|
|
48
|
+
mode: hostCfg?.mode ?? "auto",
|
|
49
|
+
command: bridgeCommand,
|
|
50
|
+
timeoutMs: hostCfg?.timeoutMs ?? 10000
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
const health = await provider.healthCheck();
|
|
54
|
+
printLine(health, "Host provider health", `mode=${hostCfg?.mode ?? "auto"}`);
|
|
55
|
+
|
|
56
|
+
const hasBridgeFn = typeof (globalThis as Record<string, unknown>).__RAX_HOST_BRIDGE__ === "function";
|
|
57
|
+
printLine(hasBridgeFn || Boolean(bridgeCommand), "Bridge source", hasBridgeFn ? "global bridge function" : bridgeCommand ? `command via ${bridgeCommandEnv}` : "auto/mock fallback");
|
|
58
|
+
|
|
59
|
+
try {
|
|
60
|
+
const ping = await provider.callModel("doctor ping", { model: hostCfg?.model ?? "host-managed", maxTokens: 32, temperature: 0 });
|
|
61
|
+
printLine(true, "callModel test", `provider=${ping.provider} model=${ping.model}`);
|
|
62
|
+
} catch (error) {
|
|
63
|
+
printLine(false, "callModel test", String(error));
|
|
64
|
+
return 1;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
try {
|
|
68
|
+
const structured = await provider.callStructured(
|
|
69
|
+
"doctor structured ping",
|
|
70
|
+
{
|
|
71
|
+
type: "object",
|
|
72
|
+
required: ["agent", "success", "confidence", "risks", "logs", "data"],
|
|
73
|
+
properties: {
|
|
74
|
+
agent: { type: "string" },
|
|
75
|
+
success: { type: "boolean" },
|
|
76
|
+
confidence: { type: "number" },
|
|
77
|
+
risks: { type: "array" },
|
|
78
|
+
logs: { type: "array" },
|
|
79
|
+
data: { type: "object" }
|
|
80
|
+
}
|
|
81
|
+
},
|
|
82
|
+
{ model: hostCfg?.model ?? "host-managed", maxTokens: 128, temperature: 0 }
|
|
83
|
+
);
|
|
84
|
+
printLine(true, "callStructured test", `model=${structured.model}`);
|
|
85
|
+
} catch (error) {
|
|
86
|
+
printLine(false, "callStructured test", String(error));
|
|
87
|
+
return 1;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
console.log(c.green("Doctor checks passed."));
|
|
91
|
+
return 0;
|
|
92
|
+
}
|
package/src/evolve.ts
ADDED
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { readFile, readdir } from "node:fs/promises";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { c } from "./styles.js";
|
|
4
|
+
|
|
5
|
+
interface EvolveOptions {
|
|
6
|
+
cwd: string;
|
|
7
|
+
history?: boolean;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
interface Blueprint {
|
|
11
|
+
id: string;
|
|
12
|
+
version: string;
|
|
13
|
+
createdAt: string;
|
|
14
|
+
fitnessScore: number;
|
|
15
|
+
mutationType: string;
|
|
16
|
+
metadata?: {
|
|
17
|
+
message?: string;
|
|
18
|
+
reason?: string;
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export async function showEvolution(options: EvolveOptions): Promise<number> {
|
|
23
|
+
const evolutionDir = path.join(options.cwd, ".rax-flow", "evolutions");
|
|
24
|
+
|
|
25
|
+
try {
|
|
26
|
+
const files = await readdir(evolutionDir);
|
|
27
|
+
const blueprintFiles = files.filter(f => f.startsWith("blueprint_") && f.endsWith(".json"));
|
|
28
|
+
|
|
29
|
+
if (blueprintFiles.length === 0) {
|
|
30
|
+
console.log(c.yellow("\nNo evolutions recorded yet. Run more tasks to trigger Darwinian mutations."));
|
|
31
|
+
return 0;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
const blueprints: Blueprint[] = [];
|
|
35
|
+
for (const file of blueprintFiles) {
|
|
36
|
+
const raw = await readFile(path.join(evolutionDir, file), "utf8");
|
|
37
|
+
blueprints.push(JSON.parse(raw) as Blueprint);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
// Sort by creation date
|
|
41
|
+
blueprints.sort((a, b) => new Date(a.createdAt).getTime() - new Date(b.createdAt).getTime());
|
|
42
|
+
|
|
43
|
+
console.log(c.bold(c.magenta(`\n\n--- [GENETIC LINEAGE: RAX-FLOW] ---`)));
|
|
44
|
+
console.log(c.gray(`Found ${blueprints.length} evolutionary jumps.\n`));
|
|
45
|
+
|
|
46
|
+
blueprints.forEach((bp, i) => {
|
|
47
|
+
const connector = i === blueprints.length - 1 ? "└" : "├";
|
|
48
|
+
const branch = i === 0 ? "" : ` ${connector}── `;
|
|
49
|
+
|
|
50
|
+
const scoreColor = bp.fitnessScore >= 0.8 ? c.green : (bp.fitnessScore >= 0.6 ? c.yellow : c.red);
|
|
51
|
+
|
|
52
|
+
console.log(`${branch}${c.bold(bp.id)} ${c.gray(`v${bp.version}`)}`);
|
|
53
|
+
console.log(` ${c.gray("Type:")} ${c.cyan(bp.mutationType)}`);
|
|
54
|
+
console.log(` ${c.gray("Fitness:")} ${scoreColor(bp.fitnessScore.toFixed(2))}`);
|
|
55
|
+
if (bp.metadata?.reason || bp.metadata?.message) {
|
|
56
|
+
console.log(` ${c.gray("Note:")} ${c.white(bp.metadata.reason || bp.metadata.message || "")}`);
|
|
57
|
+
}
|
|
58
|
+
if (i < blueprints.length - 1) {
|
|
59
|
+
console.log(` ${c.gray("│")}`);
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
console.log(c.bold(c.cyan(`\nSurvival of the fittest: Blueprint ${blueprints[blueprints.length - 1]?.id} is currently dominant.`)));
|
|
64
|
+
|
|
65
|
+
return 0;
|
|
66
|
+
} catch (error) {
|
|
67
|
+
if ((error as any).code === "ENOENT") {
|
|
68
|
+
console.log(c.yellow("\nNo evolutions directory found. Run tasks first."));
|
|
69
|
+
return 0;
|
|
70
|
+
}
|
|
71
|
+
console.error(c.red(`Failed to read evolution history: ${error}`));
|
|
72
|
+
return 1;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
export type HostTarget = "claude-code" | "codex" | "opencode" | "kilo" | "generic";
|
|
2
|
+
|
|
3
|
+
export interface HostTemplate {
|
|
4
|
+
id: HostTarget;
|
|
5
|
+
title: string;
|
|
6
|
+
envHint: string;
|
|
7
|
+
chatHint: string;
|
|
8
|
+
bootstrapPromptBase: string[];
|
|
9
|
+
quickCommands: string[];
|
|
10
|
+
autoInjectMode: "native" | "scripted" | "manual";
|
|
11
|
+
sessionEntryExamples: string[];
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export const HOST_TEMPLATES: Record<HostTarget, HostTemplate> = {
|
|
15
|
+
"claude-code": {
|
|
16
|
+
id: "claude-code",
|
|
17
|
+
title: "Claude Code",
|
|
18
|
+
envHint: "Export RAX_HOST_BRIDGE_COMMAND before starting Claude Code session.",
|
|
19
|
+
chatHint: "Paste BOOTSTRAP_PROMPT.txt at the beginning of the chat.",
|
|
20
|
+
bootstrapPromptBase: [
|
|
21
|
+
"RAXFLOW bootstrap (Claude Code)",
|
|
22
|
+
"- Enable host-native orchestration.",
|
|
23
|
+
"- Route generation through the configured host bridge.",
|
|
24
|
+
"- Keep structured JSON outputs for orchestration steps.",
|
|
25
|
+
"- Execute Verify -> Fix loop when schema validation fails.",
|
|
26
|
+
"- Report confidence, risk flags, and logs for each step."
|
|
27
|
+
],
|
|
28
|
+
quickCommands: ["npx raxflow doctor", "npx raxflow run --prompt \"Build feature X\" --stream"],
|
|
29
|
+
autoInjectMode: "scripted",
|
|
30
|
+
sessionEntryExamples: [
|
|
31
|
+
"claude-code chat --message-file .raxflow/host-init/claude-code/BOOTSTRAP_PROMPT.txt",
|
|
32
|
+
"claude-code (open session, then paste BOOTSTRAP_PROMPT.txt)"
|
|
33
|
+
]
|
|
34
|
+
},
|
|
35
|
+
codex: {
|
|
36
|
+
id: "codex",
|
|
37
|
+
title: "Codex",
|
|
38
|
+
envHint: "Set RAX_HOST_BRIDGE_COMMAND in the shell running Codex.",
|
|
39
|
+
chatHint: "Send BOOTSTRAP_PROMPT.txt as first instruction in session.",
|
|
40
|
+
bootstrapPromptBase: [
|
|
41
|
+
"RAXFLOW bootstrap (Codex)",
|
|
42
|
+
"- Use host-native model execution through the host bridge.",
|
|
43
|
+
"- Produce strict structured outputs for all agent steps.",
|
|
44
|
+
"- Apply Verify -> Fix until valid schema or retry cap.",
|
|
45
|
+
"- Include confidence and risks in every final step."
|
|
46
|
+
],
|
|
47
|
+
quickCommands: ["npx raxflow doctor", "npx raxflow run --prompt \"Build feature X\" --stream"],
|
|
48
|
+
autoInjectMode: "scripted",
|
|
49
|
+
sessionEntryExamples: [
|
|
50
|
+
"codex chat --message-file .raxflow/host-init/codex/BOOTSTRAP_PROMPT.txt",
|
|
51
|
+
"codex (open session, then paste BOOTSTRAP_PROMPT.txt)"
|
|
52
|
+
]
|
|
53
|
+
},
|
|
54
|
+
opencode: {
|
|
55
|
+
id: "opencode",
|
|
56
|
+
title: "OpenCode",
|
|
57
|
+
envHint: "Configure RAX_HOST_BRIDGE_COMMAND in OpenCode terminal/runtime env.",
|
|
58
|
+
chatHint: "Paste BOOTSTRAP_PROMPT.txt before requesting implementation.",
|
|
59
|
+
bootstrapPromptBase: [
|
|
60
|
+
"RAXFLOW bootstrap (OpenCode)",
|
|
61
|
+
"- Activate host bridge orchestration mode.",
|
|
62
|
+
"- Keep responses compact but structured for agent pipeline.",
|
|
63
|
+
"- Trigger fix cycles on validation failures automatically.",
|
|
64
|
+
"- Emit step logs and confidence scores."
|
|
65
|
+
],
|
|
66
|
+
quickCommands: ["npx raxflow doctor", "npx raxflow run --prompt \"Build feature X\" --stream"],
|
|
67
|
+
autoInjectMode: "manual",
|
|
68
|
+
sessionEntryExamples: [
|
|
69
|
+
"opencode chat --message-file .raxflow/host-init/opencode/BOOTSTRAP_PROMPT.txt",
|
|
70
|
+
"opencode (open session, then paste BOOTSTRAP_PROMPT.txt)"
|
|
71
|
+
]
|
|
72
|
+
},
|
|
73
|
+
kilo: {
|
|
74
|
+
id: "kilo",
|
|
75
|
+
title: "Kilo Code",
|
|
76
|
+
envHint: "Set RAX_HOST_BRIDGE_COMMAND in Kilo launch environment.",
|
|
77
|
+
chatHint: "Paste BOOTSTRAP_PROMPT.txt as initialization message.",
|
|
78
|
+
bootstrapPromptBase: [
|
|
79
|
+
"RAXFLOW bootstrap (Kilo)",
|
|
80
|
+
"- Run in host-native orchestration mode.",
|
|
81
|
+
"- Enforce structured output contract for each stage.",
|
|
82
|
+
"- Apply Verify -> Fix and escalate when confidence is low.",
|
|
83
|
+
"- Return actionable logs and risk flags."
|
|
84
|
+
],
|
|
85
|
+
quickCommands: ["npx raxflow doctor", "npx raxflow run --prompt \"Build feature X\" --stream"],
|
|
86
|
+
autoInjectMode: "manual",
|
|
87
|
+
sessionEntryExamples: [
|
|
88
|
+
"kilo chat --message-file .raxflow/host-init/kilo/BOOTSTRAP_PROMPT.txt",
|
|
89
|
+
"kilo (open session, then paste BOOTSTRAP_PROMPT.txt)"
|
|
90
|
+
]
|
|
91
|
+
},
|
|
92
|
+
generic: {
|
|
93
|
+
id: "generic",
|
|
94
|
+
title: "Generic Host",
|
|
95
|
+
envHint: "Provide a bridge command through RAX_HOST_BRIDGE_COMMAND.",
|
|
96
|
+
chatHint: "Paste BOOTSTRAP_PROMPT.txt at session start.",
|
|
97
|
+
bootstrapPromptBase: [
|
|
98
|
+
"RAXFLOW bootstrap (Generic)",
|
|
99
|
+
"- Enable orchestration through host bridge.",
|
|
100
|
+
"- Return strict JSON for each orchestration step.",
|
|
101
|
+
"- Retry/fix invalid outputs automatically.",
|
|
102
|
+
"- Report confidence, risks, and logs."
|
|
103
|
+
],
|
|
104
|
+
quickCommands: ["npx raxflow doctor", "npx raxflow run --prompt \"Build feature X\" --stream"],
|
|
105
|
+
autoInjectMode: "manual",
|
|
106
|
+
sessionEntryExamples: [
|
|
107
|
+
"your-host-cli chat --message-file .raxflow/host-init/generic/BOOTSTRAP_PROMPT.txt",
|
|
108
|
+
"open session, then paste BOOTSTRAP_PROMPT.txt"
|
|
109
|
+
]
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
export function parseHostTarget(value: string | undefined): HostTarget {
|
|
114
|
+
if (!value) return "generic";
|
|
115
|
+
if (value in HOST_TEMPLATES) return value as HostTarget;
|
|
116
|
+
return "generic";
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
export function listHostTargets(): HostTarget[] {
|
|
120
|
+
return Object.keys(HOST_TEMPLATES) as HostTarget[];
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
export function buildBootstrapPrompt(target: HostTarget, task?: string): string {
|
|
124
|
+
const template = HOST_TEMPLATES[target];
|
|
125
|
+
const lines = [...template.bootstrapPromptBase];
|
|
126
|
+
|
|
127
|
+
if (task && task.trim().length > 0) {
|
|
128
|
+
lines.push(`- Task context: ${task.trim()}`);
|
|
129
|
+
lines.push("- Keep orchestration aligned with this task context unless user changes scope.");
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
lines.push("- If bridge call fails, report issue clearly and keep orchestration state.");
|
|
133
|
+
return lines.join("\n");
|
|
134
|
+
}
|