Skip to main content
Glama

LCBro

by lcbro

LCBro

Low Cost Browser Remote Operations

The Cool Browser Automation MCP Server ๐Ÿ”ฅ

npm version License: MIT Node.js Version

CI/CD Pipeline Docker Testing Release Nightly Tests

โšก Lightning Fast โ€ข ๐ŸŽฏ Zero Config โ€ข ๐Ÿš€ Production Ready

LCBro is a powerful MCP server for browser automation with support for both Playwright and Chrome DevTools Protocol (CDP). It provides intelligent preprocessing, comprehensive logging, and remote browser management capabilities.

๐ŸŽฏ Cost Optimization Focus: This project is specifically designed to optimize LLM request costs and reduce context usage by intelligently preprocessing and cleaning data using local LLM models before sending to expensive main LLM APIs. This approach can reduce costs by up to 80% while improving result quality.

โœจ Features

๐ŸŽฏ Browser Automation

  • Real browser control with JavaScript execution

  • Login flows, clicks, text input, form handling

  • Screenshot capture and content extraction

  • Session management with persistent contexts

๐Ÿค– Intelligent Preprocessing

  • Auto-generates preprocessing prompts

  • Local LLM integration (Ollama, JAN)

  • Smart content analysis and optimization

  • Cost-efficient data preparation

๐Ÿ”ง Multiple Engines

  • Playwright: Full-featured automation

  • CDP: Chrome DevTools Protocol support

  • Remote browser connections

  • Auto-detection and fallback

๐Ÿ“Š Advanced Logging

  • Comprehensive LLM interaction logs

  • Performance metrics and token tracking

  • Configurable log rotation and compression

  • Debug and monitoring capabilities

๐Ÿš€ Quick Start

Use with npx (Recommended - No Installation)

# Use directly without installation npx lcbro # With custom configuration npx lcbro --config /path/to/config.yaml --port 3000

Global Installation

# Install globally via npm npm install -g lcbro # Start the server lcbro

Local Development

# Clone and install git clone https://github.com/lcbro/lcbro.git cd lcbro npm install npm run build npm start

Docker

# Run with Docker docker run -p 3000:3000 lcbro:latest

๐Ÿ’ก Usage Examples

Basic Browser Automation

# Navigate and extract content npx lcbro navigate --url "https://example.com" npx lcbro extract --format text

With Custom Configuration

# Enable CDP support npx lcbro --cdp-enabled --port 3001 # Custom logging directory npx lcbro --logs-dir "/custom/logs" --log-level debug

MCP Client Integration

{ "mcpServers": { "lcbro": { "command": "npx", "args": ["-y", "lcbro"] } } }

๐Ÿ“‹ Installation

Prerequisites

  • Node.js 18+

  • npm or yarn

  • Chrome/Chromium browser (for CDP support)

Global Installation (Recommended)

# Install globally npm install -g lcbro # Verify installation lcbro --version

Local Development

# Clone repository git clone https://github.com/lcbro/lcbro.git cd lcbro # Install dependencies npm install # Build project npm run build # Install Playwright browsers npm run install:browsers

โš™๏ธ Configuration

LCBro uses YAML configuration files with CLI overrides. Create a config/default.yaml file or use CLI options:

Basic Configuration

server: host: "localhost" port: 3000 browser: engine: playwright # playwright | cdp headless: true defaultTimeoutMs: 30000 maxContexts: 8 storageDir: /data/profiles llm: defaultModel: "ollama:llama3.1" maxOutputTokens: 2000 temperature: 0 host: "localhost" port: 11434 janPort: 1337 autoPreprocess: true security: allowDomains: ["example.com", "gov.br"] blockPrivateNetworks: true

CLI Configuration Overrides

# Server settings lcbro --port 3001 --host 0.0.0.0 # CDP browser support lcbro --cdp-enabled --cdp-port 9222 # Remote CDP server lcbro --remote-url https://cdp.example.com:9222 --remote-ssl-mode enabled # Logging configuration lcbro --log-level debug --logs-dir /tmp/lcbro-logs

๐Ÿ–ฅ๏ธ CLI Usage

LCBro provides a comprehensive command-line interface:

Main Commands

# Start the server lcbro # Show help lcbro --help # Show current configuration lcbro config # Launch browsers with CDP lcbro browser:launch -b chrome -p 9222 # Manage log files lcbro logs --command summary # Test remote CDP connection lcbro test:remote -u https://cdp.example.com:9222

๐Ÿ”ง Environment Variables

LCBro supports configuration via environment variables:

LLM Configuration

# Local LLMs (Recommended) #### Ollama (free, no API keys required) ```bash # Install Ollama curl -fsSL https://ollama.ai/install.sh | sh # Pull a model ollama pull llama3.1 # Configure LCBro export LLM_HOST=localhost export LLM_PORT=11434 export LLM_DEFAULT_MODEL=ollama:llama3.1

