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.
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:
- Open 10+ tabs (Scholarships Corner, Youth Opportunities, Opportunity Desk, …).
- Manually filter through dozens of irrelevant posts.
- Copy-paste deadlines into a spreadsheet.
- 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
Opportunityobjects. - 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:
- Find a source we don't index yet.
- Read its
robots.txtand ToS. - 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file opportunity_mcp-0.1.0.tar.gz.
File metadata
- Download URL: opportunity_mcp-0.1.0.tar.gz
- Upload date:
- Size: 20.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a24343c0b314b4bad04e4798f7e69a0e96a4ec8680e267533d54c839694b8e6c
|
|
| MD5 |
e93fe1bbd998cebbcb55415a5f0a2768
|
|
| BLAKE2b-256 |
48cd8293b8f8cdacc28604747cbbaa6b4002bc36fa556075d7de1f52e506f7fc
|
Provenance
The following attestation bundles were made for opportunity_mcp-0.1.0.tar.gz:
Publisher:
publish.yml on revolutionarybukhari/opportunity-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
opportunity_mcp-0.1.0.tar.gz -
Subject digest:
a24343c0b314b4bad04e4798f7e69a0e96a4ec8680e267533d54c839694b8e6c - Sigstore transparency entry: 1438776879
- Sigstore integration time:
-
Permalink:
revolutionarybukhari/opportunity-mcp@69a67668d0989cab4f79951646fed6ffcfac4d6d -
Branch / Tag:
refs/heads/main - Owner: https://github.com/revolutionarybukhari
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@69a67668d0989cab4f79951646fed6ffcfac4d6d -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file opportunity_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: opportunity_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 16.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d769eb81e25fcf04ccc199bc393d9161d71b37cac1879574dc5098eead600731
|
|
| MD5 |
ed75f5b7975259b4283bfa81cded3f60
|
|
| BLAKE2b-256 |
d29da928e1ffe8b61d1372a295d9ca3b38cd06dc27be56e3d497cae66e0c9299
|
Provenance
The following attestation bundles were made for opportunity_mcp-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on revolutionarybukhari/opportunity-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
opportunity_mcp-0.1.0-py3-none-any.whl -
Subject digest:
d769eb81e25fcf04ccc199bc393d9161d71b37cac1879574dc5098eead600731 - Sigstore transparency entry: 1438776888
- Sigstore integration time:
-
Permalink:
revolutionarybukhari/opportunity-mcp@69a67668d0989cab4f79951646fed6ffcfac4d6d -
Branch / Tag:
refs/heads/main - Owner: https://github.com/revolutionarybukhari
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@69a67668d0989cab4f79951646fed6ffcfac4d6d -
Trigger Event:
workflow_dispatch
-
Statement type: