Fetch Browser
by TheSethRose
Verified
# Fetch Browser
A powerful headless browser MCP server that enables AI agents to fetch web content and perform Google searches without requiring any API keys. Built with modern web standards and designed for seamless integration with AI platforms.
## Features
- **No API Keys Required**: Uses a sophisticated headless browser approach to fetch content directly
- **Smart Google Search**:
- Extract structured results from Google searches
- Support for both web and news results
- Configurable number of results (1-100)
- Full content fetching of search results
- Automatic retry and error handling
- **Universal Content Fetching**:
- Support for any webpage or API endpoint
- Multiple output formats (HTML, JSON, Text, Markdown)
- Automatic content type detection
- Response size limits and timeout protection
- Rate limiting protection
- **Format Conversion**:
- Clean HTML to Markdown conversion
- Pretty-printed JSON responses
- Structured HTML output
- Plain text with proper formatting
## Tools
### 1. Google Search Tool (`google_search`)
Executes Google searches and fetches full content of results:
```typescript
{
query: "your search query",
responseType: "markdown", // or "json", "html", "text"
maxResults: 10, // 1-100 results
topic: "web" // or "news"
}
```
### 2. URL Fetcher Tool (`fetch_url`)
Fetches content from any URL:
```typescript
{
url: "https://example.com",
responseType: "markdown", // or "json", "html", "text"
timeout: 30000 // optional, in milliseconds
}
```
## Installation
### Via Smithery
```bash
# For Claude
npx -y @smithery/cli install @TheSethRose/fetch-browser --client claude
# For Cursor
npx -y @smithery/cli install @TheSethRose/fetch-browser --client cursor
# For TypeScript
npx -y @smithery/cli install @TheSethRose/fetch-browser --client typescript
```
### Manual Installation
```bash
# Clone the repository
git clone https://github.com/TheSethRose/fetch-browser.git
cd fetch-browser
# Install dependencies
npm install
# Build the project
npm run build
# Start the server
npm start
```
## Development
```bash
# Watch mode with auto-rebuild
npm run watch
# Run with inspector
npm run inspector
# Debug mode
npm run debug
# Debug with watch mode
npm run debug:watch
```
## Response Formats
### 1. Markdown Format
```markdown
## [Page Title](https://example.com)
Content converted to clean markdown with:
- Lists
- **Bold text**
- *Italic text*
- [Links](https://example.com)
```
### 2. JSON Format
```json
{
"url": "https://example.com",
"content": "Extracted content...",
"error": null
}
```
### 3. HTML Format
```html
<div class="search-result">
<h2><a href="https://example.com">Page Title</a></h2>
<div class="content">
Original HTML content
</div>
</div>
```
### 4. Text Format
```text
### https://example.com
Plain text content with preserved formatting
==========
```
## Error Handling
- Automatic retries with exponential backoff
- Rate limiting protection
- Timeout handling
- Detailed error messages
- Individual result error tracking
## Security Features
- Response size limits
- Request timeouts
- Rate limiting protection
- No API keys or secrets required
- Proper error handling
## Credits
**Created by Seth Rose**:
- **Website**: [https://www.sethrose.dev](https://www.sethrose.dev)
- **𝕏 (Twitter)**: [https://x.com/TheSethRose](https://x.com/TheSethRose)
- **🦋 (Bluesky)**: [https://bsky.app/profile/sethrose.dev](https://bsky.app/profile/sethrose.dev)
## License
MIT License - See [LICENSE](LICENSE) for details