JAN AI (free, with optional API key)

# Configure LCBro for JAN AI export LLM_HOST=localhost export LLM_JAN_PORT=1337 export LLM_DEFAULT_MODEL=jan:llama-3.1-8b

External LLM APIs (Optional)

# OpenAI export OPENAI_API_KEY=your_api_key_here # Anthropic export ANTHROPIC_API_KEY=your_api_key_here

CDP Browser Configuration

# Enable CDP support export BROWSER_ENGINE=cdp # CDP server settings export CDP_HOST=localhost export CDP_PORT=9222 # Remote CDP server export CDP_REMOTE_URL=https://cdp.example.com:9222 export CDP_REMOTE_SSL_MODE=enabled export CDP_REMOTE_API_KEY=your_api_key ## ๐Ÿš€ Usage ### Starting the Server ```bash # Start with default configuration lcbro # Start with specific port lcbro --port 3001 # Start with CDP support lcbro --cdp-enabled # Start with custom config file lcbro --config /path/to/config.yaml

MCP Client Integration

# Claude Desktop configuration # Add to ~/.claude/claude_desktop_config.json: { "mcpServers": { "lcbro": { "command": "npx", "args": ["-y", "lcbro"] } } } # Cursor IDE configuration # Add to ~/.cursor/mcp.json: { "mcpServers": { "lcbro": { "command": "npx", "args": ["-y", "lcbro"] } } } # With CDP support { "mcpServers": { "lcbro": { "command": "npx", "args": ["-y", "lcbro", "--cdp-enabled"] } } } # With custom configuration { "mcpServers": { "lcbro": { "command": "npx", "args": ["-y", "lcbro", "--config", "/path/to/config.yaml"] } } } ## ๐Ÿ› ๏ธ Advanced Features ### Intelligent Preprocessing LCBro automatically cleans and optimizes data before sending to LLMs: ```bash # Enable intelligent preprocessing lcbro --auto-preprocess # Configure preprocessing thresholds lcbro --preprocessing-threshold-html 5000 lcbro --preprocessing-threshold-text 8000

CDP Browser Management

# Launch browsers with CDP lcbro browser:launch -b chrome -p 9222 -n 3 # Connect to remote CDP server lcbro --remote-url https://cdp.example.com:9222 # Test remote connection lcbro test:remote -u https://cdp.example.com:9222

Log Management

# View log summary lcbro logs --command summary # Clean old logs lcbro logs --command cleanup --age 30 # Compress log files lcbro logs --command compress

๐Ÿ“š Documentation

๐ŸŽฏ MCP Tools Available

LCBro provides the following MCP tools:

Navigation Tools

  • navigate_open - Open a new URL in a browser context

  • navigate_goto - Navigate to a URL in an existing context

Interaction Tools

  • interact_click - Click on elements by selector, text, or role

  • interact_type - Type text into input fields

  • interact_wait - Wait for conditions (selector, network idle, URL change)

Extraction Tools

  • extract_content - Extract page content in various formats

  • extract_table - Extract table data as JSON

  • extract_attributes - Extract attributes from elements

  • extract_screenshot - Take screenshots of pages or elements

Session Tools

  • session_auth - Perform authentication sequences

  • session_manage - Manage browser sessions and contexts

LLM Tools

  • llm_transform - Transform data using LLM with custom instructions

  • llm_analyze - Analyze content with LLM preprocessing

๐Ÿ† Project Status

โœ… Production Ready - All features implemented and tested
โœ… npm Package Ready - Can be installed globally via npm
โœ… CLI Interface - Full command-line interface available
โœ… Documentation - Comprehensive documentation provided
โœ… Multi-language Support - English, Russian, Portuguese
โœ… Zero Breaking Changes - All original functionality preserved
โœ… Continuous Integration - Automated testing and deployment
โœ… Docker Support - Multi-stage builds and container testing
โœ… Security Scanning - Automated vulnerability detection

๐Ÿš€ Quick Start

Option 1: Use with npx (Recommended - No Installation Required)

# Use directly without installation npx lcbro --help # Start server npx lcbro # With CDP support npx lcbro --cdp-enabled

Option 2: Global Installation

# Install globally npm install -g lcbro # Verify installation lcbro --version # Start server lcbro

Configure MCP Client

// Claude Desktop: ~/.claude/claude_desktop_config.json { "mcpServers": { "lcbro": { "command": "npx", "args": ["-y", "lcbro"] } } } // Cursor IDE: ~/.cursor/mcp.json { "mcpServers": { "lcbro": { "command": "npx", "args": ["-y", "lcbro"] } } }

๐Ÿ“Š Performance & Specifications

  • Package Size: 147.7 kB compressed, 759.7 kB unpacked

  • Startup Time: < 2 seconds

  • Memory Usage: < 100 MB typical

  • Concurrent Sessions: Up to 8 browser contexts

  • Supported Browsers: Chrome, Chromium, Edge (CDP), Playwright browsers

  • Node.js: 18.x, 20.x, 22.x

  • Operating Systems: Windows, macOS, Linux

