Gopher & Gemini MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Gopher & Gemini MCP Serverfetch the Gopher root menu from gopher.floodgap.com"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Gopher & Gemini MCP Server
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_fetchandgemini_fetchtools for comprehensive protocol coverageComprehensive 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
Python 3.11+ - Download here
uv package manager - Install uv
Installation
Option 1: Development Installation (Recommended)
# 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 serveOption 2: PyPI Installation
# Install from PyPI (recommended for end users)
pip install gopher-mcp
# Or with uv
uv add gopher-mcpOption 3: Development Installation
# 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-extrasClaude Desktop Integration
Add to your claude_desktop_config.json:
Unix/macOS/Linux:
{
"mcpServers": {
"gopher": {
"command": "uv",
"args": ["--directory", "/path/to/gopher-mcp", "run", "task", "serve"],
"env": {
"MAX_RESPONSE_SIZE": "1048576",
"TIMEOUT_SECONDS": "30"
}
}
}
}Windows:
{
"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)
python task.py <command> # Unified Python task runner (recommended)Alternative Options
# Unix/macOS/Linux
make <command> # Traditional make (delegates to task.py)
# Universal fallback
uv run task <command> # Direct taskipy usageAvailable Commands
Command | Description |
| Set up development environment |
| Install pre-commit hooks |
| Run ruff linting |
| Format code with ruff |
| Run mypy type checking |
| Run all quality checks |
| Run lint + typecheck |
| Run all tests |
| Run tests with coverage |
| Run unit tests only |
| Run integration tests |
| Run MCP server (stdio) |
| Run MCP server (HTTP) |
| Serve docs locally |
| Build documentation |
| Clean build artifacts |
| 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
# 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/welcomeGemini Protocol
# 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
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 configDevelopment Workflow
Setup:
uv run task dev-setup- Install dependencies and pre-commit hooksCode: Make your changes with full IDE support (type hints, linting)
Quality:
uv run task quality- Run all quality checks (lint + typecheck + test)Test:
uv run task test-cov- Run tests with coverage reportingCommit: Pre-commit hooks ensure code quality automatically
Testing
# 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 --watchConfiguration
The server can be configured through environment variables for both protocols:
Gopher Configuration
Variable | Description | Default | Example |
| Maximum response size in bytes |
|
|
| Request timeout in seconds |
|
|
| Enable response caching |
|
|
| Cache time-to-live in seconds |
|
|
| Comma-separated allowed hosts |
|
|
Gemini Configuration
Variable | Description | Default | Example |
| Maximum response size in bytes |
|
|
| Request timeout in seconds |
|
|
| Enable response caching |
|
|
| Cache time-to-live in seconds |
|
|
| Comma-separated allowed hosts |
|
|
| Enable TOFU certificate validation |
|
|
| Enable client certificate support |
|
|
Example Configuration
# 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 serveContributing
We welcome contributions! Please see our Contributing Guidelines for details.
Quick Contribution Steps
Fork the repository on GitHub
Clone your fork:
git clone https://github.com/your-username/gopher-mcp.gitSetup development environment:
uv run task dev-setupCreate a feature branch:
git checkout -b feature/amazing-featureMake your changes with tests
Quality check:
uv run task qualityCommit your changes:
git commit -m 'Add amazing feature'Push to your fork:
git push origin feature/amazing-featureSubmit 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
Model Context Protocol Servers - Official MCP server implementations
Awesome MCP Servers - Curated list of MCP servers
Claude Desktop - AI assistant that supports MCP
Support
Bug Reports: GitHub Issues
Feature Requests: GitHub Discussions
Documentation: Project Docs
Community: MCP Discord
Made with ❤️ by Cameron Rye
Star this project if you find it useful!
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
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/cameronrye/gopher-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server