Skip to main content

MCP server for Source Cooperative auto-discovery and data exploration

Project description

Source Cooperative MCP Server

Tests PyPI version Python 3.11+ License: MIT

Discover and access 800TB+ of geospatial data through AI agents.

An MCP (Model Context Protocol) server for Source Cooperative - a collaborative repository with datasets from Maxar, Harvard, ESA, USGS, and 90+ organizations.


🏗️ Architecture Overview

graph TB
    subgraph "AI Clients"
        A1[Claude Desktop]
        A2[Claude Code]
        A3[Cursor]
        A4[Cline]
        A5[Zed]
        A6[Continue.dev]
    end

    subgraph "MCP Server"
        MCP[Source Cooperative MCP<br/>FastMCP + obstore]
    end

    subgraph "6 Available Tools"
        T1[list_accounts<br/>94+ orgs]
        T2[list_products<br/>hybrid S3+API]
        T3[get_product_details<br/>+ README]
        T4[list_product_files<br/>tree mode]
        T5[get_file_metadata<br/>no download]
        T6[search<br/>hybrid fuzzy]
    end

    subgraph "Data Sources"
        S1[HTTP API<br/>source.coop/api]
        S2[S3 Direct<br/>opendata.source.coop]
    end

    A1 -->|JSON-RPC| MCP
    A2 -->|JSON-RPC| MCP
    A3 -->|JSON-RPC| MCP
    A4 -->|JSON-RPC| MCP
    A5 -->|JSON-RPC| MCP
    A6 -->|JSON-RPC| MCP

    MCP --> T1
    MCP --> T2
    MCP --> T3
    MCP --> T4
    MCP --> T5
    MCP --> T6

    T1 --> S2
    T2 --> S1
    T2 --> S2
    T3 --> S1
    T3 --> S2
    T4 --> S2
    T5 --> S2
    T6 --> S1

    style MCP fill:#4CAF50,stroke:#2E7D32,stroke-width:3px,color:#fff
    style S1 fill:#2196F3,stroke:#1976D2,stroke-width:2px,color:#fff
    style S2 fill:#2196F3,stroke:#1976D2,stroke-width:2px,color:#fff

Key Features:

  • Token Optimized - 72% reduction for large datasets
  • Smart Partitions - Auto-detects Hive-style patterns
  • Fuzzy Search - Handles typos and partial matches
  • No Auth - All 800TB+ is public

🚀 Quick Start

Install

uvx source-coop-mcp

Configure Your AI Client

Claude Desktop / Claude Code / Cursor / Cline

Add to config file:

  • Claude Desktop: ~/Library/Application Support/Claude/claude_desktop_config.json (macOS)
  • Claude Code: VS Code settings.json
  • Cursor: Cursor settings
  • Cline: Cline MCP settings
{
  "mcpServers": {
    "source-coop": {
      "command": "uvx",
      "args": ["source-coop-mcp"]
    }
  }
}

Zed

Add to Zed settings:

{
  "context_servers": {
    "source-coop": {
      "command": "uvx",
      "args": ["source-coop-mcp"]
    }
  }
}

Continue.dev

Add to Continue config (~/.continue/config.json):

{
  "experimental": {
    "modelContextProtocolServers": [
      {
        "transport": {
          "type": "stdio",
          "command": "uvx",
          "args": ["source-coop-mcp"]
        }
      }
    ]
  }
}

Restart your AI client and start exploring!


🛠️ Available Tools

Tool Purpose Performance
list_accounts() Find all 94+ organizations ~850ms
list_products() Hybrid: S3 mode (default) for ALL datasets + file counts ~240ms
list_products(include_unpublished=False) API mode for published datasets with rich metadata ~500ms
get_product_details() Get metadata + README automatically ~650ms
list_product_files() List files with S3/HTTP paths ~240ms
list_product_files(show_tree=True) Tree view (72% token savings) ~980ms
get_file_metadata() Get file info without downloading ~230ms
search(query) Hybrid: Search accounts + products (published + unpublished), top 5 results ~5-10s

💡 What You Can Do

Discover Data

"List all organizations in Source Cooperative"
→ Returns 94+ organizations: maxar, planet, harvard, etc.

"Find all datasets for harvard-lil"
→ Discovers published + unpublished products

"Search for climate datasets"
→ Smart fuzzy search handles typos and partial matches

Access Files

"List files in harvard-lil/gov-data"
→ Returns S3 paths and HTTP URLs ready for analysis

"Show me the file tree with partition detection"
→ Smart visualization: year={2020,2021,...+5 more}/ [partitioned]