๐Ÿ”ง CI/CD Pipeline Status

Automated Testing & Deployment ๐Ÿš€

Pipeline

Status

Description

CI/CD

CI/CD Pipeline

Main build, test, and deployment pipeline

Docker

Docker Testing

Container builds and multi-platform testing

Release

Release

Automated release and npm publishing

Nightly

Nightly Tests

Extended tests and performance benchmarks

๐Ÿ“Š Quality Metrics

  • Test Coverage: >80% (Unit + E2E)

  • Build Time: ~3-5 minutes

  • Docker Build: Multi-stage with layer caching

  • Security: CodeQL analysis + dependency scanning

๐Ÿ“‹ View all workflows โ†’ | ๐Ÿš€ View pipeline runs โ†’

๐Ÿ› ๏ธ Development

Prerequisites

npm install npm run install:browsers

Build & Test

# Build the project npm run build # Run tests npm test # Run E2E tests npm run test:e2e # Run CI pipeline locally make ci

๐Ÿ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿค Contributing

  1. Fork the repository

  2. Create a feature branch (git checkout -b feature/amazing-feature)

  3. Commit your changes (git commit -m 'Add amazing feature')

  4. Push to the branch (git push origin feature/amazing-feature)

  5. Open a Pull Request

๐Ÿ“ž Support & Community

GitHub Issues GitHub Stars GitHub Forks

๐Ÿ™ Acknowledgments

  • Playwright - Browser automation framework

  • Chrome DevTools Protocol - Remote browser debugging

  • MCP SDK - Model Context Protocol framework

  • Claude Desktop - MCP client integration

  • Cursor IDE - Development environment


Made with โค๏ธ by the LCBro Team

LCBro - Low Cost Browser Remote Operations
Version: 1.0.10 โ€ข Status: โœ… Production Ready โ€ข License: MIT

โฌ† Back to Top

-
security - not tested
F
license - not found
-
quality - not tested

hybrid server

The server is able to function both locally and remotely, depending on the configuration or use case.

A powerful MCP server for browser automation that supports both Playwright and Chrome DevTools Protocol (CDP) with intelligent preprocessing, comprehensive logging, and remote browser management capabilities. Enables users to perform web automation tasks like navigation, content extraction, form interactions, and screenshot capture through natural language.

  1. Low Cost Browser Remote Operations
    1. โœจ Features
      1. ๐ŸŽฏ Browser Automation
      2. ๐Ÿค– Intelligent Preprocessing
      3. ๐Ÿ”ง Multiple Engines
      4. ๐Ÿ“Š Advanced Logging
    2. ๐Ÿš€ Quick Start
      1. Use with npx (Recommended - No Installation)
      2. Global Installation
      3. Local Development
      4. Docker
    3. ๐Ÿ’ก Usage Examples
      1. Basic Browser Automation
      2. With Custom Configuration
      3. MCP Client Integration
    4. ๐Ÿ“‹ Installation
      1. Prerequisites
      2. Global Installation (Recommended)
      3. Local Development
    5. โš™๏ธ Configuration
      1. Basic Configuration
      2. CLI Configuration Overrides
    6. ๐Ÿ–ฅ๏ธ CLI Usage
      1. Main Commands
    7. ๐Ÿ”ง Environment Variables
      1. LLM Configuration
      2. External LLM APIs (Optional)
      3. CDP Browser Configuration
      4. MCP Client Integration
      5. CDP Browser Management
      6. Log Management
    8. ๐Ÿ“š Documentation
      1. ๐ŸŽฏ MCP Tools Available
        1. Navigation Tools
        2. Interaction Tools
        3. Extraction Tools
        4. Session Tools
        5. LLM Tools
      2. ๐Ÿ† Project Status
        1. ๐Ÿš€ Quick Start
          1. Option 1: Use with npx (Recommended - No Installation Required)
          2. Option 2: Global Installation
          3. Configure MCP Client
        2. ๐Ÿ“Š Performance & Specifications
          1. ๐Ÿ”ง CI/CD Pipeline Status
            1. ๐Ÿ“Š Quality Metrics
          2. ๐Ÿ› ๏ธ Development
            1. Prerequisites
            2. Build & Test
          3. ๐Ÿ“„ License
            1. ๐Ÿค Contributing
              1. ๐Ÿ“ž Support & Community
                1. ๐Ÿ™ Acknowledgments

                  MCP directory API

                  We provide all the information about MCP servers via our MCP API.

                  curl -X GET 'https://glama.ai/api/mcp/v1/servers/lcbro/lcbro-mcp'

                  If you have feedback or need assistance with the MCP directory API, please join our Discord server