Gopher & Gemini MCP Server

Gopher & Gemini MCP Server

A modern Model Context Protocol server for AI-driven exploration of Gopher and Gemini resources.

4
Stars
1
Forks
4
Watchers
7
Issues
Gopher & Gemini MCP Server provides a secure and efficient bridge for AI assistants to interact with resources on vintage Gopher and modern Gemini protocols using the Model Context Protocol (MCP) standard. It is built with FastMCP, delivers structured JSON responses optimized for LLMs, and supports comprehensive protocol coverage with advanced security and performance features. The server implements robust safeguards, certificate validation, and works cross-platform with modern Python tooling.

Key Features

Supports both Gopher and Gemini protocols
LLM-optimized structured JSON responses
TOFU and client certificate validation for enhanced security
Built on FastMCP with async/await performance
Comprehensive protocol coverage including text, menus, search, and binary files
Cross-platform compatibility (Windows, macOS, Linux)
Native gemtext parsing and Gemini status code handling
Built-in safety mechanisms: timeouts, size limits, input sanitization, host allowlists
Modern development stack: type checking, linting, CI/CD
Intelligent response caching for efficiency

Use Cases

Allow AI assistants to browse legacy Gopher and new Gemini content securely
Enable LLMs to retrieve and process alternative internet resources
Serve as a safe and efficient backend for AI-powered web browsers
Facilitate exploration of text and binary files from specialized internet spaces
Provide developers with a gateway for AI context enrichment from unique protocol sources
Integrate advanced certificate security in AI-driven data pipelines
Support AI research on alternative information networks
Deliver structured content to downstream AI tools or applications
Prototype novel context-aware AI assistants accessing vintage internet
Bridge non-HTTP protocols to modern AI workflows

README

Gopher & Gemini MCP Server

CI Documentation PyPI version Python 3.11+ License: MIT codecov Code style: ruff Checked with mypy Downloads

A modern, cross-platform Model Context Protocol (MCP) server that enables AI assistants to browse and interact with both Gopher protocol and Gemini protocol resources safely and efficiently.

🌟 Overview

The Gopher & Gemini MCP Server bridges vintage and modern alternative internet protocols with AI assistants, allowing LLMs like Claude to explore the unique content and communities that thrive on both Gopherspace and Geminispace. Built with FastMCP and modern Python practices, it provides secure, efficient gateways to these distinctive internet protocols.

Key Benefits:

  • πŸ” Discover alternative internet content - Access unique resources on both Gopher and Gemini protocols
  • πŸ›‘οΈ Safe exploration - Built-in security safeguards, TLS encryption, and content filtering
  • πŸš€ Modern implementation - Uses FastMCP framework with async/await patterns
  • πŸ”§ Developer-friendly - Comprehensive testing, type hints, and documentation
  • πŸ” Advanced security - TOFU certificate validation and client certificate support for Gemini

✨ Features

  • πŸ”§ Dual Protocol Support: gopher_fetch and gemini_fetch tools for comprehensive protocol coverage
  • πŸ“‹ Comprehensive Gopher Support: Handles menus (type 1), text files (type 0), search servers (type 7), and binary files
  • 🌐 Full Gemini Implementation: Native gemtext parsing, TLS security, and status code handling
  • πŸ” Advanced Security: TOFU certificate validation, client certificates, and secure TLS connections
  • πŸ›‘οΈ Safety First: Built-in timeouts, size limits, input sanitization, and host allowlists
  • πŸ€– LLM-Optimized: Returns structured JSON responses designed for AI consumption
  • πŸ–₯️ Cross-Platform: Works seamlessly on Windows, macOS, and Linux
  • πŸ”¬ Modern Development: Full type checking, linting, testing, and CI/CD pipeline
  • ⚑ High Performance: Async/await patterns with intelligent caching

πŸ“š Documentation

Complete documentation is available at cameronrye.github.io/gopher-mcp

πŸš€ Quick Start

πŸ“‹ Prerequisites

πŸ“¦ Installation

Option 1: Development Installation (Recommended)

bash
# Clone the repository
git clone https://github.com/cameronrye/gopher-mcp.git
cd gopher-mcp

# Set up development environment
./scripts/dev-setup.sh  # Unix/macOS
# or
scripts\dev-setup.bat   # Windows

# Run the server
uv run task serve

Option 2: PyPI Installation

bash
# Install from PyPI (recommended for end users)
pip install gopher-mcp

# Or with uv
uv add gopher-mcp

Option 3: Development Installation

bash
# Install directly from GitHub
uv add git+https://github.com/cameronrye/gopher-mcp.git

# Or install in development mode
git clone https://github.com/cameronrye/gopher-mcp.git
cd gopher-mcp
uv sync --all-extras

methods above.

