* feat(server): add configuration service with file-based persistence - Implement ConfigService for managing application configurations - Add REST API endpoints for quick start configuration - Add comprehensive test coverage for config operations - Define TypeScript types for configuration structures - Replace WebSocket-based config sync with REST API * feat(web): add quick start editor component - Create fully-featured command editor with add, edit, delete functionality - Add drag-and-drop reordering support - Implement real-time validation and error handling - Include comprehensive test coverage (100%) - Support keyboard navigation and accessibility * feat(web): add session status management - Create session status dropdown component for state management - Add session termination capabilities with proper cleanup - Refactor session header to integrate status controls - Support graceful disconnection and reconnection * feat(mac): add directory autocomplete service - Implement AutocompleteService for directory path completion - Create AutocompleteView with native macOS UI - Support home directory expansion (~/) - Add system file browser integration - Optimize performance for large directory structures * feat(mac): add quick start settings interface - Create SwiftUI settings view for managing quick start commands - Implement inline editing with immediate feedback - Add default commands for common workflows - Include toggle for using current directory as default - Add smooth animations and hover effects * feat: integrate quick start in session creation - Add quick start command buttons to session create form - Implement directory picker with autocomplete support - Update form layout for better user experience - Add comprehensive tests for new functionality - Sync quick start integration across web and native * feat(web): add repository discovery to settings - Add repository discovery functionality in unified settings - Update settings UI to support new configuration options - Remove WebSocket-based configuration sync - Simplify settings component with REST API integration * docs: add macOS quick start implementation guide - Document architecture and implementation details - Include code examples and best practices - Explain integration between web and native components - Provide troubleshooting guidance * feat: enhance UI/UX across components - Improve session list with better status indicators - Update terminal binary detection and display - Refine width selector and image upload interactions - Clean up WebSocket control handler - Update server configuration handling - Fix notification status display - Polish settings view layout * feat(web): improve session header UI elements - Position edit icon directly after text instead of far right - Update magic wand icon with sparkles to match macOS design - Change from grid to flex layout for better icon positioning - Enhance visual consistency across platforms * fix(web): improve OPTIONS label alignment in session create form - Add flex-shrink-0 to chevron icon to prevent shrinking - Add leading-none to OPTIONS label for better vertical alignment * docs: update changelog for beta.14 with Quick Start features - Document Quick Start Configuration System (#229, #250, #436) - Add native macOS settings interface details - Include session management improvements - Add bug fixes and breaking changes - Reference related issues and PRs * feat(mac): add ConfigManager for synchronized quick start commands - Create ConfigManager to sync commands with web UI config file - Monitor ~/.vibetunnel/config.json for changes - Replace UserDefaults with file-based configuration - Ensure consistency between Mac app and web interface * feat(mac): add ClickableURLView component - Create reusable component for clickable URLs in SwiftUI - Support for opening URLs in default browser - Consistent styling across the app * refactor(mac): simplify remote access settings UI - Use ClickableURLView for consistent URL display - Reduce code duplication in settings sections - Improve maintainability of remote access views * refactor(mac): integrate ConfigManager in NewSessionForm - Replace direct UserDefaults access with ConfigManager - Use synchronized quick start commands from shared config - Improve command selection UI consistency * fix(web): update terminal padding and termination handling - Remove horizontal padding from terminal containers - Implement proper session termination via DELETE API - Keep vertical padding for better visual appearance - Fix binary mode toggle styling * fix(mac): resolve ConfigManager threading crash - Fix main actor violation in file monitor callback - Remove unsafe self reference in asyncAfter closure - Capture monitor queue reference to avoid accessing self - Ensure all @Published property updates happen on main thread * feat(web): add reset to defaults button in quick start editor - Add Reset to Defaults button for easy restoration - Import DEFAULT_QUICK_START_COMMANDS from config types - Improve user experience with quick command reset option * fix(web): adjust OPTIONS chevron icon size - Reduce chevron icon from 10x10 to 8x8 for better visual balance - Update responsive size classes accordingly - Remove leading-none from OPTIONS label for better alignment * docs: update changelog with latest UI improvements and bug fixes - Document ConfigManager and ClickableURLView additions - Add AutocompleteService and reset to defaults features - Include all UI fixes and threading crash resolution - Document session header and terminal improvements * fix(mac): fix ConfigManager threading crash when moving quick start items - Remove background file monitor queue and use main queue directly - ConfigManager is @MainActor so all operations must happen on main thread - Simplify file monitor callback by removing unnecessary Task wrapper - Fixes crash when reordering quick start commands in settings * feat: add Zod validation for quick start configuration - Add Zod dependency for runtime config validation - Implement ConfigSchema to validate quick start commands - Ensure commands have non-empty strings and valid structure - Add validation on config load and update operations - Fix auth headers for config API endpoints - Remove unused repository path WebSocket handlers - Update storage key for consistency This improves config reliability and prevents invalid commands from being saved. * docs: update changelog with comprehensive beta.14 release notes - Reorganize changelog with clear user-focused sections - Add detailed feature descriptions for Quick Start functionality - Highlight UI/UX improvements with specific examples - Document all bug fixes and stability improvements - Include breaking changes and migration guidance - Add emojis for better visual organization - Expand technical details for developers * fix: handle undefined activityStatus in session categorization Sessions with undefined activityStatus were incorrectly shown as idle. Now only sessions with explicitly false isActive are considered idle. * feat: enhance quick start configuration with repository discovery - Add repository discovery and filtering in AutocompleteService - Support directory-only suggestions for quick start paths - Improve autocomplete filtering to exclude hidden and system directories - Update quick start settings UI with better directory selection - Add tests for vibe-terminal-binary component - Minor UI improvements to clickable URLs and form components * fix: update tests for storage key change and terminal sizing - Update repository-service tests to use new 'app_preferences' storage key - Fix vibe-terminal-binary test to enable fitHorizontally for maxCols constraint - Ensure tests align with recent configuration changes * fix: update failing tests and improve repository status element - Add id="repository-status" to repository counter for easier test selection - Update quick-start-editor test to match actual button classes - Fix all unified-settings tests to use the new repository-status ID - Prevent tests from accidentally selecting unrelated elements * docs: update beta 14 changelog to match earlier style Simplified changelog format to be consistent with beta 13 and earlier versions, making it more concise and easier to read. * feat: add IDs to quick-start-editor elements for better testability - Add id="quick-start-edit-button" to Edit button - Add id="quick-start-save-button" to Save button - Add id="quick-start-cancel-button" to Cancel button - Add id="quick-start-reset-button" to Reset to Defaults button - Add id="quick-start-add-command-button" to Add Command button - Add dynamic IDs for remove buttons: quick-start-remove-command-{index} - Add dynamic IDs for inputs: quick-start-name-input-{index}, quick-start-command-input-{index} - Add dynamic IDs for command items: quick-start-command-item-{index} This makes tests more maintainable by avoiding complex selectors that search by text content. * test: update quick-start-editor tests to use element IDs - Replace button text search with ID selectors for better reliability - Update edit button selector to use #quick-start-edit-button - Update add command button selector to use #quick-start-add-command-button - Update reset button selectors to use #quick-start-reset-button This demonstrates how the new IDs make tests more maintainable and less fragile. * docs: rewrite beta 14 changelog with accurate feature descriptions - Clarify that Quick Start commands became customizable (not new) - Add accurate description of session status management dropdown - Include proper technical details about systemd support - Fix misleading descriptions about features - Maintain concise style consistent with previous releases * fix: remove obsolete tests and fix control-unix-handler tests - Remove obsolete repository-path-sync.test.ts that was testing removed functionality - Remove skipped session-view-drag-drop.test.ts that was causing import errors - Fix control-unix-handler tests to test actual functionality instead of non-existent methods - All tests now passing (1008 passed, 113 skipped) * docs: update beta 14 contributors section - Add Gopi as first-time contributor for ngrok clickable URLs (#422) - Properly credit hewigovens and Claude as co-authors on systemd (#426) - Remove duplicate first-time attribution for hewigovens * docs: fix Claude contributor GitHub link to @claudemini * docs: fix claudemini's contribution attribution - claudemini improved theme toggle UI (PR #429/#438), not systemd - List them as first-time contributor - Keep Claude AI assistant as systemd co-author * docs: remove incorrect AI assistant attribution - There was no AI assistant Claude that co-authored systemd - Keep only the correct contributors: 2 first-time and 1 additional * fix: apply linter fixes for CI - Fix optional chaining in test mock - Fix unused parameters with underscore prefix - Format quick-start-editor test file - Keep any types in test file (acceptable for tests) * fix: remove all any type warnings in tests - Use proper ControlUnixHandler type import - Type vi.importMock with typeof import('net') - Type WebSocket mock with proper import type - All lint warnings now resolved * docs: add image upload feature to changelog - Added image upload menu feature (#432) - Also added theme toggle improvement (#438) that was missing * refactor: add element IDs for improved test maintainability - Added descriptive IDs to interactive elements across components - Updated tests to use ID selectors instead of text-based queries - Enhanced documentation with ID naming best practices - Makes tests more reliable and less brittle to text changes * fix: correct session-list test expectation for hideExited toggle The component emits an event but doesn't directly change its state - the parent handles the state update * docs: add more PR/issue references to beta 14 changelog - Added fixes #368 for theme toggle improvement - Added duplicate reference #421 for Chinese input issue #431 - All PR and issue references now properly documented * fix: SwiftFormat modifier order and SystemControlHandler test race condition * fix: repository scanner not showing discovered repositories - Fixed storage key mismatch between 'app_preferences' and 'vibetunnel_app_preferences' - Added missing authClient prop to unified-settings component in app.ts - Updated all test files to use the correct storage key - Repository scanner now correctly displays discovered repositories count * refactor: extract session termination logic into reusable helper - Create session-actions.ts utility for common session operations - Refactor handleTerminateSession to use the new helper - Fix handleClearSession to properly delete exited sessions before navigation - Move Git branch indicator to header next to path in file browser - Fix Options label alignment in session create form * refactor: migrate repository base path from CLI arg to config.json - Remove --repository-base-path command line argument - Add repositoryBasePath to VibeTunnelConfig type and schema - Update server to read/write repository path from config.json - Refactor client to use ServerConfigService for repository path - Update settings UI to manage path through server config API - Ensure consistent naming with macOS app implementation This simplifies configuration by using config.json as the single source of truth for repository base path, with automatic file watching for real-time updates. * docs: remove --repository-base-path from README This option was removed in the previous commit as repository base path is now configured via config.json instead of command line arguments. * fix: reduce Logs button border contrast and add comprehensive drag & drop tests - Changed border opacity from 100% to 30% for softer appearance - Created drag & drop tests with 21 passing tests covering: - Drag over/leave functionality - Drop handling for single and multiple files - Paste functionality with various UI states - Error handling and edge cases - Fixed TypeScript lint errors in test files - Disabled 2 visual overlay tests due to shadow DOM limitations in test environment * fix: auto-format session-action-service.ts to pass CI checks * fix: update tests to match refactored session action service implementation - Fixed repository service tests by adding mock serverConfigService - Updated session-card tests to expect DELETE endpoint instead of /cleanup - Corrected error message expectations in session-card tests - Fixed quick-start-editor test button class expectations - Auto-formatted all files to pass CI checks * fix: update session-action-service tests with proper mocks and window handling - Added @vitest-environment happy-dom directive for DOM testing - Set up proper mock for terminateSession to return success: true - Mock window.dispatchEvent to prevent errors in test environment - Fixed all test expectations to match refactored implementation * fix: update server config tests to match refactored API implementation - Updated config route tests to match new implementation that always returns serverConfigured: true - Fixed error messages to match 'No valid updates provided' instead of 'Invalid quick start commands' - Removed dependency on getRepositoryBasePath function, now using configService.repositoryBasePath - Added tests for repository base path updates via PUT /api/config - Added test for updating both repository path and quick start commands together * fix: resolve remaining CI issues with type assertions and import ordering * fix: update remaining tests and clean up imports - Fix repository service test to include serverConfigService - Update session card test error expectations - Fix quick start editor button class tests - Add proper mock setup for session action service - Update server config tests for refactored API - Clean up type assertions and import ordering * fix: correct undefined runningSessions variable reference in Kill All button The Kill All button was referencing a non-existent runningSessions variable after refactoring split it into activeSessions and idleSessions. Fixed by using the locally defined runningSessions variable in renderExitedControls() method. * fix: improve Quick Start settings UI styling - Use tertiaryLabelColor for better visual hierarchy - Adjust opacity values for improved contrast - Remove redundant "Quick Start" header * fix: ensure thread safety in SystemControlHandlerTests - Wrap notification flag updates in MainActor tasks - Ensure test assertions run on MainActor - Fixes potential race conditions in async tests * fix: correct SwiftFormat modifier order in VibeTunnelApp - Change 'weak static' to 'static weak' to match SwiftFormat rules - Fixes CI linting failure * fix: resolve Swift 6 concurrency errors in SystemControlHandlerTests - Wrap MainActor property mutations in Task blocks for notification observers - Fix test expectations to match actual path handling behavior - SystemControlHandler stores paths as-is without tilde conversion The CI failures were due to Swift 6's stricter concurrency checking which prevented mutating MainActor-isolated properties from Sendable closures. Also corrected the test expectation - the handler doesn't convert paths to tilde notation, that only happens in UI components. * fix: revert to correct SwiftFormat modifier order - SwiftFormat expects 'weak static', not 'static weak' - Fixes CI formatting check failure * chore: trigger CI rebuild * fix: resolve remaining CI issues with type assertions and import ordering - Disable AppleScript tests on CI environment (not available in headless mode) - Make SystemControlHandlerTests more robust with proper synchronization - Add better error messages for test failures - Fix exit code 126 issues by handling server startup failures gracefully * Remove repository base path CLI argument from BunServer - Server now reads repository base path directly from config.json - Updated NewSessionForm to use ConfigManager for repository path - Updated GeneralSettingsView to use ConfigManager instead of @AppStorage - Updated ProjectFolderPageView to use ConfigManager - Removed --repository-base-path CLI argument from BunServer - RepositoryPathSyncService already updated to use ConfigManager * Update tests to use ConfigManager and add CI diagnostics - Updated RepositoryPathSyncServiceTests to use ConfigManager instead of UserDefaults - Added diagnostic logging in BunServer for CI debugging when binary is not found - Updated GitHub Actions workflows * fix: simplify Mac CI by removing web artifact caching - Remove web artifact download/upload between Node.js and Mac CI workflows - Mac CI now builds web components directly via Xcode build process - Eliminates file permission issues with artifact transfers - Workflows can now run in parallel for faster CI - Add better diagnostics for missing binary errors in BunServer * fix: make tests properly fail when server binary is not available - Update ServerManagerTests to require server binary presence - Tests now fail with clear error if vibetunnel binary is missing - Remove fallback logic that allowed tests to pass without binary - ServerBinaryAvailableCondition now only checks app Resources folder The server binary must be properly embedded in the Mac app's Resources folder. Tests should not pass if the binary is missing, as this would indicate a broken build. * Refactor code to reduce duplication and improve structure - Use AppConstants.getPreferredGitApp() instead of direct UserDefaults access - Add getDashboardAccessMode() and setDashboardAccessMode() helpers to AppConstants - Create GitAppHelper utility to centralize Git app preference logic - Simplify GitRepositoryRow and SessionRow to use GitAppHelper - Keep ConfigManager focused on server-needed config (quickStartCommands, repositoryBasePath) - Mac-specific settings remain in UserDefaults with improved access patterns * Move configuration enums to shared location - Create ConfigurationEnums.swift with AuthenticationMode and TitleMode - Remove duplicate enum definitions from UI files - Fix ConfigManager to use correct enum case names (.osAuth instead of .os) - Add description property to AuthenticationMode for UI display - Proper separation of shared types from UI-specific code
8.8 KiB
VibeTunnel CLI
Turn any browser into your terminal. VibeTunnel proxies your terminals right into the browser, so you can vibe-code anywhere.
Full-featured terminal sharing server with web interface for macOS and Linux. Windows not yet supported.
Why VibeTunnel?
Ever wanted to check on your AI agents while you're away? Need to monitor that long-running build from your phone? Want to share a terminal session with a colleague without complex SSH setups? VibeTunnel makes it happen with zero friction.
Installation
From npm (Recommended)
npm install -g vibetunnel
From Source
git clone https://github.com/amantus-ai/vibetunnel.git
cd vibetunnel/web
pnpm install
pnpm run build
Installation Differences
npm package:
- Pre-built binaries for common platforms (macOS x64/arm64, Linux x64/arm64)
- Automatic fallback to source compilation if pre-built binaries unavailable
- Global installation makes
vibetunnelcommand available system-wide - Conditional
vtcommand installation (see VT Installation Guide) - Includes production dependencies only
Source installation:
- Full development environment with hot reload (
pnpm run dev) - Access to all development scripts and tools
- Ability to modify and rebuild the application
- Includes test suites and development dependencies
Requirements
- Node.js >= 20.0.0
- macOS or Linux (Windows not yet supported)
- Build tools for native modules (Xcode on macOS, build-essential on Linux)
Usage
Start the server
# Start with default settings (port 4020)
vibetunnel
# Start with custom port
vibetunnel --port 8080
# Start without authentication
vibetunnel --no-auth
# Bind to specific interface
vibetunnel --bind 127.0.0.1 --port 4020
# Enable SSH key authentication
vibetunnel --enable-ssh-keys
# SSH keys only (no password auth)
vibetunnel --disallow-user-password
Then open http://localhost:4020 in your browser to access the web interface.
Command-line Options
vibetunnel [options]
Basic Options:
--help, -h Show help message
--version, -v Show version information
--port <number> Server port (default: 4020 or PORT env var)
--bind <address> Bind address (default: 0.0.0.0, all interfaces)
Authentication Options:
--no-auth Disable authentication (auto-login as current user)
--enable-ssh-keys Enable SSH key authentication UI and functionality
--disallow-user-password Disable password auth, SSH keys only (auto-enables --enable-ssh-keys)
--allow-local-bypass Allow localhost connections to bypass authentication
--local-auth-token <token> Token for localhost authentication bypass
Push Notification Options:
--push-enabled Enable push notifications (default: enabled)
--push-disabled Disable push notifications
--vapid-email <email> Contact email for VAPID configuration
--generate-vapid-keys Generate new VAPID keys if none exist
Network Discovery Options:
--no-mdns Disable mDNS/Bonjour advertisement (enabled by default)
HQ Mode Options:
--hq Run as HQ (headquarters) server
--no-hq-auth Disable HQ authentication
Remote Server Options:
--hq-url <url> HQ server URL to register with
--hq-username <user> Username for HQ authentication
--hq-password <pass> Password for HQ authentication
--name <name> Unique name for remote server
--allow-insecure-hq Allow HTTP URLs for HQ (not recommended)
Debugging:
--debug Enable debug logging
Use the vt command wrapper
The vt command allows you to run commands with TTY forwarding:
# Monitor AI agents with automatic activity tracking
vt claude
vt claude --dangerously-skip-permissions
# Run commands with output visible in VibeTunnel
vt npm test
vt python script.py
vt top
# Launch interactive shell
vt --shell
vt -i
# Update session title (inside a session)
vt title "My Project"
# Execute command directly without shell wrapper
vt --no-shell-wrap ls -la
vt -S ls -la
# Control terminal title behavior
vt --title-mode none # No title management
vt --title-mode filter # Block all title changes
vt --title-mode static # Show directory and command
vt --title-mode dynamic # Show directory, command, and activity
# Verbosity control
vt -q npm test # Quiet mode (errors only)
vt -v npm run dev # Verbose mode
vt -vv npm test # Extra verbose
vt -vvv npm build # Debug mode
Forward commands to a session
# Basic usage
vibetunnel fwd <session-id> <command> [args...]
# Examples
vibetunnel fwd --session-id abc123 ls -la
vibetunnel fwd --session-id abc123 npm test
vibetunnel fwd --session-id abc123 python script.py
Linux users can install VibeTunnel as a systemd service with vibetunnel systemd for automatic startup and process management - see detailed systemd documentation.
Environment Variables
VibeTunnel respects the following environment variables:
PORT=8080 # Default port if --port not specified
VIBETUNNEL_USERNAME=myuser # Username (for env-based auth, not CLI)
VIBETUNNEL_PASSWORD=mypass # Password (for env-based auth, not CLI)
VIBETUNNEL_CONTROL_DIR=/path # Control directory for session data
VIBETUNNEL_SESSION_ID=abc123 # Current session ID (set automatically inside sessions)
VIBETUNNEL_LOG_LEVEL=debug # Log level: error, warn, info, verbose, debug
PUSH_CONTACT_EMAIL=admin@example.com # Contact email for VAPID configuration
Features
- Web-based terminal interface - Access terminals from any browser
- Multiple concurrent sessions - Run multiple terminals simultaneously
- Real-time synchronization - See output in real-time
- TTY forwarding - Full terminal emulation support
- Session management - Create, list, and manage sessions
- Cross-platform - Works on macOS and Linux
- No dependencies - Just Node.js required
Package Contents
This npm package includes:
- Full VibeTunnel server with web UI
- Command-line tools (vibetunnel, vt)
- Native PTY support for terminal emulation
- Web interface with xterm.js
- Session management and forwarding
- Built-in systemd service management for Linux
Platform Support
- macOS (Intel and Apple Silicon)
- Linux (x64 and ARM64)
- Windows: Not yet supported (#252)
Troubleshooting
Installation Issues
If you encounter issues during installation:
-
Missing Build Tools: Install build essentials
# Ubuntu/Debian sudo apt-get install build-essential python3-dev # macOS xcode-select --install -
Permission Issues: Use sudo for global installation
sudo npm install -g vibetunnel -
Node Version: Ensure Node.js 20+ is installed
node --version
Runtime Issues
- Server Won't Start: Check if port is already in use
- Authentication Failed: Verify system authentication setup
- Terminal Not Responsive: Check browser console for WebSocket errors
SSH Key Authentication Issues
If you encounter errors when generating or importing SSH keys (e.g., "Cannot read properties of undefined"), this is due to browser security restrictions on the Web Crypto API.
The Issue
Modern browsers (Chrome 60+, Firefox 75+) block the Web Crypto API when accessing web applications over HTTP from non-localhost addresses. This affects:
- Local network IPs (192.168.x.x, 10.x.x.x, 172.16-31.x.x)
- Any non-localhost hostname over HTTP
Solutions
-
Use localhost (Recommended)
# Access VibeTunnel via localhost http://localhost:4020 # If running on a remote server, use SSH tunneling: ssh -L 4020:localhost:4020 user@your-server # Then access http://localhost:4020 in your browser -
Enable HTTPS Set up a reverse proxy with HTTPS using nginx or Caddy (recommended for production).
-
Chrome Flag Workaround (Development only)
- Navigate to
chrome://flags/#unsafely-treat-insecure-origin-as-secure - Add your server URL (e.g.,
http://192.168.1.100:4020) - Enable the flag and restart Chrome
- ⚠️ This reduces security - use only for development
- Navigate to
Why This Happens
The Web Crypto API is restricted to secure contexts (HTTPS or localhost) to prevent man-in-the-middle attacks on cryptographic operations. This is a browser security feature, not a VibeTunnel limitation.
Development Setup
For source installations:
# Install dependencies
pnpm install
# Run development server with hot reload
pnpm run dev
# Run code quality checks
pnpm run check
# Build for production
pnpm run build
Documentation
See the main repository for complete documentation: https://github.com/amantus-ai/vibetunnel
License
MIT