Opportunity MCP
Search youth opportunities (scholarships, fellowships, internships) from any AI assistant.
Ask AI about Opportunity MCP
Powered by Claude ยท Grounded in docs
I know everything about Opportunity MCP. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
Opportunity MCP
A Model Context Protocol server that lets any AI assistant search youth opportunities โ scholarships, fellowships, internships, conferences, and exchange programs โ aggregated live from leading opportunity-discovery sites.
Status: alpha (
v0.1.x). Schema, tool surface, and source list may change as adapters mature. Pin to a minor version in production.
Overview
Students who depend on third-party scholarship-aggregator sites typically open ten or more tabs, sift through dozens of irrelevant posts, and copy deadlines into a personal spreadsheet โ only to miss the application window because no aggregator offers reliable deadline tracking. Opportunity MCP collapses that workflow into a single conversational query.
You: Find fully-funded master's scholarships in Europe with deadlines in the next 60 days, eligible for Pakistani citizens.
Claude: (Returns a deduplicated, structured list pulled live from the indexed sources, sorted by deadline, each linking back to the original article.)
The server runs locally over stdio, ships an SQLite + FTS5 index that refreshes every six hours via CI, and is distributed through PyPI, the official MCP Registry, and Smithery.
Distribution channels
| Channel | Identifier | Status |
|---|---|---|
| PyPI | opportunity-mcp | โ live |
| MCP Registry | io.github.revolutionarybukhari/opportunity-mcp | โ published |
| Smithery | sayedhusnainhader/opportunity-mcp | โ published |
| GitHub | revolutionarybukhari/opportunity-mcp | source of truth |
| GitHub Releases | index-N snapshots of the SQLite DB, refreshed every 6h | auto-published by CI |
Installation
Claude Desktop
pip install opportunity-mcp
opportunity-mcp-refresh # build the local index (one-off, ~30 seconds)
Add the following to claude_desktop_config.json:
{
"mcpServers": {
"opportunities": {
"command": "opportunity-mcp"
}
}
}
Restart Claude Desktop. The six tools below become available to the model.
Cursor, Windsurf, Continue, and other MCP clients
Most clients use the same mcpServers shape. Point the command at opportunity-mcp (after pip install) or use uvx for zero-install:
{
"mcpServers": {
"opportunities": {
"command": "uvx",
"args": ["opportunity-mcp"]
}
}
}
Smithery (one-click install)
https://smithery.ai/server/sayedhusnainhader/opportunity-mcp โ Smithery handles the install command for you.
From source
git clone https://github.com/revolutionarybukhari/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
The server exposes six tools. Each accepts JSON arguments and returns Pydantic-typed results.
| Tool | Signature | Description |
|---|---|---|
search_opportunities | (query, type?, funded_only?, deadline_before?, limit=20) | Full-text search across all indexed opportunities with optional filters. |
get_opportunity | (id) | Retrieve full details for a single opportunity by its ID. |
list_latest | (type?, limit=20) | Newest opportunities across all sources, sorted by post date. |
list_upcoming_deadlines | (within_days=30, type?) | Opportunities closing within N days, sorted by deadline. |
list_sources | () | List indexed sources, item counts, and last-refresh timestamps. |
refresh_index | (source?) | Re-fetch sources on demand. Optional source argument limits the refresh to one site. |
type is one of scholarship, fellowship, internship, conference, exchange, competition, grant, award, or other.
Indexed sources
Verified live against each site's RSS feed.
| Source | Mechanism | Status |
|---|---|---|
| Opportunities Corners | RSS | โ live |
| Opportunities for Youth | RSS | โ live |
| Opportunity Desk | RSS | โ live |
| Scholarships Corner | RSS | โ live |
| Opportunities Circle | RSS | โ live |
| Opportunities for Africans | RSS | โ live |
| Scholars4Dev | RSS | โ adapter live (feed currently empty upstream) |
| Youth Opportunities | HTML | planned |
| After School Africa | HTML | planned |
Per-source robots.txt compliance, ToS notes, and CI quirks are documented in docs/SOURCES.md.
Example prompts
Find fully-funded master's scholarships in Europe with deadlines in the next 60 days.
What conferences are happening in Africa in the next three months?
List the ten newest internships indexed today.
Show me everything closing in the next seven days that an undergraduate could apply to.
Get full details for opportunity 7733b95a81e3239d.
Architecture
AI client โโMCPโโโถ FastMCP server โโโถ SQLite + FTS5 โโโ refresh job โโโถ source adapters โโโถ opportunity sites
Two clean separations of concern:
- Adapters know how to read one site and produce raw
Opportunityobjects (Pydantic-validated). - The query engine knows nothing about sites โ it searches a normalized index.
Adding a new source is typically a fifty-line pull request. See docs/ADAPTER_GUIDE.md. Full architecture rationale is in docs/ARCHITECTURE.md.
Privacy & ethics
- No user tracking. All queries are processed locally; nothing leaves the user's machine except the periodic source-site refresh.
- All indexed data is public. Summaries are capped at 500 characters and every record links back to the originating article.
- Polite identification. The HTTP
User-Agentincludes the project URL so site owners can reach us directly. - Conservative refresh cadence. Sources are polled at most every six hours, via CI โ never on user query.
- Source removals on request are honored within 24 hours, with no negotiation.
robots.txtis respected by every adapter prior to fetching.
Roadmap
- Phase 2 โ country-, level-, and language-aware extraction (currently delegated to the AI client).
- Phase 3 โ first HTML adapter (Youth Opportunities), broader Tier-2/Tier-4 source coverage.
- Phase 4 โ hosted Streamable-HTTP endpoint for clients that prefer remote MCP servers.
- Phase 5 โ optional weekly digest by saved profile.
Open issues with the add a source label are good first contributions.
Contributing
Pull requests are welcome. The fastest way to help is to add a source we do not yet index โ read docs/ADAPTER_GUIDE.md and open a PR. See docs/CONTRIBUTING.md for development setup, testing conventions, and the code-of-conduct expectations.
git clone https://github.com/revolutionarybukhari/opportunity-mcp
cd opportunity-mcp
uv sync
uv run pytest
uv run ruff check .
License
MIT ยฉ Opportunity MCP Contributors.
