mcp-tw-company
An MCP server for querying Taiwan company registry open data, enabling search by name, number, directors, business items, and branch offices.
README
MCP Taiwan Company Registry
An MCP server for Taiwan company registry open data, exposing AI-callable tools over Model Context Protocol (MCP). Powered by the Ministry of Economic Affairs GCIS open data endpoints.
Features
- stdio JSON-RPC 2.0 — Standard MCP transport protocol
@mcp.tool()decorator — Pydantic-typed tool registration- REST connector — Retry support with exponential backoff
- No-auth public API access — Uses the GCIS open data endpoint directly
- E2E testing — Live API test runner
- 9 registered tools — Company search, directors, business items, branch offices, and more
Prerequisites
- Python
3.14.x uv- No API key required (public open data)
Installation
From PyPI
pip install mcp-tw-company
With uvx (no install needed)
uvx mcp-tw-company
From source
git clone https://github.com/asgard-ai-platform/mcp-tw-company.git
cd mcp-tw-company
uv sync
Configuration
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"tw-company": {
"command": "uvx",
"args": ["mcp-tw-company"]
}
}
}
Claude Code
Add to .mcp.json in your project:
{
"mcpServers": {
"tw-company": {
"command": "uvx",
"args": ["mcp-tw-company"]
}
}
}
Cursor
Add to Cursor MCP settings:
{
"mcpServers": {
"tw-company": {
"command": "uvx",
"args": ["mcp-tw-company"]
}
}
}
Quick Start
# Setup
uv sync
# Test connection
uv run python scripts/auth/test_connection.py
# Run server
uv run python mcp_server.py
Usage Examples
"Search for companies by name"
You: 幫我查「宏碁」相關的公司
AI calls:
get_company_registrations_by_name_keyword(
company_name_keyword = "宏碁",
company_status = "01",
)
Result: SUCCESS — Returns matching company registrations including name, unified business number, capital, representative, and address.
"Look up a specific company by number"
You: 統一編號 89845559 是哪家公司?
AI calls:
get_company_registration_master_by_number(
business_accounting_no = "89845559",
)
Result: SUCCESS — Returns master registration profile: 森鉅科技材料股份有限公司, capital NT$3B, located in Tainan.
"Find directors and supervisors"
You: 查一下這家公司的董監事名單
AI calls:
get_company_directors_by_number(
business_accounting_no = "89845559",
)
Result: SUCCESS — Returns 9 directors/supervisors with positions, names, corporate representatives, and shareholding.
"Check what business items a company is registered for"
You: 這家公司的營業項目有哪些?
AI calls:
get_company_registration_with_business_items_by_number(
business_accounting_no = "89845559",
)
Result: SUCCESS — Returns company profile with 13 registered business items including manufacturing, trading, and construction.
"Determine entity type by number"
You: 統編 00208407 是公司還是商號?
AI calls:
get_registry_entity_type_by_number(
no = "00208407",
)
Result: SUCCESS — Returns entity classification (company, branch office, or business).
Tools Reference
| Tool | Description | Key Parameters |
|---|---|---|
get_company_registrations_by_name_keyword |
Search companies by name keyword | company_name_keyword, company_status |
get_company_registration_master_by_number |
Company master profile | business_accounting_no (8 digits) |
get_company_registration_with_business_items_by_number |
Company profile with business items | business_accounting_no (8 digits) |
get_company_directors_by_number |
Directors and supervisors | business_accounting_no (8 digits) |
get_company_name_by_number |
Company name lookup | business_accounting_no (8 digits) |
get_registry_entity_type_by_number |
Entity type classification | no (8 digits) |
get_branch_offices_by_company_number |
Branch offices by company | business_accounting_no (8 digits) |
get_business_registration_profile_by_agency |
Business profile by agency | president_no, agency |
get_business_registration_items_by_number |
Business registration items | president_no (8 digits) |
All tools support skip (default 0) and top (default 50) pagination parameters.
TODO
- Integrate
company registration basic data (application 2)fromF05D1060-7D57-4763-BDCE-0DAF5975AFE0 - Integrate
business name by numberfrom855A3C87-003A-4930-AA4B-2F4130D713DC - Investigate the upstream access restriction for
business registrations by name keyword(A1B4CBFF-2D3A-409B-8A78-2AD94F63AE4A): the test endpoint currently returnsunauthorized integration IPin this environment - Investigate the upstream access restriction for
branch offices by branch number(23632BB3-5DB7-4423-9643-1D4AC140D479): the test endpoint currently returnsunauthorized integration IPin this environment
Project Structure
mcp-tw-company/
├── app.py # FastMCP singleton
├── mcp_server.py # Entry point (stdio transport)
├── config/settings.py # API endpoints, URL builder, request headers
├── connectors/
│ └── rest_client.py # HTTP REST with retry + pagination
├── auth/
│ └── none.py # No auth (public API)
├── tools/
│ └── company_registry_tools.py
├── tests/test_all_tools.py # E2E test runner
└── scripts/auth/test_connection.py
Testing
uv run python scripts/auth/test_connection.py # Validate API connectivity
uv run python tests/test_all_tools.py # Run all tool E2E tests
Data Source
This project uses Ministry of Economic Affairs GCIS open data endpoints for company and business registration data.
Contributing
See CONTRIBUTING.md for development setup and guidelines.
License
MIT License — see LICENSE for details.
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.