Skip to main content

Search youth opportunities (scholarships, fellowships, internships, conferences) from any AI assistant via MCP.

Project description

Opportunity MCP

Search 10+ youth-opportunity sites — scholarships, fellowships, internships, conferences, exchange programs — from any AI assistant via MCP.

PyPI License: MIT tests

Status: alpha. The schema and source list will change as adapters mature.


Why

A bright student in Lahore, Lagos, Cairo, or Manila wants to find a fully-funded master's scholarship. Today they:

  1. Open 10+ tabs (Scholarships Corner, Youth Opportunities, Opportunity Desk, …).
  2. Manually filter through dozens of irrelevant posts.
  3. Copy-paste deadlines into a spreadsheet.
  4. Miss the deadline anyway because no source tracks them.

Opportunity MCP turns that into:

You: Find me fully-funded master's scholarships in Europe with deadlines in the next 60 days.

Claude: (returns a clean, deduplicated, structured list pulled live from every source)


Install (Claude Desktop)

pip install opportunity-mcp
opportunity-mcp-refresh           # build the local index (one-off, ~30s)

Then add to your claude_desktop_config.json:

{
  "mcpServers": {
    "opportunities": {
      "command": "opportunity-mcp"
    }
  }
}

Restart Claude Desktop. Try: "Use the opportunities tool to find fully-funded fellowships closing in the next 30 days."

Cursor / Windsurf / Continue

Most MCP clients accept the same shape under mcpServers. Point them at the opportunity-mcp command.

Run from source

git clone https://github.com/opportunity-mcp/opportunity-mcp
cd opportunity-mcp
uv sync                           # or: pip install -e ".[dev]"
uv run opportunity-mcp-refresh
uv run opportunity-mcp            # speaks MCP over stdio

Tools exposed

Tool What it does
search_opportunities(query, type?, funded_only?, deadline_before?, limit?) Full-text search with filters.
get_opportunity(id) Look up a single opportunity by id.
list_latest(type?, limit?) Newest opportunities across all sources.
list_upcoming_deadlines(within_days?, type?) Sorted by closing date.
list_sources() What's indexed and when it was last refreshed.
refresh_index(source?) Re-fetch sources on demand. Optional: limit to one source.

Sources

Source Type Status
Opportunities Corners RSS
Opportunities for Youth RSS
Opportunity Desk RSS
Scholarships Corner RSS
Opportunities Circle RSS
Opportunities for Africans RSS
Scholars4Dev RSS
Youth Opportunities (youthop.com) HTML planned
After School Africa HTML planned

See docs/SOURCES.md for robots.txt / ToS notes per source.


Example prompts

Find me fully-funded master's scholarships in Europe with deadlines in the next 60 days.

What internships are open right now for students in Africa?

List the top 10 newest opportunities indexed.

Anything closing in the next 7 days that I might be eligible for as a Pakistani undergrad?

Get details on opportunity a1b2c3d4e5f60718.


Privacy & ethics

  • No user tracking. Queries never leave your machine.
  • All indexed data is public. Articles always link back to the original source.
  • Polite identification. The User-Agent contains a contact URL so site owners can reach us.
  • Conservative refresh cadence. Every 6h via CI, never on user query.
  • Source removals. If a site asks to be delisted, we honor it within 24h. No negotiation.

Architecture

AI client ──MCP──▶ FastMCP server ──▶ SQLite + FTS5 ◀── refresh job ──▶ source adapters ──▶ scholarship sites
  • Adapters know how to read one site. They produce raw Opportunity objects.
  • The query engine knows nothing about sites. It searches the normalized index.

Adding a new source is a 50-line PR. See docs/ADAPTER_GUIDE.md.


Contributing

PRs welcome. The fastest way to help:

  1. Find a source we don't index yet.
  2. Read its robots.txt and ToS.
  3. Send a 50-line PR adding an adapter (RSS) or a 100-line PR (HTML).

See docs/CONTRIBUTING.md.


License

MIT. See LICENSE.

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

opportunity_mcp-0.1.1.tar.gz (21.1 kB view details)

Uploaded Source

Built Distribution

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

opportunity_mcp-0.1.1-py3-none-any.whl (16.6 kB view details)

Uploaded Python 3

File details

Details for the file opportunity_mcp-0.1.1.tar.gz.

File metadata

  • Download URL: opportunity_mcp-0.1.1.tar.gz
  • Upload date:
  • Size: 21.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for opportunity_mcp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 5afb62c018f49aedc1cf06c0b7c11bd8a7a99b69bab2e8135a94223e4b505623
MD5 8cc9110469b5272431b09d42dcdf80e3
BLAKE2b-256 3a13466f1339bbb7a33f5a61d1c86adb2395a49b93d3b46448522d7cc499f5b8

See more details on using hashes here.

Provenance

The following attestation bundles were made for opportunity_mcp-0.1.1.tar.gz:

Publisher: publish.yml on revolutionarybukhari/opportunity-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 opportunity_mcp-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for opportunity_mcp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b2b43ee4e4c7ba7d967febc5c82ba5562dcc8dd4fe959519907c6b3852c74390
MD5 db4b8cac91ddc566e3d3ce225d8527db
BLAKE2b-256 8de35ca3cbacb192620ff276660c77f6b908a0dda729baf985b14f95087f0288

See more details on using hashes here.

Provenance

The following attestation bundles were made for opportunity_mcp-0.1.1-py3-none-any.whl:

Publisher: publish.yml on revolutionarybukhari/opportunity-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