mirror of
https://github.com/leonvanzyl/autocoder.git
synced 2026-03-17 10:53:09 +00:00
Major changes across 21 files (755 additions, 196 deletions): Browser Automation Migration: - Add versioned project migration system (prompts.py) with content-based detection and section-level regex replacement for coding/testing prompts - Migrate STEP 5 (browser verification) and BROWSER AUTOMATION sections in coding prompt template to use playwright-cli commands - Migrate STEP 2 and AVAILABLE TOOLS sections in testing prompt template - Migration auto-runs at agent startup (autonomous_agent_demo.py), copies playwright-cli skill, scaffolds .playwright/cli.config.json, updates .gitignore, and stamps .migration_version file - Add playwright-cli command validation to security allowlist (security.py) with tests for allowed subcommands and blocked eval/run-code Headless Browser Setting Fix: - Add _apply_playwright_headless() to process_manager.py that reads/updates .playwright/cli.config.json before agent subprocess launch - Remove dead PLAYWRIGHT_HEADLESS env var that was never consumed - Settings UI toggle now correctly controls visible browser window Playwright CLI Auto-Install: - Add ensurePlaywrightCli() to lib/cli.js for npm global entry point - Add playwright-cli detection + npm install to start.bat, start.sh, start_ui.bat, start_ui.sh for all startup paths Other Improvements: - Add project folder path tooltip to ProjectSelector.tsx dropdown items - Remove legacy Playwright MCP server configuration from client.py - Update CLAUDE.md with playwright-cli skill documentation Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
88 lines
2.7 KiB
Bash
Executable File
88 lines
2.7 KiB
Bash
Executable File
#!/bin/bash
|
|
cd "$(dirname "$0")"
|
|
|
|
echo ""
|
|
echo "========================================"
|
|
echo " AutoForge - Autonomous Coding Agent"
|
|
echo "========================================"
|
|
echo ""
|
|
|
|
# Check if Claude CLI is installed
|
|
if ! command -v claude &> /dev/null; then
|
|
echo "[ERROR] Claude CLI not found"
|
|
echo ""
|
|
echo "Please install Claude CLI first:"
|
|
echo " curl -fsSL https://claude.ai/install.sh | bash"
|
|
echo ""
|
|
echo "Then run this script again."
|
|
exit 1
|
|
fi
|
|
|
|
echo "[OK] Claude CLI found"
|
|
|
|
# Note: Claude CLI no longer stores credentials in ~/.claude/.credentials.json
|
|
# We can't reliably check auth status without making an API call, so we just
|
|
# verify the CLI is installed and remind the user to login if needed
|
|
if [ -d "$HOME/.claude" ]; then
|
|
echo "[OK] Claude CLI directory found"
|
|
echo " (If you're not logged in, run: claude login)"
|
|
else
|
|
echo "[!] Claude CLI not configured"
|
|
echo ""
|
|
echo "Please run 'claude login' to authenticate before continuing."
|
|
echo ""
|
|
read -p "Press Enter to continue anyway, or Ctrl+C to exit..."
|
|
fi
|
|
|
|
echo ""
|
|
|
|
# Check if venv exists with correct structure for this platform
|
|
# Windows venvs have Scripts/, Linux/macOS have bin/
|
|
if [ ! -f "venv/bin/activate" ]; then
|
|
if [ -d "venv" ]; then
|
|
echo "[INFO] Detected incompatible virtual environment (possibly created on Windows)"
|
|
echo "[INFO] Recreating virtual environment for this platform..."
|
|
rm -rf venv
|
|
if [ -d "venv" ]; then
|
|
echo "[ERROR] Failed to remove existing virtual environment"
|
|
echo "Please manually delete the 'venv' directory and try again:"
|
|
echo " rm -rf venv"
|
|
exit 1
|
|
fi
|
|
else
|
|
echo "Creating virtual environment..."
|
|
fi
|
|
python3 -m venv venv
|
|
if [ $? -ne 0 ]; then
|
|
echo "[ERROR] Failed to create virtual environment"
|
|
echo "Please ensure the venv module is installed:"
|
|
echo " Ubuntu/Debian: sudo apt install python3-venv"
|
|
echo " Or try: python3 -m ensurepip"
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
# Activate the virtual environment
|
|
source venv/bin/activate
|
|
if [ $? -ne 0 ]; then
|
|
echo "[ERROR] Failed to activate virtual environment"
|
|
echo "The venv may be corrupted. Try: rm -rf venv && ./start.sh"
|
|
exit 1
|
|
fi
|
|
|
|
# Install dependencies
|
|
echo "Installing dependencies..."
|
|
pip install -r requirements.txt --quiet
|
|
|
|
# Ensure playwright-cli is available for browser automation
|
|
if ! command -v playwright-cli &> /dev/null; then
|
|
echo "Installing playwright-cli for browser automation..."
|
|
npm install -g @playwright/cli --quiet 2>/dev/null
|
|
if [ $? -ne 0 ]; then
|
|
echo "Note: Could not install playwright-cli. Install manually: npm install -g @playwright/cli"
|
|
fi
|
|
fi
|
|
|
|
# Run the app
|
|
python start.py
|