eight-mcp-community
Provides tools to search for people using registered business cards and the public Eight network. Enables LLMs to query person information while keeping private data secure.
README
eight-mcp-community
Unofficial Python client and stdio MCP server for Eight person-search workflows.
[!WARNING] This project is unofficial and not affiliated with Eight or Sansan. It uses private/internal web endpoints that can change without notice. Keep cookies, passwords, and raw contact data out of GitHub, logs, issues, prompts, and public reports.
Design
This package follows the same idea as note-mcp-community, but the core is Python:
- PyPI/project name:
eight-mcp-community - Python import package:
eight - CLI commands:
eight-mcp-communityandeight-mcp - MCP server: stdio, suitable for local/private agent use
The core client is reusable without an LLM:
from eight import EightClient
client = EightClient.from_default_config()
result = client.search_person("鈴木太郎 東京商事")
print(result.to_safe_dict())
The MCP server is a thin wrapper over the same EightClient.
Install / run
Local development:
uv sync --dev
uv run eight-mcp-community --help
uv run eight-mcp-community serve
Run directly without installing permanently:
uvx eight-mcp-community serve
If Eight returns Cloudflare-style 403 responses with valid cookies, use the optional curl_cffi transport. It impersonates Chrome for the normal CLI/MCP path and does not require Playwright:
uvx --from 'eight-mcp-community[cloudflare]' eight-mcp-community serve
If you install with python -m pip install --user eight-mcp-community, the command may be placed under ~/.local/bin, which is not always on PATH. Either add that directory to PATH, use the absolute path, or run the module form:
python -m eight serve
~/.local/bin/eight-mcp-community serve
MCP client configuration:
{
"mcpServers": {
"eight": {
"command": "uvx",
"args": ["eight-mcp-community", "serve"]
}
}
}
Codex MCP examples:
# PATH-based
codex mcp add eight -- eight-mcp-community serve
# pip --user / absolute-path style
codex mcp add eight -- /Users/you/.local/bin/eight-mcp-community serve
# Cloudflare-resistant transport via uvx
codex mcp add eight -- uvx --from 'eight-mcp-community[cloudflare]' eight-mcp-community serve
After package upgrades, optional dependency changes, authentication changes, or MCP configuration edits, restart Codex / your MCP client or otherwise restart the MCP server process. Already-running MCP servers keep using the old Python process.
Recommended post-install message for agents:
Eight MCP registration is installed, but Eight authentication is not configured yet.
First run setup guidance: /Users/you/.local/bin/eight-mcp-community auth-setup
To configure auth, choose one setup path:
1. Cookie header: /Users/you/.local/bin/eight-mcp-community set-cookie '<COOKIE_HEADER>'
2. Password login: /Users/you/.local/bin/eight-mcp-community set-cookie --email '<EIGHT_LOGIN_EMAIL>' --password '<EIGHT_LOGIN_PASSWORD>'
auth-check は設定後の確認用です: /Users/you/.local/bin/eight-mcp-community auth-check
If auth-check returns 403 even with a valid cookie, use/install eight-mcp-community[cloudflare]. Restart Codex or the MCP client after changes.
Do not list auth-check as a way to configure cookies; it only verifies an already configured cookie/session.
Local development MCP config:
{
"mcpServers": {
"eight": {
"command": "uv",
"args": [
"--directory",
"/path/to/eight-mcp-community",
"run",
"eight-mcp-community",
"serve"
]
}
}
}
Authentication
Start with the setup helper, especially after pip install --user or Codex MCP registration:
~/.local/bin/eight-mcp-community auth-setup
The base package intentionally does not install Playwright. Do not make auth-login the first instruction after a base install. Configure a Cookie header first, or install the optional browser extra before using browser login.
If auth-check returns HTTP 403, it usually means either auth is still missing/expired or Eight/Cloudflare rejected the plain HTTP transport. Re-run auth-setup, configure a valid cookie, and if the cookie is known-good use the [cloudflare] extra:
python -m pip install --user 'eight-mcp-community[cloudflare]'
Supported credential lookup order:
EIGHT_COOKIE— Cookie headerEIGHT_SESSION_COOKIE— alternate Cookie headerEIGHT_MCP_COMMUNITY_CONFIG— path to config JSON with acookiefield- Default config file:
~/.config/eight-mcp-community/config.json EIGHT_COOKIE_FILE— Mozilla/Netscape cookie jar path- Optional env login:
EIGHT_EMAIL+EIGHT_PASSWORD
For remote/server use, prefer a cookie config or env secret. The package does not require browser automation.
Create a config file from a trusted Cookie header:
~/.local/bin/eight-mcp-community set-cookie '<COOKIE_HEADER>'
~/.local/bin/eight-mcp-community auth-check
If you do not have a Cookie header, you can ask the CLI to log in and save cookies:
~/.local/bin/eight-mcp-community set-cookie --email '<EIGHT_LOGIN_EMAIL>' --password '<EIGHT_LOGIN_PASSWORD>'
--email and --password are used only for the login request. The config file stores the resulting Cookie header, not the email or password.
Eight may require MFA or another browser challenge. In that case, install the optional browser extra before using the browser login flow:
python -m pip install --user 'eight-mcp-community[browser]'
python -m playwright install chromium
~/.local/bin/eight-mcp-community auth-login
Browser login is optional and only installed through the [browser] extra. The standard CLI/MCP path does not depend on Playwright. If you run auth-login from a base install, it prints JSON setup guidance instead of a traceback.
If Playwright's browser binary is missing, install it once on the same machine/user account:
python -m playwright install chromium
Or use env:
EIGHT_COOKIE='<COOKIE_HEADER>' eight-mcp-community auth-check
If EIGHT_EMAIL and EIGHT_PASSWORD are set, the client can perform the same password-login flow used by the existing Hermes skill and save resulting cookies into the default config as a Cookie header. MFA/challenge responses are reported as structured errors and are not bypassed.
CLI
eight-mcp-community auth-setup
eight-mcp-community auth-status
eight-mcp-community auth-check
eight-mcp-community set-cookie 'Cookie header'
eight-mcp-community set-cookie --email '<EIGHT_LOGIN_EMAIL>' --password '<EIGHT_LOGIN_PASSWORD>'
python -m pip install --user 'eight-mcp-community[browser]'
python -m playwright install chromium
eight-mcp-community auth-login
eight-mcp-community clear-cookie
eight-mcp-community search '鈴木'
eight-mcp-community search '鈴木' --always-network
eight-mcp-community serve
All command output is JSON except --help.
MCP tools
Authentication/setup tools:
eight_auth_status— report whether auth is configured and from where, without leaking secretseight_auth_setup— return recommended setup steps; use this before telling users to run browser logineight_auth_check— verify access to Eight/myhomeand CSRF extractioneight_set_cookie— store a Cookie header in the local config file, or log in withemail/passwordand save cookieseight_auth_login_browser— open a Playwright browser login flow and save cookies locally after verifying/myhomestatus and CSRF token presenceeight_clear_cookie— delete the stored config-file cookieeight_login_help— explain supported setup paths
Search tools:
eight_search_person— search registered/exchanged cards first; search public Eight network only if no registered-card hit, unlessalwaysNetworkis trueeight_search_registered_cards— search only registered/exchanged business cardseight_search_network_people— search only public Eight network people, keeping public results separate from private cards
Returned data is intentionally minimal and LLM-safe: source, name, company, department, title, updated date, confidence/source bucket, and when available matched_fields / match_excerpt so users can understand why a result matched. Raw HTML, raw JSON, cookies, tokens, email addresses, phone numbers, and bulk exports are not returned.
Privacy and safety
- Do not use this project for bulk contact export or contact-list harvesting.
- Do not commit cookies, config files, raw API dumps, screenshots, or credentials.
- Treat registered business-card results as private context; cite public sources for public-facing reports.
- Eight business-card data can be stale. Corroborate current affiliation/title with public sources when accuracy matters.
Development
uv sync --dev
uv run ruff check .
uv run pytest
Manual MCP smoke test:
printf '%s\n' \
'{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2025-06-18","capabilities":{},"clientInfo":{"name":"smoke-test","version":"0.0.0"}}}' \
'{"jsonrpc":"2.0","method":"notifications/initialized","params":{}}' \
'{"jsonrpc":"2.0","id":2,"method":"tools/list","params":{}}' \
| timeout 5s uv run eight-mcp-community serve
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.