A community-driven registry for Claude, Cursor, Windsurf, Cline & more. Not affiliated with Anthropic.
Are you the author? Sign in to claim
MCP (Model Context Protocol) server for Upwork via browser automation. Enables Claude Code to search jobs, manage propos
MCP (Model Context Protocol) server for Upwork via browser automation. Enables Claude Code to search jobs, manage proposals, messages, and contracts on Upwork.
This MCP uses Chrome DevTools Protocol (CDP) to connect to your real Chrome browser. This approach:
cd upwork-mcp
uv sync
The server connects to Chrome via CDP (Chrome DevTools Protocol).
# Start login flow - opens Chrome with debug port
uv run upwork-mcp --login
This will:
--remote-debugging-port=9222~/.upwork-mcp/chrome-profile/uv run upwork-mcp --check
uv run upwork-mcp --logout
Add to your MCP settings (~/.config/claude-code/settings.json or workspace settings):
{
"mcpServers": {
"upwork": {
"command": "uv",
"args": ["--directory", "/path/to/upwork-mcp", "run", "upwork-mcp"]
}
}
}
| Tool | Description |
|---|---|
upwork_search_jobs | Search for jobs matching criteria |
upwork_get_job_details | Get detailed job information |
upwork_get_my_profile | Get your freelancer profile |
upwork_get_connects_balance | Get current connects balance |
upwork_get_profile_stats | Get earnings and work history stats |
upwork_get_proposals | Get your submitted proposals |
upwork_get_proposal_details | Get details of a specific proposal |
upwork_submit_proposal | Submit a proposal to a job |
upwork_withdraw_proposal | Withdraw a submitted proposal |
upwork_get_messages | Get inbox conversations |
upwork_get_conversation | Get messages in a conversation |
upwork_send_message | Send a message |
upwork_get_unread_count | Get unread message count |
upwork_get_contracts | Get your contracts |
upwork_get_contract_details | Get contract details |
upwork_get_work_diary | Get work diary entries |
upwork_check_session | Check if session is valid |
upwork_close_session | Close browser and cleanup |
Search for Python developer jobs on Upwork with budget over $1000
Get details for this Upwork job: https://www.upwork.com/jobs/~01234567890
Show my active proposals on Upwork
Check my Upwork messages
upwork-mcp [OPTIONS]
Options:
--login Open browser for manual login
--check Check if session is valid
--logout Clear saved session
--no-headless Show browser window (debugging)
--timeout MS Page timeout in milliseconds (default: 30000)
--transport MCP transport type (default: stdio)
upwork-mcp/
├── pyproject.toml
├── README.md
├── src/upwork_mcp/
│ ├── __init__.py
│ ├── server.py # MCP server entry point
│ ├── browser/
│ │ ├── client.py # Patchright browser wrapper
│ │ └── auth.py # Login flow
│ ├── tools/
│ │ ├── jobs.py # Job search and details
│ │ ├── profile.py # Profile and connects
│ │ ├── proposals.py # Proposal management
│ │ ├── messages.py # Messaging
│ │ └── contracts.py # Contract management
│ └── utils/
│ ├── config.py # Configuration
│ └── logging.py # Logging setup
├── tests/
└── scripts/
└── test_all.py
uv run python scripts/test_all.py
Session data is stored in ~/.upwork-mcp/profile/. This includes browser cookies and local storage that persist your Upwork login.
# Re-authenticate
uvx upwork-mcp --login
Run with visible browser to solve manually:
uvx upwork-mcp --no-headless
# Install Chromium for Patchright
uvx patchright install chromium
Apache 2.0
Run Claude Code as an MCP server so any agent can delegate coding tasks to it
Browser automation using accessibility snapshots instead of screenshots
A trilingual (繁中 / English / 简中) learning roadmap for agentic AI: from LLM basics to multi-agent systems, with 240+ cura
MCP server integration for DaVinci Resolve Studio