2Captcha MCP
Full 2Captcha API (43 tools) for Claude Code: 31 captcha solvers + management + webhook.
Ask AI about 2Captcha MCP
Powered by Claude Β· Grounded in docs
I know everything about 2Captcha MCP. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
2Captcha MCP
MCP server exposing the full 2Captcha API surface β 31 captcha types, 5 management tools, 3 pingback CRUD tools, 3 webhook event-store tools, and 1 composite solve-and-wait tool (43 tools total) β to Claude Code via stdio.
Built on the official 2captcha-python SDK (AsyncTwoCaptcha), so retry/polling/parsing are handled upstream and every captcha type the SDK supports is available the moment the SDK adds it.
Quick start
pip install twocaptcha-mcp
# or for development:
pip install -e ".[dev]"
Create a .env next to the project root:
2Captcha_API_KEY=your_2captcha_key_here
Verify it works:
python -m twocaptcha_mcp # starts the stdio server (Ctrl+C to stop)
Register the server with Claude Code:
claude mcp add 2captcha -e 2Captcha_API_KEY=your_2captcha_key_here -- python -m twocaptcha_mcp
After a claude restart, prompt the model with:
"Use twocaptcha_balance to check my account."
Configuration
All settings are environment-driven. Aliases in priority order:
| Setting | Aliases | Default | Range |
|---|---|---|---|
| API key (required) | 2Captcha_API_KEY, TWOCAPTCHA_API_KEY, 2CAPTCHA_API_KEY, API_KEY_2CAPTCHA | β | β |
| Server | TWOCAPTCHA_SERVER | 2captcha.com | 2captcha.com, rucaptcha.com |
| Default timeout | TWOCAPTCHA_DEFAULT_TIMEOUT | 120 s | 1..600 |
| reCAPTCHA timeout | TWOCAPTCHA_RECAPTCHA_TIMEOUT | 600 s | 1..1200 |
| Polling interval | TWOCAPTCHA_POLLING_INTERVAL | 10 s | 1..120 |
| Soft id | TWOCAPTCHA_SOFT_ID | 4580 | β |
| Log level | TWOCAPTCHA_LOG_LEVEL | INFO | DEBUG/INFO/WARNING/ERROR/CRITICAL |
| Default pingback URL | TWOCAPTCHA_DEFAULT_CALLBACK | unset | https URL |
Tools
Captcha solvers (31)
| Tool | SDK method | Required arguments |
|---|---|---|
twocaptcha_solve_normal | normal | file_path xor file_base64 |
twocaptcha_solve_text | text | text |
twocaptcha_solve_audio | audio | file (xor), audio_lang |
twocaptcha_solve_grid | grid | file (xor) |
twocaptcha_solve_canvas | canvas | file (xor) |
twocaptcha_solve_coordinates | coordinates | file (xor) |
twocaptcha_solve_rotate | rotate | files: list |
twocaptcha_solve_vkimage | vkimage | files, steps |
twocaptcha_solve_recaptcha | recaptcha | sitekey, url, version, enterprise |
twocaptcha_solve_hcaptcha | hcaptcha | sitekey, url |
twocaptcha_solve_turnstile | turnstile | sitekey, url (+ data/pagedata for CF Challenge) |
twocaptcha_solve_funcaptcha | funcaptcha | sitekey, url |
twocaptcha_solve_geetest | geetest | gt, challenge, url |
twocaptcha_solve_geetest_v4 | geetest_v4 | captcha_id, url |
twocaptcha_solve_capy | capy | sitekey, url |
twocaptcha_solve_keycaptcha | keycaptcha | s_s_c_user_id, s_s_c_session_id, two signs, url |
twocaptcha_solve_lemin | lemin | captcha_id, div_id, url |
twocaptcha_solve_mtcaptcha | mtcaptcha | sitekey, url |
twocaptcha_solve_friendly_captcha | friendly_captcha | sitekey, url |
twocaptcha_solve_cutcaptcha | cutcaptcha | misery_key, apikey, url |
twocaptcha_solve_amazon_waf | amazon_waf | sitekey, iv, context, url |
twocaptcha_solve_tencent | tencent | app_id, url |
twocaptcha_solve_atb_captcha | atb_captcha | app_id, api_server, url |
twocaptcha_solve_datadome β | datadome | proxy, user_agent, captcha_url, pageurl |
twocaptcha_solve_captchafox β | captchafox | proxy, user_agent, sitekey, pageurl |
twocaptcha_solve_vkcaptcha β | vkcaptcha | proxy, user_agent, redirect_uri |
twocaptcha_solve_prosopo | prosopo | sitekey, pageurl |
twocaptcha_solve_temu | temu | body, part1..3 |
twocaptcha_solve_altcha | altcha | pageurl |
twocaptcha_solve_cybersiara | cybersiara | master_url_id, pageurl, cyber_user_agent |
twocaptcha_solve_yandex_smart | yandex_smart | sitekey, url |
β β proxy and user_agent are required by the SDK signature.
All solver tools accept the same set of optional kwargs (mixin SolverKwargs):
proxy: {type, uri}(HTTP/HTTPS/SOCKS4/SOCKS5)pingback: HttpUrlβ per-call pingback URL (must be pre-registered)soft_id: intcookies: struser_agent: strlang: strheader_acao: 0|1
Management (5)
twocaptcha_balanceβ current balance in USDtwocaptcha_report_good/twocaptcha_report_badβ report a captcha id within 15 minutestwocaptcha_get_resultβ poll a captcha id manually (paired withsend_raw)twocaptcha_send_rawβ escape hatch for SDK methods this server does not yet expose
Pingback CRUD (3)
twocaptcha_register_pingbackβ whitelist a callback URLtwocaptcha_list_pingbacksβ list whitelisted addressestwocaptcha_delete_pingbackβ delete one oraddr="all"
Development
pytest --cov=twocaptcha_mcp --cov-branch --cov-fail-under=92 -v
ruff check . && ruff format --check .
mypy --strict twocaptcha_mcp
Run live tests against the real 2Captcha API (consumes credits):
pytest -m live --run-live # balance + solve_normal + concurrent_balance
pytest -m e2e --run-e2e # full MCP protocol roundtrip via mcp.client.session
Architecture
twocaptcha_mcp/
βββ __main__.py # stdio entrypoint
βββ server.py # build_server + dispatch_tool_call
βββ config.py # pydantic-settings (.env)
βββ logger.py # stderr-only logger (stdout is reserved for stdio MCP)
βββ client/
β βββ solver.py # SolverClient β async wrapper over AsyncTwoCaptcha
β βββ pingback.py # httpx wrapper for legacy res.php
β βββ rate_limiter.py # async sliding-window per-method rate limiter
β βββ errors.py # internal CaptchaError hierarchy
βββ schemas/ # Pydantic request/response models per captcha family
βββ tools/ # @captcha_tool handlers per captcha family + composite
βββ webhook_receiver/ # Starlette app + SQLite store (twocaptcha-mcp-webhook)
Tool handlers depend only on the SolverClient / PingbackClient abstractions β the SDK is never imported from a handler. Adding a new captcha type is a 3-step process: schema β tool handler β snapshot test count bump.
Webhook receiver (optional, since 0.3.0)
For long-running solves (recaptcha v3 up to 600 s), the polling-mode SDK call
holds the MCP request slot for the entire duration. Run the optional
twocaptcha-mcp-webhook server to flip into pingback mode β 2Captcha POSTs the
result to your URL, the receiver writes it to SQLite, and the MCP tools read
asynchronously without blocking.
- Composite tool:
twocaptcha_solve_and_wait_pingbacksends the captcha and waits on the local store - Read tools:
twocaptcha_pingback_events_list/get/clear - Deployment: docs/DEPLOY-WEBHOOK.md
- Troubleshooting: TROUBLESHOOTING.md
Contributing
See CONTRIBUTING.md for the dev loop, code conventions, and the SemVer policy for the MCP tool surface.
Security
See SECURITY.md. Vulnerabilities are reported privately via GitHub Security Advisory.
License
MIT β see LICENSE.
Registry verification β mcp-name: io.github.aruxojuyu665/twocaptcha-mcp
