@hatchway/cli 0.50.62 → 0.50.64
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/dist/chunks/Banner-B4nm86qK.js +27 -0
- package/dist/chunks/Banner-B4nm86qK.js.map +1 -0
- package/dist/chunks/{init-Ckj9MlWI.js → init-CBODHYDw.js} +4 -3
- package/dist/chunks/{init-Ckj9MlWI.js.map → init-CBODHYDw.js.map} +1 -1
- package/dist/chunks/{init-tui-m2supRiJ.js → init-tui-CcxzfgmC.js} +3 -2
- package/dist/chunks/{init-tui-m2supRiJ.js.map → init-tui-CcxzfgmC.js.map} +1 -1
- package/dist/chunks/{main-tui-DZ6e5DoU.js → main-tui-qySRaa-s.js} +5 -4
- package/dist/chunks/{main-tui-DZ6e5DoU.js.map → main-tui-qySRaa-s.js.map} +1 -1
- package/dist/chunks/{run-Du6dvTJL.js → run-BbxtXsLx.js} +3 -2
- package/dist/chunks/{run-Du6dvTJL.js.map → run-BbxtXsLx.js.map} +1 -1
- package/dist/chunks/{Banner-DL1Fpz_g.js → version-info-CDtU8Ta2.js} +3 -26
- package/dist/chunks/version-info-CDtU8Ta2.js.map +1 -0
- package/dist/cli/index.js +4 -4
- package/dist/index.js +64 -9
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/dist/chunks/Banner-DL1Fpz_g.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"run-Du6dvTJL.js","sources":["../../src/cli/tui/components/LogPanel.tsx","../../src/cli/tui/components/StatusBar.tsx","../../src/cli/tui/components/FullLogView.tsx","../../src/cli/tui/components/CopyMenu.tsx","../../src/cli/tui/screens/RunnerDashboard.tsx","../../src/cli/commands/run.ts"],"sourcesContent":["/**\n * LogPanel - Right panel showing scrollable log entries\n * Takes up 80% of width, shows:\n * - Timestamped log entries\n * - Tool calls with truncated args\n * - Scrollable with keyboard navigation\n */\n\nimport React, { useState, useEffect, useRef } from 'react';\nimport { Box, Text, useInput } from 'ink';\nimport { colors } from '../theme.js';\nimport type { LogEntry } from '../../../lib/logging/types.js';\n\ninterface LogPanelProps {\n entries: LogEntry[];\n isVerbose: boolean;\n width: number;\n height: number;\n isFocused: boolean;\n}\n\nexport function LogPanel({ entries, isVerbose, width, height, isFocused }: LogPanelProps) {\n const [scrollOffset, setScrollOffset] = useState(0);\n const [autoScroll, setAutoScroll] = useState(true);\n\n // Filter entries based on verbose mode\n const visibleEntries = isVerbose \n ? entries \n : entries.filter(e => !e.verbose);\n\n // Available height for log lines (subtract 2 for border, 1 for header)\n const visibleLines = Math.max(1, height - 3);\n\n // Auto-scroll when new entries arrive\n useEffect(() => {\n if (autoScroll && visibleEntries.length > 0) {\n const maxScroll = Math.max(0, visibleEntries.length - visibleLines);\n setScrollOffset(maxScroll);\n }\n }, [visibleEntries.length, autoScroll, visibleLines]);\n\n // Handle keyboard navigation\n useInput((input, key) => {\n if (!isFocused) return;\n\n if (key.upArrow) {\n setAutoScroll(false);\n setScrollOffset(prev => Math.max(0, prev - 1));\n } else if (key.downArrow) {\n const maxScroll = Math.max(0, visibleEntries.length - visibleLines);\n setScrollOffset(prev => Math.min(maxScroll, prev + 1));\n // Re-enable auto-scroll if we're at the bottom\n if (scrollOffset >= maxScroll - 1) {\n setAutoScroll(true);\n }\n } else if (key.pageUp) {\n setAutoScroll(false);\n setScrollOffset(prev => Math.max(0, prev - visibleLines));\n } else if (key.pageDown) {\n const maxScroll = Math.max(0, visibleEntries.length - visibleLines);\n setScrollOffset(prev => Math.min(maxScroll, prev + visibleLines));\n }\n });\n\n // Get visible slice of entries\n const displayedEntries = visibleEntries.slice(scrollOffset, scrollOffset + visibleLines);\n\n // Format time\n const formatTime = (timestamp: number): string => {\n return new Date(timestamp).toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n });\n };\n\n return (\n <Box\n flexDirection=\"column\"\n width={width}\n height={height}\n borderStyle=\"single\"\n borderColor={isFocused ? colors.cyan : colors.darkGray}\n paddingX={1}\n >\n {/* Header */}\n <Box justifyContent=\"space-between\" marginBottom={0}>\n <Text color={colors.cyan} bold>LOGS</Text>\n <Text color={colors.dimGray}>\n [verbose: {isVerbose ? 'on' : 'off'}]\n </Text>\n </Box>\n\n {/* Log entries */}\n <Box flexDirection=\"column\" flexGrow={1}>\n {displayedEntries.length === 0 ? (\n <Box justifyContent=\"center\" alignItems=\"center\" flexGrow={1}>\n <Text color={colors.dimGray}>Waiting for logs...</Text>\n </Box>\n ) : (\n displayedEntries.map((entry, index) => (\n <LogEntryRow \n key={entry.id} \n entry={entry} \n maxWidth={width - 4}\n />\n ))\n )}\n </Box>\n\n {/* Scroll indicator */}\n {visibleEntries.length > visibleLines && (\n <Box justifyContent=\"flex-end\">\n <Text color={colors.dimGray}>\n {scrollOffset + 1}-{Math.min(scrollOffset + visibleLines, visibleEntries.length)}/{visibleEntries.length}\n {autoScroll ? ' (auto)' : ''}\n </Text>\n </Box>\n )}\n </Box>\n );\n}\n\n// Individual log entry row\nfunction LogEntryRow({ entry, maxWidth }: { entry: LogEntry; maxWidth: number }) {\n const time = new Date(entry.timestamp).toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n });\n\n const levelColors = {\n debug: colors.dimGray,\n info: colors.cyan,\n success: colors.success,\n warn: colors.warning,\n error: colors.error,\n };\n\n const levelIcons = {\n debug: ' ',\n info: '●',\n success: '✓',\n warn: '⚠',\n error: '✗',\n };\n\n // Tool calls get special formatting\n if (entry.toolName) {\n const argsText = entry.toolArgs ? ` ${entry.toolArgs}` : '';\n const fullText = `${entry.toolName}${argsText}`;\n const truncated = fullText.length > maxWidth - 12 \n ? fullText.substring(0, maxWidth - 15) + '...'\n : fullText;\n\n return (\n <Box>\n <Text color={colors.dimGray}>{time}</Text>\n <Text color={colors.cyan}> 🔧 </Text>\n <Text color={colors.white}>{entry.toolName}</Text>\n {entry.toolArgs && <Text color={colors.gray}> {entry.toolArgs}</Text>}\n </Box>\n );\n }\n\n // Regular log entries\n const color = levelColors[entry.level];\n const icon = levelIcons[entry.level];\n \n // Truncate message if needed\n const availableWidth = maxWidth - 12; // time + space + icon + space\n const truncatedMessage = entry.message.length > availableWidth\n ? entry.message.substring(0, availableWidth - 3) + '...'\n : entry.message;\n\n return (\n <Box>\n <Text color={colors.dimGray}>{time}</Text>\n <Text color={color}> {icon} </Text>\n <Text color={color}>{truncatedMessage}</Text>\n </Box>\n );\n}\n","/**\n * StatusBar - Bottom bar showing connection status and keyboard shortcuts\n */\n\nimport React from 'react';\nimport { Box, Text } from 'ink';\nimport { colors } from '../theme.js';\nimport { getVersionInfo } from '../../utils/version-info.js';\n\ninterface StatusBarProps {\n isConnected: boolean;\n isVerbose: boolean;\n buildCount?: number;\n currentBuildIndex?: number;\n view: 'dashboard' | 'fullLog' | 'copyMenu';\n}\n\nexport function StatusBar({\n isConnected,\n isVerbose,\n buildCount = 0,\n currentBuildIndex = 0,\n view,\n}: StatusBarProps) {\n // Get version info\n const versionInfo = getVersionInfo();\n \n // Connection indicator\n const connectionIndicator = (\n <Box marginRight={2}>\n <Text color={isConnected ? colors.success : colors.error}>\n {isConnected ? '●' : '○'}\n </Text>\n <Text color={colors.gray}>\n {' '}{isConnected ? 'Connected' : 'Disconnected'}\n </Text>\n </Box>\n );\n\n // Build count indicator (only show if multiple builds)\n const buildIndicator = buildCount > 1 ? (\n <Box marginRight={2}>\n <Text color={colors.gray}>\n Build {currentBuildIndex + 1}/{buildCount}\n </Text>\n </Box>\n ) : null;\n\n // Shortcuts based on current view\n const shortcuts = view === 'dashboard' ? (\n <Box>\n <Shortcut letter=\"q\" label=\"quit\" />\n <Shortcut letter=\"b\" label=\"browser\" />\n <Shortcut letter=\"v\" label={`verbose: ${isVerbose ? 'on' : 'off'}`} />\n <Shortcut letter=\"c\" label=\"copy\" />\n <Shortcut letter=\"t\" label=\"text view\" />\n {buildCount > 1 && <Shortcut letter=\"n/p\" label=\"switch build\" />}\n <Shortcut letter=\"↑↓\" label=\"scroll\" />\n </Box>\n ) : view === 'fullLog' ? (\n <Box>\n <Shortcut letter=\"t\" label=\"dashboard\" />\n <Shortcut letter=\"c\" label=\"copy\" />\n <Shortcut letter=\"/\" label=\"search\" />\n <Shortcut letter=\"f\" label=\"filter\" />\n <Shortcut letter=\"↑↓\" label=\"scroll\" />\n <Shortcut letter=\"PgUp/Dn\" label=\"page\" />\n </Box>\n ) : (\n <Box>\n <Shortcut letter=\"Esc\" label=\"cancel\" />\n </Box>\n );\n\n // Version display\n const versionDisplay = (\n <Box marginLeft={2}>\n <Text color={colors.dimGray}>\n {versionInfo.display}\n </Text>\n </Box>\n );\n\n return (\n <Box\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n paddingX={1}\n justifyContent=\"space-between\"\n >\n <Box>\n {connectionIndicator}\n {buildIndicator}\n </Box>\n <Box>\n {shortcuts}\n {versionDisplay}\n </Box>\n </Box>\n );\n}\n\n// Helper component for shortcuts\nfunction Shortcut({ letter, label }: { letter: string; label: string }) {\n return (\n <Box marginRight={2}>\n <Text color={colors.dimGray}>[</Text>\n <Text color={colors.cyan}>{letter}</Text>\n <Text color={colors.dimGray}>]</Text>\n <Text color={colors.gray}>{label}</Text>\n </Box>\n );\n}\n","/**\n * FullLogView - Full-screen log view with search and filter\n */\n\nimport React, { useState, useEffect } from 'react';\nimport { Box, Text, useInput, useStdout } from 'ink';\nimport TextInput from 'ink-text-input';\nimport { colors } from '../theme.js';\nimport type { LogEntry, LogLevel } from '../../../lib/logging/types.js';\n\ntype FilterMode = 'all' | 'errors' | 'tools' | 'verbose';\n\ninterface FullLogViewProps {\n entries: LogEntry[];\n onBack: () => void;\n onCopy: () => void;\n}\n\nexport function FullLogView({ entries, onBack, onCopy }: FullLogViewProps) {\n const { stdout } = useStdout();\n const terminalHeight = stdout?.rows || 24;\n const terminalWidth = stdout?.columns || 80;\n\n const [searchQuery, setSearchQuery] = useState('');\n const [isSearching, setIsSearching] = useState(false);\n const [filterMode, setFilterMode] = useState<FilterMode>('all');\n const [scrollOffset, setScrollOffset] = useState(0);\n const [searchMode, setSearchMode] = useState<'filter' | 'highlight'>('highlight');\n\n // Available height for log lines\n const headerHeight = 3;\n const footerHeight = 2;\n const visibleLines = Math.max(1, terminalHeight - headerHeight - footerHeight);\n\n // Filter and search entries\n const processedEntries = entries.filter(entry => {\n // Apply filter mode\n if (filterMode === 'errors' && entry.level !== 'error' && entry.level !== 'warn') {\n return false;\n }\n if (filterMode === 'tools' && !entry.toolName) {\n return false;\n }\n if (filterMode !== 'verbose' && entry.verbose) {\n return false;\n }\n\n // Apply search filter (if in filter mode)\n if (searchQuery && searchMode === 'filter') {\n const query = searchQuery.toLowerCase();\n const messageMatch = entry.message.toLowerCase().includes(query);\n const toolMatch = entry.toolName?.toLowerCase().includes(query);\n const argsMatch = entry.toolArgs?.toLowerCase().includes(query);\n return messageMatch || toolMatch || argsMatch;\n }\n\n return true;\n });\n\n // Calculate max scroll\n const maxScroll = Math.max(0, processedEntries.length - visibleLines);\n\n // Get visible entries\n const visibleEntries = processedEntries.slice(scrollOffset, scrollOffset + visibleLines);\n\n // Handle keyboard input\n useInput((input, key) => {\n if (isSearching) {\n if (key.escape || key.return) {\n setIsSearching(false);\n }\n return;\n }\n\n if (input === 't') {\n onBack();\n } else if (input === 'c') {\n onCopy();\n } else if (input === '/') {\n setIsSearching(true);\n } else if (input === 'f') {\n // Cycle through filter modes\n const modes: FilterMode[] = ['all', 'errors', 'tools', 'verbose'];\n const currentIndex = modes.indexOf(filterMode);\n setFilterMode(modes[(currentIndex + 1) % modes.length]);\n setScrollOffset(0);\n } else if (input === 'm') {\n // Toggle search mode\n setSearchMode(prev => prev === 'filter' ? 'highlight' : 'filter');\n } else if (key.upArrow) {\n setScrollOffset(prev => Math.max(0, prev - 1));\n } else if (key.downArrow) {\n setScrollOffset(prev => Math.min(maxScroll, prev + 1));\n } else if (key.pageUp) {\n setScrollOffset(prev => Math.max(0, prev - visibleLines));\n } else if (key.pageDown) {\n setScrollOffset(prev => Math.min(maxScroll, prev + visibleLines));\n } else if (key.escape) {\n if (searchQuery) {\n setSearchQuery('');\n } else {\n onBack();\n }\n }\n });\n\n // Format time\n const formatTime = (timestamp: number): string => {\n return new Date(timestamp).toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n });\n };\n\n // Check if text matches search query\n const highlightSearch = (text: string): React.ReactNode => {\n if (!searchQuery || searchMode !== 'highlight') {\n return text;\n }\n\n const query = searchQuery.toLowerCase();\n const index = text.toLowerCase().indexOf(query);\n if (index === -1) {\n return text;\n }\n\n return (\n <>\n {text.slice(0, index)}\n <Text backgroundColor={colors.warning} color=\"black\">\n {text.slice(index, index + searchQuery.length)}\n </Text>\n {text.slice(index + searchQuery.length)}\n </>\n );\n };\n\n return (\n <Box flexDirection=\"column\" height={terminalHeight}>\n {/* Header with search */}\n <Box\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n paddingX={1}\n justifyContent=\"space-between\"\n >\n <Text color={colors.cyan} bold>LOGS</Text>\n <Box>\n <Text color={colors.dimGray}>Search: </Text>\n {isSearching ? (\n <Box borderStyle=\"round\" borderColor={colors.cyan} paddingX={1}>\n <TextInput\n value={searchQuery}\n onChange={setSearchQuery}\n placeholder=\"type to search...\"\n />\n </Box>\n ) : (\n <Text color={searchQuery ? colors.white : colors.dimGray}>\n [{searchQuery || 'none'}] ({searchMode})\n </Text>\n )}\n <Text color={colors.dimGray}> [/]</Text>\n </Box>\n </Box>\n\n {/* Log content */}\n <Box\n flexDirection=\"column\"\n flexGrow={1}\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n borderTop={false}\n borderBottom={false}\n paddingX={1}\n >\n {visibleEntries.map((entry, index) => {\n const time = formatTime(entry.timestamp);\n const levelColors = {\n debug: colors.dimGray,\n info: colors.cyan,\n success: colors.success,\n warn: colors.warning,\n error: colors.error,\n };\n const levelIcons = {\n debug: ' ',\n info: '●',\n success: '✓',\n warn: '⚠',\n error: '✗',\n };\n\n if (entry.toolName) {\n return (\n <Box key={entry.id}>\n <Text color={colors.dimGray}>{time}</Text>\n <Text color={colors.cyan}> 🔧 </Text>\n <Text color={colors.white}>{highlightSearch(entry.toolName)}</Text>\n {entry.toolArgs && (\n <Text color={colors.gray}> {highlightSearch(entry.toolArgs)}</Text>\n )}\n </Box>\n );\n }\n\n return (\n <Box key={entry.id}>\n <Text color={colors.dimGray}>{time}</Text>\n <Text color={levelColors[entry.level]}> {levelIcons[entry.level]} </Text>\n <Text color={levelColors[entry.level]}>{highlightSearch(entry.message)}</Text>\n </Box>\n );\n })}\n </Box>\n\n {/* Footer with shortcuts and scroll position */}\n <Box\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n paddingX={1}\n justifyContent=\"space-between\"\n >\n <Box>\n <Shortcut letter=\"t\" label=\"dashboard\" />\n <Shortcut letter=\"c\" label=\"copy\" />\n <Shortcut letter=\"/\" label=\"search\" />\n <Shortcut letter=\"f\" label={`filter: ${filterMode}`} />\n <Shortcut letter=\"m\" label={`mode: ${searchMode}`} />\n </Box>\n <Text color={colors.dimGray}>\n {scrollOffset + 1}-{Math.min(scrollOffset + visibleLines, processedEntries.length)}/{processedEntries.length}\n </Text>\n </Box>\n </Box>\n );\n}\n\nfunction Shortcut({ letter, label }: { letter: string; label: string }) {\n return (\n <Box marginRight={2}>\n <Text color={colors.dimGray}>[</Text>\n <Text color={colors.cyan}>{letter}</Text>\n <Text color={colors.dimGray}>]</Text>\n <Text color={colors.gray}>{label}</Text>\n </Box>\n );\n}\n","/**\n * CopyMenu - Modal for copying logs to clipboard\n */\n\nimport React from 'react';\nimport { Box, Text, useInput } from 'ink';\nimport { colors } from '../theme.js';\n\ninterface CopyMenuProps {\n onSelect: (option: 'visible' | 'last50' | 'last100' | 'all' | 'range') => void;\n onCancel: () => void;\n visibleCount: number;\n totalCount: number;\n}\n\nexport function CopyMenu({ onSelect, onCancel, visibleCount, totalCount }: CopyMenuProps) {\n useInput((input, key) => {\n if (key.escape) {\n onCancel();\n } else if (input === '1') {\n onSelect('visible');\n } else if (input === '2') {\n onSelect('last50');\n } else if (input === '3') {\n onSelect('last100');\n } else if (input === '4') {\n onSelect('all');\n } else if (input === '5') {\n onSelect('range');\n }\n });\n\n return (\n <Box\n flexDirection=\"column\"\n borderStyle=\"round\"\n borderColor={colors.cyan}\n paddingX={2}\n paddingY={1}\n >\n <Box marginBottom={1}>\n <Text color={colors.cyan} bold>Copy Logs</Text>\n </Box>\n\n <Box flexDirection=\"column\" marginBottom={1}>\n <CopyOption number=\"1\" label={`Copy visible (${visibleCount} lines)`} />\n <CopyOption number=\"2\" label=\"Copy last 50 lines\" />\n <CopyOption number=\"3\" label=\"Copy last 100 lines\" />\n <CopyOption number=\"4\" label={`Copy all from file (${totalCount} lines)`} />\n <CopyOption number=\"5\" label=\"Copy range...\" />\n </Box>\n\n <Box>\n <Text color={colors.dimGray}>[Esc] Cancel</Text>\n </Box>\n </Box>\n );\n}\n\nfunction CopyOption({ number, label }: { number: string; label: string }) {\n return (\n <Box>\n <Text color={colors.dimGray}>[</Text>\n <Text color={colors.cyan}>{number}</Text>\n <Text color={colors.dimGray}>]</Text>\n <Text color={colors.white}> {label}</Text>\n </Box>\n );\n}\n","/**\n * RunnerDashboard - Main TUI container for the runner\n * \n * Layout:\n * - 20% left: BuildPanel (current build + todos) - hidden when no build\n * - 80% right: LogPanel (scrollable logs)\n * - Bottom: StatusBar (connection, shortcuts)\n * \n * Views:\n * - dashboard: Main split view\n * - fullLog: Full-screen log view with search\n * - copyMenu: Copy options modal overlay\n */\n\nimport React, { useState, useEffect, useCallback, useRef } from 'react';\nimport { Box, Text, useInput, useStdout, useApp } from 'ink';\nimport { colors } from '../theme.js';\nimport { BuildPanel } from '../components/BuildPanel.js';\nimport { LogPanel } from '../components/LogPanel.js';\nimport { StatusBar } from '../components/StatusBar.js';\nimport { FullLogView } from '../components/FullLogView.js';\nimport { CopyMenu } from '../components/CopyMenu.js';\nimport { useBuildState, useLogEntries } from '../hooks/useBuildState.js';\nimport { Banner } from '../components/Banner.js';\nimport type { BuildInfo, TodoItem, LogEntry } from '../../../lib/logging/types.js';\nimport { getLogBuffer } from '../../../lib/logging/log-buffer.js';\nimport { openBrowser } from '../../utils/cli-auth.js';\n\ntype ViewMode = 'dashboard' | 'fullLog' | 'copyMenu';\n\nexport interface RunnerDashboardProps {\n // Initial config (passed from runner)\n config: {\n runnerId: string;\n serverUrl: string;\n workspace: string;\n apiUrl?: string;\n };\n // Event handlers\n onQuit?: () => void;\n}\n\nexport function RunnerDashboard({ config, onQuit }: RunnerDashboardProps) {\n const { exit } = useApp();\n const { stdout } = useStdout();\n const terminalHeight = stdout?.rows || 24;\n const terminalWidth = stdout?.columns || 80;\n\n // State management\n const [buildState, buildActions] = useBuildState();\n const logEntries = useLogEntries(100);\n const [view, setView] = useState<ViewMode>('dashboard');\n \n // Track if we've opened browser on first connection\n const hasOpenedBrowserRef = useRef(false);\n\n // Get the dashboard URL (use apiUrl if provided, otherwise default to hatchway.sh)\n const dashboardUrl = config.apiUrl || 'https://hatchway.sh';\n\n // Open browser handler\n const handleOpenBrowser = useCallback(() => {\n openBrowser(dashboardUrl).catch(() => {\n // Silently fail - user can manually open the URL\n });\n }, [dashboardUrl]);\n\n // Auto-open browser on first successful connection\n useEffect(() => {\n if (buildState.isConnected && !hasOpenedBrowserRef.current) {\n hasOpenedBrowserRef.current = true;\n // Small delay to ensure the TUI is fully rendered before opening browser\n setTimeout(() => {\n handleOpenBrowser();\n }, 500);\n }\n }, [buildState.isConnected, handleOpenBrowser]);\n\n // Handle keyboard input\n useInput((input, key) => {\n // Global quit handler\n if (input === 'q' && view !== 'copyMenu') {\n if (onQuit) {\n onQuit();\n }\n exit();\n return;\n }\n\n // Copy menu is modal - handle separately\n if (view === 'copyMenu') {\n return; // CopyMenu handles its own input\n }\n\n // Dashboard shortcuts\n if (view === 'dashboard') {\n if (input === 'v') {\n buildActions.toggleVerbose();\n } else if (input === 'c') {\n setView('copyMenu');\n } else if (input === 't') {\n setView('fullLog');\n } else if (input === 'n') {\n buildActions.nextBuild();\n } else if (input === 'p') {\n buildActions.prevBuild();\n } else if (input === 'b') {\n handleOpenBrowser();\n }\n }\n\n // Full log view shortcuts\n if (view === 'fullLog') {\n if (input === 't') {\n setView('dashboard');\n } else if (input === 'c') {\n setView('copyMenu');\n }\n }\n });\n\n // Handle copy action\n const handleCopy = useCallback(async (option: 'visible' | 'last50' | 'last100' | 'all' | 'range') => {\n try {\n const buffer = getLogBuffer();\n let entriesToCopy: LogEntry[] = [];\n\n switch (option) {\n case 'visible':\n entriesToCopy = logEntries.slice(-20); // Approximate visible count\n break;\n case 'last50':\n entriesToCopy = buffer.getRecent(50);\n break;\n case 'last100':\n entriesToCopy = buffer.getRecent(100);\n break;\n case 'all':\n entriesToCopy = buffer.readFromFile();\n break;\n case 'range':\n // TODO: Implement range selection\n entriesToCopy = buffer.getRecent(100);\n break;\n }\n\n const text = buffer.toText(entriesToCopy);\n \n // Copy to clipboard using pbcopy on macOS\n const { spawn } = await import('child_process');\n const pbcopy = spawn('pbcopy');\n pbcopy.stdin.write(text);\n pbcopy.stdin.end();\n \n // TODO: Show success message\n } catch (error) {\n console.error('Failed to copy to clipboard:', error);\n }\n\n setView('dashboard');\n }, [logEntries]);\n\n // Calculate panel dimensions\n const bannerHeight = 7; // ASCII art banner\n const headerHeight = 3; // Config/status line\n const statusBarHeight = 3;\n const contentHeight = Math.max(1, terminalHeight - bannerHeight - headerHeight - statusBarHeight);\n \n // 20/80 split\n const buildPanelWidth = Math.floor(terminalWidth * 0.2);\n const logPanelWidth = terminalWidth - buildPanelWidth;\n\n // Show build panel only when there's an active build\n const showBuildPanel = buildState.currentBuild !== null;\n\n // Check for available update (set by auto-update check in index.ts)\n const updateAvailable = process.env.HATCHWAY_UPDATE_AVAILABLE;\n\n return (\n <Box flexDirection=\"column\" height={terminalHeight} width={terminalWidth}>\n {/* Banner */}\n <Banner />\n\n {/* Update notification banner */}\n {updateAvailable && (\n <Box justifyContent=\"center\" paddingY={0}>\n <Text color={colors.cyan}>⬆ Update available: </Text>\n <Text color={colors.success}>{updateAvailable}</Text>\n <Text color={colors.dimGray}> — Run </Text>\n <Text color={colors.cyan}>hatchway upgrade</Text>\n <Text color={colors.dimGray}> to update</Text>\n </Box>\n )}\n\n {/* Header bar with connection status */}\n <Box\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n paddingX={1}\n justifyContent=\"space-between\"\n >\n <Text color={colors.dimGray}>\n Runner: <Text color={colors.cyan}>{config.runnerId}</Text> • Server: <Text color={colors.cyan}>{config.serverUrl.replace(/^wss?:\\/\\//, '')}</Text>\n </Text>\n <Box>\n <Text color={buildState.isConnected ? colors.success : colors.error}>\n {buildState.isConnected ? '●' : '○'}\n </Text>\n <Text color={colors.gray}>\n {' '}{buildState.isConnected ? 'Connected' : 'Disconnected'}\n </Text>\n </Box>\n </Box>\n\n {/* Main content */}\n {view === 'dashboard' && (\n <Box flexGrow={1} height={contentHeight}>\n {showBuildPanel && (\n <BuildPanel\n build={buildState.currentBuild}\n width={buildPanelWidth}\n height={contentHeight}\n />\n )}\n <LogPanel\n entries={logEntries}\n isVerbose={buildState.isVerbose}\n width={showBuildPanel ? logPanelWidth : terminalWidth}\n height={contentHeight}\n isFocused={true}\n />\n </Box>\n )}\n\n {view === 'fullLog' && (\n <FullLogView\n entries={logEntries}\n onBack={() => setView('dashboard')}\n onCopy={() => setView('copyMenu')}\n />\n )}\n\n {/* Copy menu overlay */}\n {view === 'copyMenu' && (\n <Box\n position=\"absolute\"\n flexDirection=\"column\"\n justifyContent=\"center\"\n alignItems=\"center\"\n width={terminalWidth}\n height={terminalHeight}\n >\n <CopyMenu\n onSelect={handleCopy}\n onCancel={() => setView('dashboard')}\n visibleCount={Math.min(20, logEntries.length)}\n totalCount={getLogBuffer().readFromFile().length}\n />\n </Box>\n )}\n\n {/* Status bar (only in dashboard view) */}\n {view === 'dashboard' && (\n <StatusBar\n isConnected={buildState.isConnected}\n isVerbose={buildState.isVerbose}\n buildCount={buildState.builds.length}\n currentBuildIndex={buildState.currentBuildIndex}\n view={view}\n />\n )}\n </Box>\n );\n}\n\n// Export for external use\nexport { useBuildState, useLogEntries };\n","import chalk from 'chalk';\nimport { homedir, userInfo } from 'node:os';\nimport { join } from 'node:path';\nimport { render } from 'ink';\nimport React from 'react';\nimport { logger } from '../utils/logger.js';\nimport { configManager } from '../utils/config-manager.js';\nimport { startRunner } from '../../index.js';\nimport { RunnerDashboard } from '../tui/screens/RunnerDashboard.js';\nimport { initRunnerLogger } from '../../lib/logging/index.js';\nimport { setFileLoggerTuiMode } from '../../lib/file-logger.js';\nimport { \n hasStoredToken, \n getStoredToken, \n performOAuthLogin, \n storeToken \n} from '../utils/cli-auth.js';\n\n// Default public Hatchway instance\nconst DEFAULT_URL = 'https://hatchway.sh';\nconst DEFAULT_WORKSPACE = join(homedir(), 'hatchway-workspace');\n\n/**\n * Normalize URL by adding protocol if missing\n * Uses http:// for localhost, https:// for everything else\n */\nfunction normalizeUrl(url: string): string {\n if (!url) return url;\n\n // If protocol already present, return as-is\n if (url.match(/^https?:\\/\\//i)) {\n return url;\n }\n\n // For localhost or 127.0.0.1, use http://\n if (url.match(/^(localhost|127\\.0\\.0\\.1)(:|\\/|$)/i)) {\n return `http://${url}`;\n }\n\n // For everything else, use https://\n return `https://${url}`;\n}\n\n/**\n * Derive WebSocket URL from a base HTTP/HTTPS URL\n * Converts https://example.com to wss://example.com/ws/runner\n */\nfunction deriveWsUrl(baseUrl: string): string {\n const normalized = normalizeUrl(baseUrl);\n const wsProtocol = normalized.startsWith('https://') ? 'wss://' : 'ws://';\n const hostPath = normalized.replace(/^https?:\\/\\//, '');\n // Remove trailing slash if present\n const cleanHostPath = hostPath.replace(/\\/$/, '');\n return `${wsProtocol}${cleanHostPath}/ws/runner`;\n}\n\n/**\n * Get the current system username\n */\nfunction getSystemUsername(): string {\n try {\n return userInfo().username;\n } catch {\n // Fallback if userInfo() fails\n return process.env.USER || process.env.USERNAME || 'runner';\n }\n}\n\ninterface RunOptions {\n broker?: string; // Legacy: WebSocket URL override (deprecated, use --url instead)\n url?: string;\n workspace?: string;\n runnerId?: string;\n secret?: string;\n verbose?: boolean;\n local?: boolean; // Enable local mode (bypasses authentication)\n noTui?: boolean; // Disable TUI dashboard\n}\n\n/**\n * Check if we should use TUI\n */\nfunction shouldUseTUI(options: RunOptions): boolean {\n // Explicit flag\n if (options.noTui) return false;\n\n // CI/CD environments\n if (process.env.CI === '1' || process.env.CI === 'true') return false;\n\n // Not a TTY\n if (!process.stdout.isTTY) return false;\n\n // Explicit env var to disable\n if (process.env.NO_TUI === '1') return false;\n\n return true;\n}\n\nexport async function runCommand(options: RunOptions) {\n // Set local mode environment variable if requested\n if (options.local) {\n process.env.HATCHWAY_LOCAL_MODE = 'true';\n logger.info(chalk.yellow('Local mode enabled - authentication bypassed'));\n }\n\n const useTUI = shouldUseTUI(options);\n\n // Build runner options from CLI flags or smart defaults\n // NOTE: For the `runner` command, we intentionally ignore local config values\n // and default to the public Hatchway instance. This command is specifically\n // for connecting to remote servers, not local development.\n // Users can still override with CLI flags if needed.\n \n // Resolve API URL: CLI flag > default public instance (ignore config)\n const apiUrl = normalizeUrl(options.url || DEFAULT_URL);\n \n // Resolve WebSocket URL: CLI broker flag > derive from API URL (ignore config)\n const wsUrl = options.broker || deriveWsUrl(apiUrl);\n \n // Resolve workspace: CLI flag > config > default ~/hatchway-workspace\n // (workspace from config is fine since it's user's preference for where projects go)\n const config = configManager.get();\n const workspace = options.workspace || config.workspace || DEFAULT_WORKSPACE;\n \n // Resolve runner ID: CLI flag > system username (ignore config 'local' default)\n const runnerId = options.runnerId || getSystemUsername();\n \n // Resolve secret: CLI flag > config (required)\n // Only use config secret if it looks like a valid token (starts with sv_)\n // This prevents the default 'dev-secret' from being used in runner mode\n const configSecret = configManager.getSecret();\n const sharedSecret = options.secret || (configSecret?.startsWith('sv_') ? configSecret : undefined);\n\n const runnerOptions = {\n wsUrl,\n apiUrl,\n sharedSecret,\n runnerId,\n workspace,\n verbose: options.verbose,\n tuiMode: useTUI,\n };\n\n // Validate required options - secret is required\n // If not provided, try to use stored OAuth token or trigger OAuth flow\n if (!runnerOptions.sharedSecret) {\n // Check if we have a stored OAuth token\n if (hasStoredToken()) {\n const storedToken = getStoredToken();\n if (storedToken) {\n runnerOptions.sharedSecret = storedToken;\n logger.info(`Using stored runner token: ${chalk.cyan(storedToken.substring(0, 12) + '...')}`);\n }\n }\n \n // If still no secret and not in local mode, trigger OAuth flow\n if (!runnerOptions.sharedSecret && !options.local) {\n logger.info('No runner token found. Starting OAuth authentication...');\n logger.info('');\n \n const result = await performOAuthLogin({\n apiUrl: runnerOptions.apiUrl,\n silent: false,\n });\n \n if (result.success && result.token) {\n storeToken(result.token, runnerOptions.apiUrl);\n runnerOptions.sharedSecret = result.token;\n logger.log('');\n logger.success('Authentication successful!');\n logger.info(`Token: ${chalk.cyan(result.token.substring(0, 12) + '...')}`);\n logger.log('');\n } else {\n logger.error(result.error || 'Authentication failed');\n logger.info('');\n logger.info('You can also provide a token manually:');\n logger.info(` ${chalk.cyan('hatchway runner --secret <your-secret>')}`);\n logger.info('');\n logger.info('Or login first:');\n logger.info(` ${chalk.cyan('hatchway login')}`);\n process.exit(1);\n }\n }\n \n // Final check - if still no secret (and not local mode)\n if (!runnerOptions.sharedSecret && !options.local) {\n logger.error('Shared secret is required');\n logger.info('');\n logger.info('Get a runner key from your Hatchway dashboard, or provide via:');\n logger.info(` ${chalk.cyan('hatchway runner --secret <your-secret>')}`);\n logger.info('');\n logger.info('Or login with OAuth:');\n logger.info(` ${chalk.cyan('hatchway login')}`);\n process.exit(1);\n }\n }\n\n // ========================================\n // PLAIN TEXT MODE (--no-tui)\n // ========================================\n if (!useTUI) {\n // Display startup info\n logger.section('Starting Hatchway Runner');\n logger.info(`Server: ${chalk.cyan(runnerOptions.wsUrl)}`);\n logger.info(`API URL: ${chalk.cyan(runnerOptions.apiUrl)}`);\n logger.info(`Runner ID: ${chalk.cyan(runnerOptions.runnerId)}`);\n logger.info(`Workspace: ${chalk.cyan(runnerOptions.workspace)}`);\n logger.log('');\n\n if (options.verbose) {\n logger.debug('Verbose logging enabled');\n logger.debug(`Full options: ${JSON.stringify(runnerOptions, null, 2)}`);\n }\n\n try {\n // Start the runner (runs indefinitely)\n await startRunner(runnerOptions);\n } catch (error) {\n logger.error('Failed to start runner:');\n logger.error(error instanceof Error ? error.message : 'Unknown error');\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack);\n }\n process.exit(1);\n }\n return;\n }\n\n // ========================================\n // TUI MODE (default)\n // ========================================\n \n // Initialize the logger BEFORE rendering TUI so the TUI can subscribe to events\n // This must happen before startRunner() which would create its own logger\n initRunnerLogger({\n verbose: options.verbose || false,\n tuiMode: true,\n });\n \n // Enable TUI mode in file-logger to suppress terminal output\n setFileLoggerTuiMode(true);\n \n // Track runner cleanup function\n let runnerCleanupFn: (() => Promise<void>) | undefined;\n\n // Clear screen and enter alternate buffer for clean TUI\n process.stdout.write('\\x1b[?1049h'); // Enter alternate screen\n process.stdout.write('\\x1b[2J\\x1b[H'); // Clear and home\n\n // Ensure stdin is in raw mode for keyboard input\n if (process.stdin.setRawMode) {\n process.stdin.setRawMode(true);\n }\n process.stdin.resume();\n\n // Handle quit from TUI\n const handleQuit = async () => {\n // Exit alternate screen buffer\n process.stdout.write('\\x1b[?1049l');\n \n console.log('\\n' + chalk.yellow('Shutting down runner...'));\n \n if (runnerCleanupFn) {\n try {\n await runnerCleanupFn();\n console.log(chalk.green('✓') + ' Runner stopped');\n } catch (e) {\n console.error(chalk.red('✗') + ' Error stopping runner:', e);\n }\n }\n \n process.exit(0);\n };\n\n // Handle SIGINT (Ctrl+C)\n process.on('SIGINT', handleQuit);\n\n // Render the TUI dashboard\n const { waitUntilExit, clear } = render(\n React.createElement(RunnerDashboard, {\n config: {\n runnerId,\n serverUrl: wsUrl,\n workspace,\n apiUrl,\n },\n onQuit: handleQuit,\n }),\n {\n stdin: process.stdin,\n stdout: process.stdout,\n stderr: process.stderr,\n exitOnCtrlC: false, // We handle this ourselves\n patchConsole: false, // We use our own logging\n }\n );\n\n try {\n // Start the runner and get cleanup function\n runnerCleanupFn = await startRunner(runnerOptions);\n\n // Wait for TUI to exit (user pressed 'q')\n await waitUntilExit();\n\n // Clean up\n clear();\n await handleQuit();\n } catch (error) {\n clear();\n process.stdout.write('\\x1b[?1049l'); // Exit alternate screen\n \n logger.error('Failed to start runner:');\n logger.error(error instanceof Error ? error.message : 'Unknown error');\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack);\n }\n process.exit(1);\n }\n}\n"],"names":["useState","useEffect","_jsxs","_jsx","Shortcut","useRef","useCallback"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"run-BbxtXsLx.js","sources":["../../src/cli/tui/components/LogPanel.tsx","../../src/cli/tui/components/StatusBar.tsx","../../src/cli/tui/components/FullLogView.tsx","../../src/cli/tui/components/CopyMenu.tsx","../../src/cli/tui/screens/RunnerDashboard.tsx","../../src/cli/commands/run.ts"],"sourcesContent":["/**\n * LogPanel - Right panel showing scrollable log entries\n * Takes up 80% of width, shows:\n * - Timestamped log entries\n * - Tool calls with truncated args\n * - Scrollable with keyboard navigation\n */\n\nimport React, { useState, useEffect, useRef } from 'react';\nimport { Box, Text, useInput } from 'ink';\nimport { colors } from '../theme.js';\nimport type { LogEntry } from '../../../lib/logging/types.js';\n\ninterface LogPanelProps {\n entries: LogEntry[];\n isVerbose: boolean;\n width: number;\n height: number;\n isFocused: boolean;\n}\n\nexport function LogPanel({ entries, isVerbose, width, height, isFocused }: LogPanelProps) {\n const [scrollOffset, setScrollOffset] = useState(0);\n const [autoScroll, setAutoScroll] = useState(true);\n\n // Filter entries based on verbose mode\n const visibleEntries = isVerbose \n ? entries \n : entries.filter(e => !e.verbose);\n\n // Available height for log lines (subtract 2 for border, 1 for header)\n const visibleLines = Math.max(1, height - 3);\n\n // Auto-scroll when new entries arrive\n useEffect(() => {\n if (autoScroll && visibleEntries.length > 0) {\n const maxScroll = Math.max(0, visibleEntries.length - visibleLines);\n setScrollOffset(maxScroll);\n }\n }, [visibleEntries.length, autoScroll, visibleLines]);\n\n // Handle keyboard navigation\n useInput((input, key) => {\n if (!isFocused) return;\n\n if (key.upArrow) {\n setAutoScroll(false);\n setScrollOffset(prev => Math.max(0, prev - 1));\n } else if (key.downArrow) {\n const maxScroll = Math.max(0, visibleEntries.length - visibleLines);\n setScrollOffset(prev => Math.min(maxScroll, prev + 1));\n // Re-enable auto-scroll if we're at the bottom\n if (scrollOffset >= maxScroll - 1) {\n setAutoScroll(true);\n }\n } else if (key.pageUp) {\n setAutoScroll(false);\n setScrollOffset(prev => Math.max(0, prev - visibleLines));\n } else if (key.pageDown) {\n const maxScroll = Math.max(0, visibleEntries.length - visibleLines);\n setScrollOffset(prev => Math.min(maxScroll, prev + visibleLines));\n }\n });\n\n // Get visible slice of entries\n const displayedEntries = visibleEntries.slice(scrollOffset, scrollOffset + visibleLines);\n\n // Format time\n const formatTime = (timestamp: number): string => {\n return new Date(timestamp).toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n });\n };\n\n return (\n <Box\n flexDirection=\"column\"\n width={width}\n height={height}\n borderStyle=\"single\"\n borderColor={isFocused ? colors.cyan : colors.darkGray}\n paddingX={1}\n >\n {/* Header */}\n <Box justifyContent=\"space-between\" marginBottom={0}>\n <Text color={colors.cyan} bold>LOGS</Text>\n <Text color={colors.dimGray}>\n [verbose: {isVerbose ? 'on' : 'off'}]\n </Text>\n </Box>\n\n {/* Log entries */}\n <Box flexDirection=\"column\" flexGrow={1}>\n {displayedEntries.length === 0 ? (\n <Box justifyContent=\"center\" alignItems=\"center\" flexGrow={1}>\n <Text color={colors.dimGray}>Waiting for logs...</Text>\n </Box>\n ) : (\n displayedEntries.map((entry, index) => (\n <LogEntryRow \n key={entry.id} \n entry={entry} \n maxWidth={width - 4}\n />\n ))\n )}\n </Box>\n\n {/* Scroll indicator */}\n {visibleEntries.length > visibleLines && (\n <Box justifyContent=\"flex-end\">\n <Text color={colors.dimGray}>\n {scrollOffset + 1}-{Math.min(scrollOffset + visibleLines, visibleEntries.length)}/{visibleEntries.length}\n {autoScroll ? ' (auto)' : ''}\n </Text>\n </Box>\n )}\n </Box>\n );\n}\n\n// Individual log entry row\nfunction LogEntryRow({ entry, maxWidth }: { entry: LogEntry; maxWidth: number }) {\n const time = new Date(entry.timestamp).toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n });\n\n const levelColors = {\n debug: colors.dimGray,\n info: colors.cyan,\n success: colors.success,\n warn: colors.warning,\n error: colors.error,\n };\n\n const levelIcons = {\n debug: ' ',\n info: '●',\n success: '✓',\n warn: '⚠',\n error: '✗',\n };\n\n // Tool calls get special formatting\n if (entry.toolName) {\n const argsText = entry.toolArgs ? ` ${entry.toolArgs}` : '';\n const fullText = `${entry.toolName}${argsText}`;\n const truncated = fullText.length > maxWidth - 12 \n ? fullText.substring(0, maxWidth - 15) + '...'\n : fullText;\n\n return (\n <Box>\n <Text color={colors.dimGray}>{time}</Text>\n <Text color={colors.cyan}> 🔧 </Text>\n <Text color={colors.white}>{entry.toolName}</Text>\n {entry.toolArgs && <Text color={colors.gray}> {entry.toolArgs}</Text>}\n </Box>\n );\n }\n\n // Regular log entries\n const color = levelColors[entry.level];\n const icon = levelIcons[entry.level];\n \n // Truncate message if needed\n const availableWidth = maxWidth - 12; // time + space + icon + space\n const truncatedMessage = entry.message.length > availableWidth\n ? entry.message.substring(0, availableWidth - 3) + '...'\n : entry.message;\n\n return (\n <Box>\n <Text color={colors.dimGray}>{time}</Text>\n <Text color={color}> {icon} </Text>\n <Text color={color}>{truncatedMessage}</Text>\n </Box>\n );\n}\n","/**\n * StatusBar - Bottom bar showing connection status and keyboard shortcuts\n */\n\nimport React from 'react';\nimport { Box, Text } from 'ink';\nimport { colors } from '../theme.js';\nimport { getVersionInfo } from '../../utils/version-info.js';\n\ninterface StatusBarProps {\n isConnected: boolean;\n isVerbose: boolean;\n buildCount?: number;\n currentBuildIndex?: number;\n view: 'dashboard' | 'fullLog' | 'copyMenu';\n}\n\nexport function StatusBar({\n isConnected,\n isVerbose,\n buildCount = 0,\n currentBuildIndex = 0,\n view,\n}: StatusBarProps) {\n // Get version info\n const versionInfo = getVersionInfo();\n \n // Connection indicator\n const connectionIndicator = (\n <Box marginRight={2}>\n <Text color={isConnected ? colors.success : colors.error}>\n {isConnected ? '●' : '○'}\n </Text>\n <Text color={colors.gray}>\n {' '}{isConnected ? 'Connected' : 'Disconnected'}\n </Text>\n </Box>\n );\n\n // Build count indicator (only show if multiple builds)\n const buildIndicator = buildCount > 1 ? (\n <Box marginRight={2}>\n <Text color={colors.gray}>\n Build {currentBuildIndex + 1}/{buildCount}\n </Text>\n </Box>\n ) : null;\n\n // Shortcuts based on current view\n const shortcuts = view === 'dashboard' ? (\n <Box>\n <Shortcut letter=\"q\" label=\"quit\" />\n <Shortcut letter=\"b\" label=\"browser\" />\n <Shortcut letter=\"v\" label={`verbose: ${isVerbose ? 'on' : 'off'}`} />\n <Shortcut letter=\"c\" label=\"copy\" />\n <Shortcut letter=\"t\" label=\"text view\" />\n {buildCount > 1 && <Shortcut letter=\"n/p\" label=\"switch build\" />}\n <Shortcut letter=\"↑↓\" label=\"scroll\" />\n </Box>\n ) : view === 'fullLog' ? (\n <Box>\n <Shortcut letter=\"t\" label=\"dashboard\" />\n <Shortcut letter=\"c\" label=\"copy\" />\n <Shortcut letter=\"/\" label=\"search\" />\n <Shortcut letter=\"f\" label=\"filter\" />\n <Shortcut letter=\"↑↓\" label=\"scroll\" />\n <Shortcut letter=\"PgUp/Dn\" label=\"page\" />\n </Box>\n ) : (\n <Box>\n <Shortcut letter=\"Esc\" label=\"cancel\" />\n </Box>\n );\n\n // Version display\n const versionDisplay = (\n <Box marginLeft={2}>\n <Text color={colors.dimGray}>\n {versionInfo.display}\n </Text>\n </Box>\n );\n\n return (\n <Box\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n paddingX={1}\n justifyContent=\"space-between\"\n >\n <Box>\n {connectionIndicator}\n {buildIndicator}\n </Box>\n <Box>\n {shortcuts}\n {versionDisplay}\n </Box>\n </Box>\n );\n}\n\n// Helper component for shortcuts\nfunction Shortcut({ letter, label }: { letter: string; label: string }) {\n return (\n <Box marginRight={2}>\n <Text color={colors.dimGray}>[</Text>\n <Text color={colors.cyan}>{letter}</Text>\n <Text color={colors.dimGray}>]</Text>\n <Text color={colors.gray}>{label}</Text>\n </Box>\n );\n}\n","/**\n * FullLogView - Full-screen log view with search and filter\n */\n\nimport React, { useState, useEffect } from 'react';\nimport { Box, Text, useInput, useStdout } from 'ink';\nimport TextInput from 'ink-text-input';\nimport { colors } from '../theme.js';\nimport type { LogEntry, LogLevel } from '../../../lib/logging/types.js';\n\ntype FilterMode = 'all' | 'errors' | 'tools' | 'verbose';\n\ninterface FullLogViewProps {\n entries: LogEntry[];\n onBack: () => void;\n onCopy: () => void;\n}\n\nexport function FullLogView({ entries, onBack, onCopy }: FullLogViewProps) {\n const { stdout } = useStdout();\n const terminalHeight = stdout?.rows || 24;\n const terminalWidth = stdout?.columns || 80;\n\n const [searchQuery, setSearchQuery] = useState('');\n const [isSearching, setIsSearching] = useState(false);\n const [filterMode, setFilterMode] = useState<FilterMode>('all');\n const [scrollOffset, setScrollOffset] = useState(0);\n const [searchMode, setSearchMode] = useState<'filter' | 'highlight'>('highlight');\n\n // Available height for log lines\n const headerHeight = 3;\n const footerHeight = 2;\n const visibleLines = Math.max(1, terminalHeight - headerHeight - footerHeight);\n\n // Filter and search entries\n const processedEntries = entries.filter(entry => {\n // Apply filter mode\n if (filterMode === 'errors' && entry.level !== 'error' && entry.level !== 'warn') {\n return false;\n }\n if (filterMode === 'tools' && !entry.toolName) {\n return false;\n }\n if (filterMode !== 'verbose' && entry.verbose) {\n return false;\n }\n\n // Apply search filter (if in filter mode)\n if (searchQuery && searchMode === 'filter') {\n const query = searchQuery.toLowerCase();\n const messageMatch = entry.message.toLowerCase().includes(query);\n const toolMatch = entry.toolName?.toLowerCase().includes(query);\n const argsMatch = entry.toolArgs?.toLowerCase().includes(query);\n return messageMatch || toolMatch || argsMatch;\n }\n\n return true;\n });\n\n // Calculate max scroll\n const maxScroll = Math.max(0, processedEntries.length - visibleLines);\n\n // Get visible entries\n const visibleEntries = processedEntries.slice(scrollOffset, scrollOffset + visibleLines);\n\n // Handle keyboard input\n useInput((input, key) => {\n if (isSearching) {\n if (key.escape || key.return) {\n setIsSearching(false);\n }\n return;\n }\n\n if (input === 't') {\n onBack();\n } else if (input === 'c') {\n onCopy();\n } else if (input === '/') {\n setIsSearching(true);\n } else if (input === 'f') {\n // Cycle through filter modes\n const modes: FilterMode[] = ['all', 'errors', 'tools', 'verbose'];\n const currentIndex = modes.indexOf(filterMode);\n setFilterMode(modes[(currentIndex + 1) % modes.length]);\n setScrollOffset(0);\n } else if (input === 'm') {\n // Toggle search mode\n setSearchMode(prev => prev === 'filter' ? 'highlight' : 'filter');\n } else if (key.upArrow) {\n setScrollOffset(prev => Math.max(0, prev - 1));\n } else if (key.downArrow) {\n setScrollOffset(prev => Math.min(maxScroll, prev + 1));\n } else if (key.pageUp) {\n setScrollOffset(prev => Math.max(0, prev - visibleLines));\n } else if (key.pageDown) {\n setScrollOffset(prev => Math.min(maxScroll, prev + visibleLines));\n } else if (key.escape) {\n if (searchQuery) {\n setSearchQuery('');\n } else {\n onBack();\n }\n }\n });\n\n // Format time\n const formatTime = (timestamp: number): string => {\n return new Date(timestamp).toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n });\n };\n\n // Check if text matches search query\n const highlightSearch = (text: string): React.ReactNode => {\n if (!searchQuery || searchMode !== 'highlight') {\n return text;\n }\n\n const query = searchQuery.toLowerCase();\n const index = text.toLowerCase().indexOf(query);\n if (index === -1) {\n return text;\n }\n\n return (\n <>\n {text.slice(0, index)}\n <Text backgroundColor={colors.warning} color=\"black\">\n {text.slice(index, index + searchQuery.length)}\n </Text>\n {text.slice(index + searchQuery.length)}\n </>\n );\n };\n\n return (\n <Box flexDirection=\"column\" height={terminalHeight}>\n {/* Header with search */}\n <Box\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n paddingX={1}\n justifyContent=\"space-between\"\n >\n <Text color={colors.cyan} bold>LOGS</Text>\n <Box>\n <Text color={colors.dimGray}>Search: </Text>\n {isSearching ? (\n <Box borderStyle=\"round\" borderColor={colors.cyan} paddingX={1}>\n <TextInput\n value={searchQuery}\n onChange={setSearchQuery}\n placeholder=\"type to search...\"\n />\n </Box>\n ) : (\n <Text color={searchQuery ? colors.white : colors.dimGray}>\n [{searchQuery || 'none'}] ({searchMode})\n </Text>\n )}\n <Text color={colors.dimGray}> [/]</Text>\n </Box>\n </Box>\n\n {/* Log content */}\n <Box\n flexDirection=\"column\"\n flexGrow={1}\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n borderTop={false}\n borderBottom={false}\n paddingX={1}\n >\n {visibleEntries.map((entry, index) => {\n const time = formatTime(entry.timestamp);\n const levelColors = {\n debug: colors.dimGray,\n info: colors.cyan,\n success: colors.success,\n warn: colors.warning,\n error: colors.error,\n };\n const levelIcons = {\n debug: ' ',\n info: '●',\n success: '✓',\n warn: '⚠',\n error: '✗',\n };\n\n if (entry.toolName) {\n return (\n <Box key={entry.id}>\n <Text color={colors.dimGray}>{time}</Text>\n <Text color={colors.cyan}> 🔧 </Text>\n <Text color={colors.white}>{highlightSearch(entry.toolName)}</Text>\n {entry.toolArgs && (\n <Text color={colors.gray}> {highlightSearch(entry.toolArgs)}</Text>\n )}\n </Box>\n );\n }\n\n return (\n <Box key={entry.id}>\n <Text color={colors.dimGray}>{time}</Text>\n <Text color={levelColors[entry.level]}> {levelIcons[entry.level]} </Text>\n <Text color={levelColors[entry.level]}>{highlightSearch(entry.message)}</Text>\n </Box>\n );\n })}\n </Box>\n\n {/* Footer with shortcuts and scroll position */}\n <Box\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n paddingX={1}\n justifyContent=\"space-between\"\n >\n <Box>\n <Shortcut letter=\"t\" label=\"dashboard\" />\n <Shortcut letter=\"c\" label=\"copy\" />\n <Shortcut letter=\"/\" label=\"search\" />\n <Shortcut letter=\"f\" label={`filter: ${filterMode}`} />\n <Shortcut letter=\"m\" label={`mode: ${searchMode}`} />\n </Box>\n <Text color={colors.dimGray}>\n {scrollOffset + 1}-{Math.min(scrollOffset + visibleLines, processedEntries.length)}/{processedEntries.length}\n </Text>\n </Box>\n </Box>\n );\n}\n\nfunction Shortcut({ letter, label }: { letter: string; label: string }) {\n return (\n <Box marginRight={2}>\n <Text color={colors.dimGray}>[</Text>\n <Text color={colors.cyan}>{letter}</Text>\n <Text color={colors.dimGray}>]</Text>\n <Text color={colors.gray}>{label}</Text>\n </Box>\n );\n}\n","/**\n * CopyMenu - Modal for copying logs to clipboard\n */\n\nimport React from 'react';\nimport { Box, Text, useInput } from 'ink';\nimport { colors } from '../theme.js';\n\ninterface CopyMenuProps {\n onSelect: (option: 'visible' | 'last50' | 'last100' | 'all' | 'range') => void;\n onCancel: () => void;\n visibleCount: number;\n totalCount: number;\n}\n\nexport function CopyMenu({ onSelect, onCancel, visibleCount, totalCount }: CopyMenuProps) {\n useInput((input, key) => {\n if (key.escape) {\n onCancel();\n } else if (input === '1') {\n onSelect('visible');\n } else if (input === '2') {\n onSelect('last50');\n } else if (input === '3') {\n onSelect('last100');\n } else if (input === '4') {\n onSelect('all');\n } else if (input === '5') {\n onSelect('range');\n }\n });\n\n return (\n <Box\n flexDirection=\"column\"\n borderStyle=\"round\"\n borderColor={colors.cyan}\n paddingX={2}\n paddingY={1}\n >\n <Box marginBottom={1}>\n <Text color={colors.cyan} bold>Copy Logs</Text>\n </Box>\n\n <Box flexDirection=\"column\" marginBottom={1}>\n <CopyOption number=\"1\" label={`Copy visible (${visibleCount} lines)`} />\n <CopyOption number=\"2\" label=\"Copy last 50 lines\" />\n <CopyOption number=\"3\" label=\"Copy last 100 lines\" />\n <CopyOption number=\"4\" label={`Copy all from file (${totalCount} lines)`} />\n <CopyOption number=\"5\" label=\"Copy range...\" />\n </Box>\n\n <Box>\n <Text color={colors.dimGray}>[Esc] Cancel</Text>\n </Box>\n </Box>\n );\n}\n\nfunction CopyOption({ number, label }: { number: string; label: string }) {\n return (\n <Box>\n <Text color={colors.dimGray}>[</Text>\n <Text color={colors.cyan}>{number}</Text>\n <Text color={colors.dimGray}>]</Text>\n <Text color={colors.white}> {label}</Text>\n </Box>\n );\n}\n","/**\n * RunnerDashboard - Main TUI container for the runner\n * \n * Layout:\n * - 20% left: BuildPanel (current build + todos) - hidden when no build\n * - 80% right: LogPanel (scrollable logs)\n * - Bottom: StatusBar (connection, shortcuts)\n * \n * Views:\n * - dashboard: Main split view\n * - fullLog: Full-screen log view with search\n * - copyMenu: Copy options modal overlay\n */\n\nimport React, { useState, useEffect, useCallback, useRef } from 'react';\nimport { Box, Text, useInput, useStdout, useApp } from 'ink';\nimport { colors } from '../theme.js';\nimport { BuildPanel } from '../components/BuildPanel.js';\nimport { LogPanel } from '../components/LogPanel.js';\nimport { StatusBar } from '../components/StatusBar.js';\nimport { FullLogView } from '../components/FullLogView.js';\nimport { CopyMenu } from '../components/CopyMenu.js';\nimport { useBuildState, useLogEntries } from '../hooks/useBuildState.js';\nimport { Banner } from '../components/Banner.js';\nimport type { BuildInfo, TodoItem, LogEntry } from '../../../lib/logging/types.js';\nimport { getLogBuffer } from '../../../lib/logging/log-buffer.js';\nimport { openBrowser } from '../../utils/cli-auth.js';\n\ntype ViewMode = 'dashboard' | 'fullLog' | 'copyMenu';\n\nexport interface RunnerDashboardProps {\n // Initial config (passed from runner)\n config: {\n runnerId: string;\n serverUrl: string;\n workspace: string;\n apiUrl?: string;\n };\n // Event handlers\n onQuit?: () => void;\n}\n\nexport function RunnerDashboard({ config, onQuit }: RunnerDashboardProps) {\n const { exit } = useApp();\n const { stdout } = useStdout();\n const terminalHeight = stdout?.rows || 24;\n const terminalWidth = stdout?.columns || 80;\n\n // State management\n const [buildState, buildActions] = useBuildState();\n const logEntries = useLogEntries(100);\n const [view, setView] = useState<ViewMode>('dashboard');\n \n // Track if we've opened browser on first connection\n const hasOpenedBrowserRef = useRef(false);\n\n // Get the dashboard URL (use apiUrl if provided, otherwise default to hatchway.sh)\n const dashboardUrl = config.apiUrl || 'https://hatchway.sh';\n\n // Open browser handler\n const handleOpenBrowser = useCallback(() => {\n openBrowser(dashboardUrl).catch(() => {\n // Silently fail - user can manually open the URL\n });\n }, [dashboardUrl]);\n\n // Auto-open browser on first successful connection\n useEffect(() => {\n if (buildState.isConnected && !hasOpenedBrowserRef.current) {\n hasOpenedBrowserRef.current = true;\n // Small delay to ensure the TUI is fully rendered before opening browser\n setTimeout(() => {\n handleOpenBrowser();\n }, 500);\n }\n }, [buildState.isConnected, handleOpenBrowser]);\n\n // Handle keyboard input\n useInput((input, key) => {\n // Global quit handler\n if (input === 'q' && view !== 'copyMenu') {\n if (onQuit) {\n onQuit();\n }\n exit();\n return;\n }\n\n // Copy menu is modal - handle separately\n if (view === 'copyMenu') {\n return; // CopyMenu handles its own input\n }\n\n // Dashboard shortcuts\n if (view === 'dashboard') {\n if (input === 'v') {\n buildActions.toggleVerbose();\n } else if (input === 'c') {\n setView('copyMenu');\n } else if (input === 't') {\n setView('fullLog');\n } else if (input === 'n') {\n buildActions.nextBuild();\n } else if (input === 'p') {\n buildActions.prevBuild();\n } else if (input === 'b') {\n handleOpenBrowser();\n }\n }\n\n // Full log view shortcuts\n if (view === 'fullLog') {\n if (input === 't') {\n setView('dashboard');\n } else if (input === 'c') {\n setView('copyMenu');\n }\n }\n });\n\n // Handle copy action\n const handleCopy = useCallback(async (option: 'visible' | 'last50' | 'last100' | 'all' | 'range') => {\n try {\n const buffer = getLogBuffer();\n let entriesToCopy: LogEntry[] = [];\n\n switch (option) {\n case 'visible':\n entriesToCopy = logEntries.slice(-20); // Approximate visible count\n break;\n case 'last50':\n entriesToCopy = buffer.getRecent(50);\n break;\n case 'last100':\n entriesToCopy = buffer.getRecent(100);\n break;\n case 'all':\n entriesToCopy = buffer.readFromFile();\n break;\n case 'range':\n // TODO: Implement range selection\n entriesToCopy = buffer.getRecent(100);\n break;\n }\n\n const text = buffer.toText(entriesToCopy);\n \n // Copy to clipboard using pbcopy on macOS\n const { spawn } = await import('child_process');\n const pbcopy = spawn('pbcopy');\n pbcopy.stdin.write(text);\n pbcopy.stdin.end();\n \n // TODO: Show success message\n } catch (error) {\n console.error('Failed to copy to clipboard:', error);\n }\n\n setView('dashboard');\n }, [logEntries]);\n\n // Calculate panel dimensions\n const bannerHeight = 7; // ASCII art banner\n const headerHeight = 3; // Config/status line\n const statusBarHeight = 3;\n const contentHeight = Math.max(1, terminalHeight - bannerHeight - headerHeight - statusBarHeight);\n \n // 20/80 split\n const buildPanelWidth = Math.floor(terminalWidth * 0.2);\n const logPanelWidth = terminalWidth - buildPanelWidth;\n\n // Show build panel only when there's an active build\n const showBuildPanel = buildState.currentBuild !== null;\n\n // Check for available update (set by auto-update check in index.ts)\n const updateAvailable = process.env.HATCHWAY_UPDATE_AVAILABLE;\n\n return (\n <Box flexDirection=\"column\" height={terminalHeight} width={terminalWidth}>\n {/* Banner */}\n <Banner />\n\n {/* Update notification banner */}\n {updateAvailable && (\n <Box justifyContent=\"center\" paddingY={0}>\n <Text color={colors.cyan}>⬆ Update available: </Text>\n <Text color={colors.success}>{updateAvailable}</Text>\n <Text color={colors.dimGray}> — Run </Text>\n <Text color={colors.cyan}>hatchway upgrade</Text>\n <Text color={colors.dimGray}> to update</Text>\n </Box>\n )}\n\n {/* Header bar with connection status */}\n <Box\n borderStyle=\"single\"\n borderColor={colors.darkGray}\n paddingX={1}\n justifyContent=\"space-between\"\n >\n <Text color={colors.dimGray}>\n Runner: <Text color={colors.cyan}>{config.runnerId}</Text> • Server: <Text color={colors.cyan}>{config.serverUrl.replace(/^wss?:\\/\\//, '')}</Text>\n </Text>\n <Box>\n <Text color={buildState.isConnected ? colors.success : colors.error}>\n {buildState.isConnected ? '●' : '○'}\n </Text>\n <Text color={colors.gray}>\n {' '}{buildState.isConnected ? 'Connected' : 'Disconnected'}\n </Text>\n </Box>\n </Box>\n\n {/* Main content */}\n {view === 'dashboard' && (\n <Box flexGrow={1} height={contentHeight}>\n {showBuildPanel && (\n <BuildPanel\n build={buildState.currentBuild}\n width={buildPanelWidth}\n height={contentHeight}\n />\n )}\n <LogPanel\n entries={logEntries}\n isVerbose={buildState.isVerbose}\n width={showBuildPanel ? logPanelWidth : terminalWidth}\n height={contentHeight}\n isFocused={true}\n />\n </Box>\n )}\n\n {view === 'fullLog' && (\n <FullLogView\n entries={logEntries}\n onBack={() => setView('dashboard')}\n onCopy={() => setView('copyMenu')}\n />\n )}\n\n {/* Copy menu overlay */}\n {view === 'copyMenu' && (\n <Box\n position=\"absolute\"\n flexDirection=\"column\"\n justifyContent=\"center\"\n alignItems=\"center\"\n width={terminalWidth}\n height={terminalHeight}\n >\n <CopyMenu\n onSelect={handleCopy}\n onCancel={() => setView('dashboard')}\n visibleCount={Math.min(20, logEntries.length)}\n totalCount={getLogBuffer().readFromFile().length}\n />\n </Box>\n )}\n\n {/* Status bar (only in dashboard view) */}\n {view === 'dashboard' && (\n <StatusBar\n isConnected={buildState.isConnected}\n isVerbose={buildState.isVerbose}\n buildCount={buildState.builds.length}\n currentBuildIndex={buildState.currentBuildIndex}\n view={view}\n />\n )}\n </Box>\n );\n}\n\n// Export for external use\nexport { useBuildState, useLogEntries };\n","import chalk from 'chalk';\nimport { homedir, userInfo } from 'node:os';\nimport { join } from 'node:path';\nimport { render } from 'ink';\nimport React from 'react';\nimport { logger } from '../utils/logger.js';\nimport { configManager } from '../utils/config-manager.js';\nimport { startRunner } from '../../index.js';\nimport { RunnerDashboard } from '../tui/screens/RunnerDashboard.js';\nimport { initRunnerLogger } from '../../lib/logging/index.js';\nimport { setFileLoggerTuiMode } from '../../lib/file-logger.js';\nimport { \n hasStoredToken, \n getStoredToken, \n performOAuthLogin, \n storeToken \n} from '../utils/cli-auth.js';\n\n// Default public Hatchway instance\nconst DEFAULT_URL = 'https://hatchway.sh';\nconst DEFAULT_WORKSPACE = join(homedir(), 'hatchway-workspace');\n\n/**\n * Normalize URL by adding protocol if missing\n * Uses http:// for localhost, https:// for everything else\n */\nfunction normalizeUrl(url: string): string {\n if (!url) return url;\n\n // If protocol already present, return as-is\n if (url.match(/^https?:\\/\\//i)) {\n return url;\n }\n\n // For localhost or 127.0.0.1, use http://\n if (url.match(/^(localhost|127\\.0\\.0\\.1)(:|\\/|$)/i)) {\n return `http://${url}`;\n }\n\n // For everything else, use https://\n return `https://${url}`;\n}\n\n/**\n * Derive WebSocket URL from a base HTTP/HTTPS URL\n * Converts https://example.com to wss://example.com/ws/runner\n */\nfunction deriveWsUrl(baseUrl: string): string {\n const normalized = normalizeUrl(baseUrl);\n const wsProtocol = normalized.startsWith('https://') ? 'wss://' : 'ws://';\n const hostPath = normalized.replace(/^https?:\\/\\//, '');\n // Remove trailing slash if present\n const cleanHostPath = hostPath.replace(/\\/$/, '');\n return `${wsProtocol}${cleanHostPath}/ws/runner`;\n}\n\n/**\n * Get the current system username\n */\nfunction getSystemUsername(): string {\n try {\n return userInfo().username;\n } catch {\n // Fallback if userInfo() fails\n return process.env.USER || process.env.USERNAME || 'runner';\n }\n}\n\ninterface RunOptions {\n broker?: string; // Legacy: WebSocket URL override (deprecated, use --url instead)\n url?: string;\n workspace?: string;\n runnerId?: string;\n secret?: string;\n verbose?: boolean;\n local?: boolean; // Enable local mode (bypasses authentication)\n noTui?: boolean; // Disable TUI dashboard\n}\n\n/**\n * Check if we should use TUI\n */\nfunction shouldUseTUI(options: RunOptions): boolean {\n // Explicit flag\n if (options.noTui) return false;\n\n // CI/CD environments\n if (process.env.CI === '1' || process.env.CI === 'true') return false;\n\n // Not a TTY\n if (!process.stdout.isTTY) return false;\n\n // Explicit env var to disable\n if (process.env.NO_TUI === '1') return false;\n\n return true;\n}\n\nexport async function runCommand(options: RunOptions) {\n // Set local mode environment variable if requested\n if (options.local) {\n process.env.HATCHWAY_LOCAL_MODE = 'true';\n logger.info(chalk.yellow('Local mode enabled - authentication bypassed'));\n }\n\n const useTUI = shouldUseTUI(options);\n\n // Build runner options from CLI flags or smart defaults\n // NOTE: For the `runner` command, we intentionally ignore local config values\n // and default to the public Hatchway instance. This command is specifically\n // for connecting to remote servers, not local development.\n // Users can still override with CLI flags if needed.\n \n // Resolve API URL: CLI flag > default public instance (ignore config)\n const apiUrl = normalizeUrl(options.url || DEFAULT_URL);\n \n // Resolve WebSocket URL: CLI broker flag > derive from API URL (ignore config)\n const wsUrl = options.broker || deriveWsUrl(apiUrl);\n \n // Resolve workspace: CLI flag > config > default ~/hatchway-workspace\n // (workspace from config is fine since it's user's preference for where projects go)\n const config = configManager.get();\n const workspace = options.workspace || config.workspace || DEFAULT_WORKSPACE;\n \n // Resolve runner ID: CLI flag > system username (ignore config 'local' default)\n const runnerId = options.runnerId || getSystemUsername();\n \n // Resolve secret: CLI flag > config (required)\n // Only use config secret if it looks like a valid token (starts with sv_)\n // This prevents the default 'dev-secret' from being used in runner mode\n const configSecret = configManager.getSecret();\n const sharedSecret = options.secret || (configSecret?.startsWith('sv_') ? configSecret : undefined);\n\n const runnerOptions = {\n wsUrl,\n apiUrl,\n sharedSecret,\n runnerId,\n workspace,\n verbose: options.verbose,\n tuiMode: useTUI,\n };\n\n // Validate required options - secret is required\n // If not provided, try to use stored OAuth token or trigger OAuth flow\n if (!runnerOptions.sharedSecret) {\n // Check if we have a stored OAuth token\n if (hasStoredToken()) {\n const storedToken = getStoredToken();\n if (storedToken) {\n runnerOptions.sharedSecret = storedToken;\n logger.info(`Using stored runner token: ${chalk.cyan(storedToken.substring(0, 12) + '...')}`);\n }\n }\n \n // If still no secret and not in local mode, trigger OAuth flow\n if (!runnerOptions.sharedSecret && !options.local) {\n logger.info('No runner token found. Starting OAuth authentication...');\n logger.info('');\n \n const result = await performOAuthLogin({\n apiUrl: runnerOptions.apiUrl,\n silent: false,\n });\n \n if (result.success && result.token) {\n storeToken(result.token, runnerOptions.apiUrl);\n runnerOptions.sharedSecret = result.token;\n logger.log('');\n logger.success('Authentication successful!');\n logger.info(`Token: ${chalk.cyan(result.token.substring(0, 12) + '...')}`);\n logger.log('');\n } else {\n logger.error(result.error || 'Authentication failed');\n logger.info('');\n logger.info('You can also provide a token manually:');\n logger.info(` ${chalk.cyan('hatchway runner --secret <your-secret>')}`);\n logger.info('');\n logger.info('Or login first:');\n logger.info(` ${chalk.cyan('hatchway login')}`);\n process.exit(1);\n }\n }\n \n // Final check - if still no secret (and not local mode)\n if (!runnerOptions.sharedSecret && !options.local) {\n logger.error('Shared secret is required');\n logger.info('');\n logger.info('Get a runner key from your Hatchway dashboard, or provide via:');\n logger.info(` ${chalk.cyan('hatchway runner --secret <your-secret>')}`);\n logger.info('');\n logger.info('Or login with OAuth:');\n logger.info(` ${chalk.cyan('hatchway login')}`);\n process.exit(1);\n }\n }\n\n // ========================================\n // PLAIN TEXT MODE (--no-tui)\n // ========================================\n if (!useTUI) {\n // Display startup info\n logger.section('Starting Hatchway Runner');\n logger.info(`Server: ${chalk.cyan(runnerOptions.wsUrl)}`);\n logger.info(`API URL: ${chalk.cyan(runnerOptions.apiUrl)}`);\n logger.info(`Runner ID: ${chalk.cyan(runnerOptions.runnerId)}`);\n logger.info(`Workspace: ${chalk.cyan(runnerOptions.workspace)}`);\n logger.log('');\n\n if (options.verbose) {\n logger.debug('Verbose logging enabled');\n logger.debug(`Full options: ${JSON.stringify(runnerOptions, null, 2)}`);\n }\n\n try {\n // Start the runner (runs indefinitely)\n await startRunner(runnerOptions);\n } catch (error) {\n logger.error('Failed to start runner:');\n logger.error(error instanceof Error ? error.message : 'Unknown error');\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack);\n }\n process.exit(1);\n }\n return;\n }\n\n // ========================================\n // TUI MODE (default)\n // ========================================\n \n // Initialize the logger BEFORE rendering TUI so the TUI can subscribe to events\n // This must happen before startRunner() which would create its own logger\n initRunnerLogger({\n verbose: options.verbose || false,\n tuiMode: true,\n });\n \n // Enable TUI mode in file-logger to suppress terminal output\n setFileLoggerTuiMode(true);\n \n // Track runner cleanup function\n let runnerCleanupFn: (() => Promise<void>) | undefined;\n\n // Clear screen and enter alternate buffer for clean TUI\n process.stdout.write('\\x1b[?1049h'); // Enter alternate screen\n process.stdout.write('\\x1b[2J\\x1b[H'); // Clear and home\n\n // Ensure stdin is in raw mode for keyboard input\n if (process.stdin.setRawMode) {\n process.stdin.setRawMode(true);\n }\n process.stdin.resume();\n\n // Handle quit from TUI\n const handleQuit = async () => {\n // Exit alternate screen buffer\n process.stdout.write('\\x1b[?1049l');\n \n console.log('\\n' + chalk.yellow('Shutting down runner...'));\n \n if (runnerCleanupFn) {\n try {\n await runnerCleanupFn();\n console.log(chalk.green('✓') + ' Runner stopped');\n } catch (e) {\n console.error(chalk.red('✗') + ' Error stopping runner:', e);\n }\n }\n \n process.exit(0);\n };\n\n // Handle SIGINT (Ctrl+C)\n process.on('SIGINT', handleQuit);\n\n // Render the TUI dashboard\n const { waitUntilExit, clear } = render(\n React.createElement(RunnerDashboard, {\n config: {\n runnerId,\n serverUrl: wsUrl,\n workspace,\n apiUrl,\n },\n onQuit: handleQuit,\n }),\n {\n stdin: process.stdin,\n stdout: process.stdout,\n stderr: process.stderr,\n exitOnCtrlC: false, // We handle this ourselves\n patchConsole: false, // We use our own logging\n }\n );\n\n try {\n // Start the runner and get cleanup function\n runnerCleanupFn = await startRunner(runnerOptions);\n\n // Wait for TUI to exit (user pressed 'q')\n await waitUntilExit();\n\n // Clean up\n clear();\n await handleQuit();\n } catch (error) {\n clear();\n process.stdout.write('\\x1b[?1049l'); // Exit alternate screen\n \n logger.error('Failed to start runner:');\n logger.error(error instanceof Error ? error.message : 'Unknown error');\n if (error instanceof Error && error.stack) {\n logger.debug(error.stack);\n }\n process.exit(1);\n }\n}\n"],"names":["useState","useEffect","_jsxs","_jsx","Shortcut","useRef","useCallback"],"mappings":"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"}
|
|
@@ -1,13 +1,8 @@
|
|
|
1
1
|
// Hatchway CLI - Built with Rollup
|
|
2
2
|
import { execSync } from 'node:child_process';
|
|
3
3
|
import { existsSync, readFileSync } from 'node:fs';
|
|
4
|
-
import {
|
|
4
|
+
import { dirname, join } from 'node:path';
|
|
5
5
|
import { fileURLToPath } from 'node:url';
|
|
6
|
-
import { j as jsxRuntimeExports, B as Box, T as Text, c as colors } from './theme-NAQBkisB.js';
|
|
7
|
-
import 'node:stream';
|
|
8
|
-
import 'node:process';
|
|
9
|
-
import 'chalk';
|
|
10
|
-
import 'node:events';
|
|
11
6
|
|
|
12
7
|
/**
|
|
13
8
|
* Version and git commit info utilities
|
|
@@ -93,23 +88,5 @@ function getVersionInfo() {
|
|
|
93
88
|
};
|
|
94
89
|
}
|
|
95
90
|
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
* Each line is padded to exactly the same width for perfect alignment
|
|
99
|
-
*/
|
|
100
|
-
function Banner() {
|
|
101
|
-
// Full banner lines - HATCH in cyan, WAY in purple
|
|
102
|
-
// All lines padded to same total width for consistent centering
|
|
103
|
-
const lines = [
|
|
104
|
-
{ hatch: '██╗ ██╗ █████╗ ████████╗ ██████╗██╗ ██╗', way: '██╗ ██╗ █████╗ ██╗ ██╗' },
|
|
105
|
-
{ hatch: '██║ ██║██╔══██╗╚══██╔══╝██╔════╝██║ ██║', way: '██║ ██║██╔══██╗╚██╗ ██╔╝' },
|
|
106
|
-
{ hatch: '███████║███████║ ██║ ██║ ███████║', way: '██║ █╗ ██║███████║ ╚████╔╝ ' },
|
|
107
|
-
{ hatch: '██╔══██║██╔══██║ ██║ ██║ ██╔══██║', way: '██║███╗██║██╔══██║ ╚██╔╝ ' },
|
|
108
|
-
{ hatch: '██║ ██║██║ ██║ ██║ ╚██████╗██║ ██║', way: '╚███╔███╔╝██║ ██║ ██║ ' },
|
|
109
|
-
{ hatch: '╚═╝ ╚═╝╚═╝ ╚═╝ ╚═╝ ╚═════╝╚═╝ ╚═╝', way: ' ╚══╝╚══╝ ╚═╝ ╚═╝ ╚═╝ ' },
|
|
110
|
-
];
|
|
111
|
-
return (jsxRuntimeExports.jsx(Box, { flexDirection: "column", alignItems: "center", children: lines.map((line, index) => (jsxRuntimeExports.jsxs(Box, { children: [jsxRuntimeExports.jsx(Text, { color: colors.cyan, children: line.hatch }), jsxRuntimeExports.jsx(Text, { color: colors.brightPurple, children: line.way })] }, index))) }));
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
export { Banner as B, getVersionInfo as g };
|
|
115
|
-
//# sourceMappingURL=Banner-DL1Fpz_g.js.map
|
|
91
|
+
export { getPackageVersion as a, getVersionInfo as g };
|
|
92
|
+
//# sourceMappingURL=version-info-CDtU8Ta2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"version-info-CDtU8Ta2.js","sources":["../../src/cli/utils/version-info.ts"],"sourcesContent":["/**\n * Version and git commit info utilities\n */\n\nimport { execSync } from 'node:child_process';\nimport { readFileSync, existsSync } from 'node:fs';\nimport { join, dirname } from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = dirname(__filename);\n\n/**\n * Find the package root directory (apps/runner).\n * Works in both development (src/cli/utils/) and production (dist/cli/utils/) modes.\n */\nfunction findPackageRoot(): string {\n // Try multiple possible locations\n const possiblePaths = [\n // Development: src/cli/utils/ -> apps/runner (3 levels up)\n join(__dirname, '..', '..', '..'),\n // Production from dist/cli/utils/: -> apps/runner (3 levels up, same structure)\n join(__dirname, '..', '..', '..'),\n ];\n \n for (const path of possiblePaths) {\n const packageJsonPath = join(path, 'package.json');\n if (existsSync(packageJsonPath)) {\n try {\n const pkg = JSON.parse(readFileSync(packageJsonPath, 'utf-8'));\n // Verify this is the runner package\n if (pkg.name === '@hatchway/cli') {\n return path;\n }\n } catch {\n // Continue to next path\n }\n }\n }\n \n // Fallback to the standard path\n return join(__dirname, '..', '..', '..');\n}\n\n// Cache the package root\nconst packageRoot = findPackageRoot();\n\n/**\n * Get the package version from package.json\n */\nexport function getPackageVersion(): string {\n try {\n const packageJsonPath = join(packageRoot, 'package.json');\n if (existsSync(packageJsonPath)) {\n const packageJson = JSON.parse(readFileSync(packageJsonPath, 'utf-8'));\n return packageJson.version || '0.0.0';\n }\n } catch {\n // Ignore errors\n }\n return '0.0.0';\n}\n\n/**\n * Get the short git commit hash\n */\nexport function getGitCommit(): string | null {\n try {\n // Try to get commit from git command\n const commit = execSync('git rev-parse --short HEAD', {\n cwd: packageRoot,\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n return commit || null;\n } catch {\n // Git not available or not a git repo\n return null;\n }\n}\n\n/**\n * Get combined version string with commit\n * Returns \"v0.19.1 (abc1234)\" or just \"v0.19.1\" if no commit\n */\nexport function getVersionString(): string {\n const version = getPackageVersion();\n const commit = getGitCommit();\n \n if (commit) {\n return `v${version} (${commit})`;\n }\n return `v${version}`;\n}\n\n/**\n * Version info object\n */\nexport interface VersionInfo {\n version: string;\n commit: string | null;\n display: string;\n}\n\n/**\n * Get all version info\n */\nexport function getVersionInfo(): VersionInfo {\n const version = getPackageVersion();\n const commit = getGitCommit();\n \n return {\n version,\n commit,\n display: commit ? `v${version} (${commit})` : `v${version}`,\n };\n}\n"],"names":["__filename","__dirname"],"mappings":";;;;;;AAAA;;AAEG;AAOH,MAAMA,YAAU,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;AACjD,MAAMC,WAAS,GAAG,OAAO,CAACD,YAAU,CAAC;AAErC;;;AAGG;AACH,SAAS,eAAe,GAAA;;AAEtB,IAAA,MAAM,aAAa,GAAG;;QAEpB,IAAI,CAACC,WAAS,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;;QAEjC,IAAI,CAACA,WAAS,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;KAClC;AAED,IAAA,KAAK,MAAM,IAAI,IAAI,aAAa,EAAE;QAChC,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,EAAE,cAAc,CAAC;AAClD,QAAA,IAAI,UAAU,CAAC,eAAe,CAAC,EAAE;AAC/B,YAAA,IAAI;AACF,gBAAA,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;;AAE9D,gBAAA,IAAI,GAAG,CAAC,IAAI,KAAK,eAAe,EAAE;AAChC,oBAAA,OAAO,IAAI;gBACb;YACF;AAAE,YAAA,MAAM;;YAER;QACF;IACF;;IAGA,OAAO,IAAI,CAACA,WAAS,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;AAC1C;AAEA;AACA,MAAM,WAAW,GAAG,eAAe,EAAE;AAErC;;AAEG;SACa,iBAAiB,GAAA;AAC/B,IAAA,IAAI;QACF,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,EAAE,cAAc,CAAC;AACzD,QAAA,IAAI,UAAU,CAAC,eAAe,CAAC,EAAE;AAC/B,YAAA,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;AACtE,YAAA,OAAO,WAAW,CAAC,OAAO,IAAI,OAAO;QACvC;IACF;AAAE,IAAA,MAAM;;IAER;AACA,IAAA,OAAO,OAAO;AAChB;AAEA;;AAEG;SACa,YAAY,GAAA;AAC1B,IAAA,IAAI;;AAEF,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,4BAA4B,EAAE;AACpD,YAAA,GAAG,EAAE,WAAW;AAChB,YAAA,QAAQ,EAAE,OAAO;AACjB,YAAA,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;SAChC,CAAC,CAAC,IAAI,EAAE;QACT,OAAO,MAAM,IAAI,IAAI;IACvB;AAAE,IAAA,MAAM;;AAEN,QAAA,OAAO,IAAI;IACb;AACF;AAyBA;;AAEG;SACa,cAAc,GAAA;AAC5B,IAAA,MAAM,OAAO,GAAG,iBAAiB,EAAE;AACnC,IAAA,MAAM,MAAM,GAAG,YAAY,EAAE;IAE7B,OAAO;QACL,OAAO;QACP,MAAM;AACN,QAAA,OAAO,EAAE,MAAM,GAAG,CAAA,CAAA,EAAI,OAAO,CAAA,EAAA,EAAK,MAAM,GAAG,GAAG,CAAA,CAAA,EAAI,OAAO,CAAA,CAAE;KAC5D;AACH;;;;"}
|
package/dist/cli/index.js
CHANGED
|
@@ -510,12 +510,12 @@ program
|
|
|
510
510
|
// Default action when no subcommand is provided
|
|
511
511
|
if (options.runner) {
|
|
512
512
|
// Start runner only (legacy flag)
|
|
513
|
-
const { runCommand } = await import('../chunks/run-
|
|
513
|
+
const { runCommand } = await import('../chunks/run-BbxtXsLx.js');
|
|
514
514
|
await runCommand({});
|
|
515
515
|
}
|
|
516
516
|
else {
|
|
517
517
|
// Show TUI main menu
|
|
518
|
-
const { mainTUICommand } = await import('../chunks/main-tui-
|
|
518
|
+
const { mainTUICommand } = await import('../chunks/main-tui-qySRaa-s.js');
|
|
519
519
|
await mainTUICommand();
|
|
520
520
|
}
|
|
521
521
|
}
|
|
@@ -536,7 +536,7 @@ program
|
|
|
536
536
|
.option('--non-interactive', 'Use defaults without prompts (alias for -y)')
|
|
537
537
|
.action(async (options) => {
|
|
538
538
|
try {
|
|
539
|
-
const { initCommand } = await import('../chunks/init-
|
|
539
|
+
const { initCommand } = await import('../chunks/init-CBODHYDw.js');
|
|
540
540
|
await initCommand(options);
|
|
541
541
|
}
|
|
542
542
|
catch (error) {
|
|
@@ -587,7 +587,7 @@ program
|
|
|
587
587
|
.option('--no-tui', 'Disable TUI dashboard, use plain text logs')
|
|
588
588
|
.action(async (options) => {
|
|
589
589
|
try {
|
|
590
|
-
const { runCommand } = await import('../chunks/run-
|
|
590
|
+
const { runCommand } = await import('../chunks/run-BbxtXsLx.js');
|
|
591
591
|
await runCommand(options);
|
|
592
592
|
}
|
|
593
593
|
catch (error) {
|
package/dist/index.js
CHANGED
|
@@ -29,6 +29,7 @@ import { simpleGit } from 'simple-git';
|
|
|
29
29
|
import * as os from 'os';
|
|
30
30
|
import { existsSync as existsSync$1, mkdirSync as mkdirSync$1 } from 'fs';
|
|
31
31
|
import { tunnelManager } from './chunks/manager-DjVI7erc.js';
|
|
32
|
+
import { a as getPackageVersion } from './chunks/version-info-CDtU8Ta2.js';
|
|
32
33
|
import 'chalk';
|
|
33
34
|
import 'http';
|
|
34
35
|
import 'http-proxy';
|
|
@@ -4334,9 +4335,10 @@ function buildPromptWithImages(prompt, messageParts) {
|
|
|
4334
4335
|
* query() SDK function -> minimal transformation -> output
|
|
4335
4336
|
*
|
|
4336
4337
|
* Sentry Integration:
|
|
4337
|
-
* -
|
|
4338
|
-
* -
|
|
4339
|
-
* -
|
|
4338
|
+
* - Manual gen_ai.* spans for AI Agent Monitoring in Sentry
|
|
4339
|
+
* - gen_ai.invoke_agent wraps the full query lifecycle
|
|
4340
|
+
* - gen_ai.execute_tool spans are emitted per tool call
|
|
4341
|
+
* - Token usage and cost are captured from the SDK result message
|
|
4340
4342
|
*/
|
|
4341
4343
|
function createNativeClaudeQuery(modelId = DEFAULT_CLAUDE_MODEL_ID, abortController) {
|
|
4342
4344
|
return async function* nativeClaudeQuery(prompt, workingDirectory, systemPrompt, _agent, _codexThreadId, messageParts) {
|
|
@@ -4422,20 +4424,44 @@ function createNativeClaudeQuery(modelId = DEFAULT_CLAUDE_MODEL_ID, abortControl
|
|
|
4422
4424
|
let messageCount = 0;
|
|
4423
4425
|
let toolCallCount = 0;
|
|
4424
4426
|
let textBlockCount = 0;
|
|
4427
|
+
// Wrap the entire agent execution in a gen_ai.invoke_agent span for Sentry AI monitoring
|
|
4428
|
+
const agentSpan = Sentry.startInactiveSpan({
|
|
4429
|
+
op: 'gen_ai.invoke_agent',
|
|
4430
|
+
name: `Claude Agent (${modelId})`,
|
|
4431
|
+
attributes: {
|
|
4432
|
+
'gen_ai.agent.name': 'hatchway-builder',
|
|
4433
|
+
'gen_ai.request.model': modelId,
|
|
4434
|
+
'gen_ai.agent.input': finalPrompt.substring(0, 500),
|
|
4435
|
+
'gen_ai.system_prompt.length': appendedSystemPrompt.length,
|
|
4436
|
+
'gen_ai.agent.available_tools': JSON.stringify(['Bash', 'Read', 'Write', 'Edit', 'Glob', 'Grep', 'Task', 'TodoWrite', 'WebFetch']),
|
|
4437
|
+
},
|
|
4438
|
+
});
|
|
4425
4439
|
try {
|
|
4426
4440
|
// Stream messages directly from the SDK
|
|
4427
|
-
// NOTE: query() is auto-instrumented by Sentry's claudeCodeAgentSdkIntegration
|
|
4428
4441
|
for await (const sdkMessage of query({ prompt: finalPrompt, options })) {
|
|
4429
4442
|
messageCount++;
|
|
4430
4443
|
// Transform SDK message to our internal format
|
|
4431
4444
|
const transformed = transformSDKMessage(sdkMessage);
|
|
4432
4445
|
if (transformed) {
|
|
4433
|
-
// Track stats for
|
|
4446
|
+
// Track stats and emit gen_ai.execute_tool spans for tool calls
|
|
4434
4447
|
if (transformed.type === 'assistant' && transformed.message?.content) {
|
|
4435
4448
|
for (const block of transformed.message.content) {
|
|
4436
4449
|
if (block.type === 'tool_use') {
|
|
4437
4450
|
toolCallCount++;
|
|
4438
4451
|
debugLog$4(`[runner] [native-sdk] 🔧 Tool call: ${block.name}\n`);
|
|
4452
|
+
// Emit a gen_ai.execute_tool span for each tool invocation
|
|
4453
|
+
const toolSpan = Sentry.startInactiveSpan({
|
|
4454
|
+
op: 'gen_ai.execute_tool',
|
|
4455
|
+
name: `Tool: ${block.name}`,
|
|
4456
|
+
attributes: {
|
|
4457
|
+
'gen_ai.tool.name': block.name,
|
|
4458
|
+
'gen_ai.tool.call_id': block.id,
|
|
4459
|
+
'gen_ai.tool.input': JSON.stringify(block.input).substring(0, 1000),
|
|
4460
|
+
},
|
|
4461
|
+
});
|
|
4462
|
+
// Tool spans are completed immediately since we get input and output
|
|
4463
|
+
// as separate messages — the output is captured in the tool_result handler below
|
|
4464
|
+
toolSpan?.end();
|
|
4439
4465
|
}
|
|
4440
4466
|
else if (block.type === 'text') {
|
|
4441
4467
|
textBlockCount++;
|
|
@@ -4484,13 +4510,31 @@ function createNativeClaudeQuery(modelId = DEFAULT_CLAUDE_MODEL_ID, abortControl
|
|
|
4484
4510
|
process.stderr.write(`[native-sdk] Tool use summary: ${summaryMsg.summary}\n`);
|
|
4485
4511
|
}
|
|
4486
4512
|
}
|
|
4487
|
-
//
|
|
4513
|
+
// Capture result messages — record token usage and cost on the agent span
|
|
4488
4514
|
if (sdkMessage.type === 'result') {
|
|
4489
|
-
|
|
4490
|
-
|
|
4515
|
+
const resultMsg = sdkMessage;
|
|
4516
|
+
if (agentSpan) {
|
|
4517
|
+
agentSpan.setAttribute('gen_ai.usage.input_tokens', resultMsg.usage?.input_tokens ?? 0);
|
|
4518
|
+
agentSpan.setAttribute('gen_ai.usage.output_tokens', resultMsg.usage?.output_tokens ?? 0);
|
|
4519
|
+
agentSpan.setAttribute('gen_ai.usage.total_tokens', (resultMsg.usage?.input_tokens ?? 0) + (resultMsg.usage?.output_tokens ?? 0));
|
|
4520
|
+
agentSpan.setAttribute('gen_ai.usage.cost_usd', resultMsg.total_cost_usd ?? 0);
|
|
4521
|
+
agentSpan.setAttribute('gen_ai.agent.num_turns', resultMsg.num_turns ?? 0);
|
|
4522
|
+
agentSpan.setAttribute('gen_ai.agent.num_tool_calls', toolCallCount);
|
|
4523
|
+
agentSpan.setAttribute('gen_ai.agent.result', resultMsg.subtype ?? 'unknown');
|
|
4524
|
+
agentSpan.setAttribute('gen_ai.agent.duration_ms', resultMsg.duration_ms ?? 0);
|
|
4525
|
+
agentSpan.setAttribute('gen_ai.agent.duration_api_ms', resultMsg.duration_api_ms ?? 0);
|
|
4526
|
+
if (resultMsg.usage?.cache_read_input_tokens) {
|
|
4527
|
+
agentSpan.setAttribute('gen_ai.usage.cache_read_tokens', resultMsg.usage.cache_read_input_tokens);
|
|
4528
|
+
}
|
|
4529
|
+
if (resultMsg.usage?.cache_creation_input_tokens) {
|
|
4530
|
+
agentSpan.setAttribute('gen_ai.usage.cache_creation_tokens', resultMsg.usage.cache_creation_input_tokens);
|
|
4531
|
+
}
|
|
4532
|
+
}
|
|
4533
|
+
if (resultMsg.subtype === 'success') {
|
|
4534
|
+
debugLog$4(`[runner] [native-sdk] ✅ Query complete - ${resultMsg.num_turns} turns, $${resultMsg.total_cost_usd?.toFixed(4)} USD\n`);
|
|
4491
4535
|
}
|
|
4492
4536
|
else {
|
|
4493
|
-
debugLog$4(`[runner] [native-sdk] ⚠️ Query ended with: ${
|
|
4537
|
+
debugLog$4(`[runner] [native-sdk] ⚠️ Query ended with: ${resultMsg.subtype}\n`);
|
|
4494
4538
|
}
|
|
4495
4539
|
}
|
|
4496
4540
|
}
|
|
@@ -4498,9 +4542,16 @@ function createNativeClaudeQuery(modelId = DEFAULT_CLAUDE_MODEL_ID, abortControl
|
|
|
4498
4542
|
}
|
|
4499
4543
|
catch (error) {
|
|
4500
4544
|
debugLog$4(`[runner] [native-sdk] ❌ Error: ${error instanceof Error ? error.message : String(error)}\n`);
|
|
4545
|
+
if (agentSpan) {
|
|
4546
|
+
agentSpan.setStatus({ code: 2, message: error instanceof Error ? error.message : String(error) });
|
|
4547
|
+
}
|
|
4501
4548
|
Sentry.captureException(error);
|
|
4502
4549
|
throw error;
|
|
4503
4550
|
}
|
|
4551
|
+
finally {
|
|
4552
|
+
// End the agent span regardless of success/failure
|
|
4553
|
+
agentSpan?.end();
|
|
4554
|
+
}
|
|
4504
4555
|
};
|
|
4505
4556
|
}
|
|
4506
4557
|
|
|
@@ -12971,6 +13022,10 @@ Write a brief, professional summary (1-3 sentences) describing what was accompli
|
|
|
12971
13022
|
logger.setConnected(true);
|
|
12972
13023
|
Sentry.logger.info('Runner connected to server', {
|
|
12973
13024
|
runnerId: RUNNER_ID,
|
|
13025
|
+
version: getPackageVersion(),
|
|
13026
|
+
user: os$1.userInfo().username,
|
|
13027
|
+
hostname: os$1.hostname(),
|
|
13028
|
+
platform: os$1.platform(),
|
|
12974
13029
|
serverUrl: WS_URL,
|
|
12975
13030
|
workspace: WORKSPACE_ROOT,
|
|
12976
13031
|
});
|