"Get file metadata without downloading"
→ Size, last modified, ETag

Smart Search

"Search for climte" (typo)
→ Finds "climate" datasets (fuzzy matching)

"Search for geo" (partial)
→ Finds "geospatial", "geocoding", etc.

⚡ Features

Feature Description
Complete Discovery Finds unpublished products the official API doesn't show
No Authentication All 800TB+ data is public
Fast Performance Rust-backed S3 client (9x faster than boto3)
Token Optimized Tree mode: 72% token reduction for large datasets
Smart Partitions Auto-detects patterns: year={2020,2021,...}
Fuzzy Search Handles typos and partial matches
README Integration Documentation automatically included
800TB+ Data 94+ organizations, geospatial datasets

📋 Example Workflow

1. "List all organizations"
   → Get 94+ account names

2. "Show me all datasets from maxar"
   → Discover published + unpublished products

3. "Search for climate data"
   → Smart fuzzy search finds relevant datasets

4. "Get details for harvard-lil/gov-data"
   → Full metadata + README content

5. "List files in this dataset with tree view"
   → Token-optimized tree with partition detection

🎯 Why This Server?

Problem

Source Cooperative has 800TB+ of valuable data, but:

  • Official API only shows published products
  • No auto-discovery of organizations
  • Requires knowing what you're looking for

Solution

This MCP server provides:

  • ✅ Complete auto-discovery (published + unpublished)
  • ✅ Smart search with fuzzy matching
  • ✅ Direct S3 access for all files
  • ✅ Token-optimized outputs (72% reduction)
  • ✅ Smart partition detection (10-88% additional savings)
  • ✅ README documentation included automatically
  • ✅ No authentication required

📊 Performance

All operations complete in under 1 second:

list_accounts():                          ~850ms  (94+ organizations)
list_products():                          ~240ms  (S3 mode - ALL datasets + file counts)
list_products(include_unpublished=False): ~500ms  (API mode - published with metadata)
list_product_files():                     ~240ms  (simple list)
list_product_files(tree=True):            ~980ms  (72% token savings)
get_file_metadata():                      ~230ms  (HEAD only)
search(query):                            ~5-10s  (hybrid search - 1 recursive S3 scan, top 5 enriched)

Token Optimization Impact

Dataset Size Without Tree With Tree Saved
10 files 1,500 tokens 415 tokens 72.3%
100 files 15,000 tokens 4,150 tokens 72.3%
1,000 files 150,000 tokens 41,500 tokens 72.3%

With partition detection (1,000 partitions): 88% total savings!


🔧 Requirements

  • Python: 3.11 or higher
  • Package Manager: uv (installed automatically by uvx)
  • Operating Systems: macOS, Linux, Windows

🤝 Development

See DEVELOPMENT.md for:

  • Architecture details
  • Testing instructions
  • Contributing guidelines
  • Performance benchmarks
  • Token optimization details

📝 Support


📄 License

MIT License - see LICENSE for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

source_coop_mcp-0.2.4.tar.gz (125.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

source_coop_mcp-0.2.4-py3-none-any.whl (18.3 kB view details)

Uploaded Python 3

File details

Details for the file source_coop_mcp-0.2.4.tar.gz.

File metadata

  • Download URL: source_coop_mcp-0.2.4.tar.gz
  • Upload date:
  • Size: 125.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for source_coop_mcp-0.2.4.tar.gz
Algorithm Hash digest
SHA256 4f5a6ed87d57ced5ab3a4b1740f706eaca438d570437b6668ba8d97bc2975b5d
MD5 6115c50d37727f46c711f32e65e534e0
BLAKE2b-256 e8351949dc2dbf70a438189ab90b2389549f3f731fb217bd232aa431035e1138

See more details on using hashes here.

Provenance

The following attestation bundles were made for source_coop_mcp-0.2.4.tar.gz:

Publisher: publish.yml on yharby/source-coop-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file source_coop_mcp-0.2.4-py3-none-any.whl.

File metadata

File hashes

Hashes for source_coop_mcp-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 cfb01d895cf4809f40daf1b2ab922f7cf8d7842d2ebe78a758eed6b082c94549
MD5 f65a129e05e233598ea927652fc4789f
BLAKE2b-256 60be9967ee30f9bb9f59c4e0ae5baf44df2daf7a9135ad3e6dc8970a1417321c

See more details on using hashes here.

Provenance

The following attestation bundles were made for source_coop_mcp-0.2.4-py3-none-any.whl:

Publisher: publish.yml on yharby/source-coop-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page