πŸ”§ Claude Desktop Integration

Add to your claude_desktop_config.json:

Unix/macOS/Linux:

json
{
  "mcpServers": {
    "gopher": {
      "command": "uv",
      "args": ["--directory", "/path/to/gopher-mcp", "run", "task", "serve"],
      "env": {
        "MAX_RESPONSE_SIZE": "1048576",
        "TIMEOUT_SECONDS": "30"
      }
    }
  }
}

Windows:

json
{
  "mcpServers": {
    "gopher": {
      "command": "uv",
      "args": [
        "--directory",
        "C:\\path\\to\\gopher-mcp",
        "run",
        "task",
        "serve"
      ],
      "env": {
        "MAX_RESPONSE_SIZE": "1048576",
        "TIMEOUT_SECONDS": "30"
      }
    }
  }
}

πŸ› οΈ Cross-Platform Development

This project includes a unified Python-based task management system that works across all platforms:

Recommended (All Platforms)

bash
python task.py <command>    # Unified Python task runner (recommended)

Alternative Options

bash
# Unix/macOS/Linux
make <command>              # Traditional make (delegates to task.py)

# Universal fallback
uv run task <command>       # Direct taskipy usage

Available Commands

Command Description
dev-setup Set up development environment
install-hooks Install pre-commit hooks
lint Run ruff linting
format Format code with ruff
typecheck Run mypy type checking
quality Run all quality checks
check Run lint + typecheck
test Run all tests
test-cov Run tests with coverage
test-unit Run unit tests only
test-integration Run integration tests
serve Run MCP server (stdio)
serve-http Run MCP server (HTTP)
docs-serve Serve docs locally
docs-build Build documentation
clean Clean build artifacts
ci Run CI pipeline locally

πŸ“– Usage

The server provides two powerful MCP tools for exploring alternative internet protocols:

gopher_fetch Tool

Fetches Gopher menus, text files, or metadata by URL with comprehensive error handling and security safeguards.

Parameters:

  • url (string, required): Full Gopher URL (e.g., gopher://gopher.floodgap.com/1/)

Response Types:

  • MenuResult: For Gopher menus (type 1) and search results (type 7)
    • Contains structured menu items with type, display text, selector, host, and port
  • TextResult: For text files (type 0)
    • Returns the full text content with metadata
  • BinaryResult: Metadata only for binary files (types 4, 5, 6, 9, g, I)
    • Provides file information without downloading binary content
  • ErrorResult: For errors or unsupported content
    • Includes detailed error messages and troubleshooting hints

gemini_fetch Tool

Fetches Gemini content with full TLS security, TOFU certificate validation, and native gemtext parsing.

Parameters:

  • url (string, required): Full Gemini URL (e.g., gemini://geminiprotocol.net/)

Response Types:

  • GeminiGemtextResult: For gemtext content (text/gemini)
    • Parsed gemtext document with structured lines, links, and headings
  • GeminiSuccessResult: For other text and binary content
    • Raw content with MIME type information
  • GeminiInputResult: For input requests (status 10-11)
    • Prompts for user input with optional sensitive flag
  • GeminiRedirectResult: For redirects (status 30-31)
    • New URL for temporary or permanent redirects
  • GeminiErrorResult: For errors (status 40-69)
    • Detailed error information with status codes
  • GeminiCertificateResult: For certificate requests (status 60-69)
    • Certificate requirement information

🌐 Example URLs to Try

Gopher Protocol

bash
# Classic Gopher menu
gopher://gopher.floodgap.com/1/

# Gopher news and information
gopher://gopher.floodgap.com/1/gopher

# Search example (type 7)
gopher://gopher.floodgap.com/7/v2/vs

# Text file example
gopher://gopher.floodgap.com/0/gopher/welcome

Gemini Protocol

bash
# Gemini protocol homepage
gemini://geminiprotocol.net/

# Gemini software directory
gemini://geminiprotocol.net/software/

# Example personal gemlog
gemini://warmedal.se/~antenna/

# Gemini search aggregator
gemini://kennedy.gemi.dev/

πŸ€– Example AI Interactions

Once configured, you can ask Claude:

Gopher Exploration:

  • "Browse the main Gopher menu at gopher.floodgap.com"
  • "Search for 'python' on the Veronica-2 search server"
  • "Show me the welcome text from Floodgap's Gopher server"
  • "What's available in the Gopher community directory?"

Gemini Exploration:

  • "Fetch the Gemini protocol homepage"
  • "Show me the software directory on geminiprotocol.net"
  • "Browse the latest posts from a gemlog"
  • "What's the difference between Gopher and Gemini protocols?"

πŸ”§ Development

πŸ“ Project Structure

text
gopher-mcp/
β”œβ”€β”€ src/gopher_mcp/          # Main package
β”‚   β”œβ”€β”€ __init__.py          # Package initialization
β”‚   β”œβ”€β”€ server.py            # FastMCP server implementation
β”‚   β”œβ”€β”€ gopher_client.py     # Gopher protocol client
β”‚   β”œβ”€β”€ models.py            # Pydantic data models
β”‚   β”œβ”€β”€ tools.py             # MCP tool definitions
β”‚   └── utils.py             # Utility functions
β”œβ”€β”€ tests/                   # Comprehensive test suite
β”‚   β”œβ”€β”€ test_server.py       # Server tests
β”‚   β”œβ”€β”€ test_gopher_client.py # Client tests
β”‚   └── test_integration.py  # Integration tests
β”œβ”€β”€ docs/                    # MkDocs documentation
β”œβ”€β”€ scripts/                 # Development scripts
β”œβ”€β”€ .github/workflows/       # CI/CD pipelines
β”œβ”€β”€ Makefile                 # Unix/macOS task runner
β”œβ”€β”€ task.bat                 # Windows task runner
└── pyproject.toml           # Modern Python project config

πŸ”„ Development Workflow

  1. Setup: uv run task dev-setup - Install dependencies and pre-commit hooks
  2. Code: Make your changes with full IDE support (type hints, linting)
  3. Quality: uv run task quality - Run all quality checks (lint + typecheck + test)
  4. Test: uv run task test-cov - Run tests with coverage reporting
  5. Commit: Pre-commit hooks ensure code quality automatically

πŸ§ͺ Testing

bash
# Run all tests
uv run task test

# Run with coverage
uv run task test-cov

# Run specific test types
uv run task test-unit
uv run task test-integration

# Run tests in watch mode during development
uv run pytest --watch

βš™οΈ Configuration

The server can be configured through environment variables for both protocols:

Gopher Configuration

Variable Description Default Example
GOPHER_MAX_RESPONSE_SIZE Maximum response size in bytes 1048576 (1MB) 2097152
GOPHER_TIMEOUT_SECONDS Request timeout in seconds 30 60
GOPHER_CACHE_ENABLED Enable response caching true false
GOPHER_CACHE_TTL_SECONDS Cache time-to-live in seconds 300 600
GOPHER_ALLOWED_HOSTS Comma-separated allowed hosts None (all) example.com,test.com

Gemini Configuration

Variable Description Default Example
GEMINI_MAX_RESPONSE_SIZE Maximum response size in bytes 1048576 (1MB) 2097152
GEMINI_TIMEOUT_SECONDS Request timeout in seconds 30 60
GEMINI_CACHE_ENABLED Enable response caching true false
GEMINI_CACHE_TTL_SECONDS Cache time-to-live in seconds 300 600
GEMINI_ALLOWED_HOSTS Comma-separated allowed hosts None (all) example.org,test.org
GEMINI_TOFU_ENABLED Enable TOFU certificate validation true false
GEMINI_CLIENT_CERTS_ENABLED Enable client certificate support true false

Example Configuration

bash
# Gopher settings
export GOPHER_MAX_RESPONSE_SIZE=2097152
export GOPHER_TIMEOUT_SECONDS=60
export GOPHER_CACHE_ENABLED=true
export GOPHER_ALLOWED_HOSTS="gopher.floodgap.com,gopher.quux.org"

# Gemini settings
export GEMINI_MAX_RESPONSE_SIZE=2097152
export GEMINI_TIMEOUT_SECONDS=60
export GEMINI_TOFU_ENABLED=true
export GEMINI_CLIENT_CERTS_ENABLED=true
export GEMINI_ALLOWED_HOSTS="geminiprotocol.net,warmedal.se"

# Run with custom config
uv run task serve

🀝 Contributing

We welcome contributions! Please see our Contributing Guidelines for details.

Quick Contribution Steps

  1. Fork the repository on GitHub
  2. Clone your fork: git clone https://github.com/your-username/gopher-mcp.git
  3. Setup development environment: uv run task dev-setup
  4. Create a feature branch: git checkout -b feature/amazing-feature
  5. Make your changes with tests
  6. Quality check: uv run task quality
  7. Commit your changes: git commit -m 'Add amazing feature'
  8. Push to your fork: git push origin feature/amazing-feature
  9. Submit a pull request with a clear description

Development Standards

  • βœ… Type hints for all functions and methods
  • βœ… Comprehensive tests with >90% coverage
  • βœ… Documentation for all public APIs
  • βœ… Security considerations for all network operations
  • βœ… Cross-platform compatibility (Windows, macOS, Linux)

πŸ“„ License

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

πŸ™ Acknowledgments

  • Model Context Protocol by Anthropic - The foundation that makes this integration possible
  • FastMCP - High-level Python framework for building MCP servers
  • Pituophis - Excellent Python Gopher client library
  • The Gopher Protocol Community - Keeping the spirit of the early internet alive

πŸ”— Related Projects

πŸ“ž Support


Made with ❀️ for the intersection of vintage internet protocols and modern AI

⭐ Star this project if you find it useful!

Star History

Star History Chart

Repository Owner

cameronrye
cameronrye

User

Repository Details

Language Python
Default Branch main
Size 460 KB
Contributors 2
License MIT License
MCP Verified Nov 12, 2025

Programming Languages

Python
98.32%
Batchfile
0.84%
Shell
0.8%
Makefile
0.04%

Topics

gemini gemini-protocol gopher gopher-protocol mcp mcp-server

Join Our Newsletter

Stay updated with the latest AI tools, news, and offers by subscribing to our weekly newsletter.

We respect your privacy. Unsubscribe at any time.

Related MCPs

Discover similar Model Context Protocol servers

  • FastMCP

    FastMCP

    The fast, Pythonic way to build MCP servers and clients.

    FastMCP is a production-ready framework for building Model Context Protocol (MCP) applications in Python. It streamlines the creation of MCP servers and clients, providing advanced features such as enterprise authentication, composable tools, OpenAPI/FastAPI generation, server proxying, deployment tools, and comprehensive client libraries. Designed for ease of use, it offers both standard protocol support and robust utilities for production deployments.

    • ⭐ 20,201
    • MCP
    • jlowin/fastmcp
  • Google Workspace MCP Server

    Google Workspace MCP Server

    Full natural language control of Google Workspace through the Model Context Protocol.

    Google Workspace MCP Server enables comprehensive natural language interaction with Google services such as Calendar, Drive, Gmail, Docs, Sheets, Slides, Forms, Tasks, and Chat via any MCP-compatible client or AI assistant. It supports both single-user and secure multi-user OAuth 2.1 authentication, providing a production-ready backend for custom apps. Built on FastMCP, it delivers high performance and advanced context handling, offering deep integration with the entire Google Workspace suite.

    • ⭐ 890
    • MCP
    • taylorwilsdon/google_workspace_mcp
  • godoc-mcp

    godoc-mcp

    Token-efficient Go documentation server for LLMs using Model Context Protocol.

    godoc-mcp is a Model Context Protocol (MCP) server that provides efficient, structured access to Go package documentation for large language models. It enables LLMs to understand Go projects without reading entire source files by supplying essential documentation and source code at varying levels of granularity. The tool supports project navigation, automatic module setup, caching, and works offline for both standard and third-party Go packages.

    • ⭐ 88
    • MCP
    • mrjoshuak/godoc-mcp
  • AIM Guard MCP

    AIM Guard MCP

    AI-powered security and safety server for Model Context Protocol environments.

    AIM Guard MCP is a server implementing the Model Context Protocol (MCP), providing AI-powered security analysis and safety instruction tools tailored for AI agents. It offers features such as contextual security instructions, harmful content detection, API key scanning, and prompt injection detection, all designed to guard and protect interactions with various MCPs and external services. Built for fast integration, it connects with the AIM Intelligence API and is compatible with any MCP-compliant AI assistant.

    • ⭐ 13
    • MCP
    • AIM-Intelligence/AIM-MCP
  • Google Workspace MCP Server

    Google Workspace MCP Server

    A secure MCP server bridging Google Workspace and AI clients.

    Google Workspace MCP Server implements the Model Context Protocol to enable secure integration between Google Workspace servicesβ€”such as Gmail, Calendar, and Driveβ€”and any MCP-compatible AI client. It allows users to read, search, create, update, and delete Google Calendar events, emails, and Drive files directly through an AI agent interface. The tool ensures authentication via Google OAuth and provides a seamless setup process for both server and client sides. This makes it easier for AI-powered workflows to interact with Google Workspace data securely and contextually.

    • ⭐ 20
    • MCP
    • giuseppe-coco/Google-Workspace-MCP-Server
  • Scrapeless MCP Server

    Scrapeless MCP Server

    A real-time web integration layer for LLMs and AI agents built on the open MCP standard.

    Scrapeless MCP Server is a powerful integration layer enabling large language models, AI agents, and applications to interact with the web in real time. Built on the open Model Context Protocol, it facilitates seamless connections between models like ChatGPT, Claude, and tools such as Cursor to external web capabilities, including Google services, browser automation, and advanced data extraction. The system supports multiple transport modes and is designed to provide dynamic, real-world context to AI workflows. Robust scraping, dynamic content handling, and flexible export formats are core parts of the feature set.

    • ⭐ 57
    • MCP
    • scrapeless-ai/scrapeless-mcp-server
  • Didn't find tool you were looking for?

    Be as detailed as possible for better results