mcp-dauthau
Connects AI tools to Vietnamese bid (đấu thầu) lookup service DauThau via MCP, with local key signing for security.
README
@dauthau/mcp-dauthau
Node.js wrapper kết nối AI tool (Claude Code, Cursor, Antigravity, Windsurf...) với dịch vụ tra cứu đấu thầu công Việt Nam của DauThau qua giao thức Model Context Protocol.
Wrapper chạy stdio trên máy bạn, ký request local rồi forward HTTPS lên gateway. Apisecret KHÔNG bao giờ rời máy bạn.
Tính năng
- 🔐 Apisecret giữ local — wrapper ký
hashsecretper-request bằngnode:crypto(md5) hoặcbcrypt, chỉ gửi chữ ký qua mạng. - ⚡ Zero-install — chạy qua
npx -y @dauthau/mcp-dauthau@latest, không cài cố định, auto-update. - 🧩 Pass-through proxy động — danh sách tool query từ gateway mỗi session. Khi backend mở rộng tool, bạn KHÔNG cần update wrapper.
- 🛡️ Tối thiểu dependency — chỉ 1 runtime dependency (
@modelcontextprotocol/sdk) + Node stdlib. Mỗi release publish với npm provenance SLSA. - 🌍 Cross-platform — Node.js ≥ 22 trên macOS / Linux / Windows. CI test cả 3 OS × 3 Node version.
Yêu cầu
- Node.js >= 22 (LTS). Tải tại https://nodejs.org/
- Tài khoản DauThau với apikey + apisecret (đăng ký tại https://dauthau.info).
- MCP gateway key — liên hệ DauThau để được cấp.
Cài đặt
KHÔNG cần npm install. Dùng trực tiếp qua npx.
Config .mcp.json cho Claude Code / Cursor / Windsurf
{
"mcpServers": {
"dauthau": {
"command": "npx",
"args": ["-y", "@dauthau/mcp-dauthau@latest"],
"env": {
"DAUTHAU_APIKEY": "<apikey-cua-ban>",
"DAUTHAU_APISECRET": "<apisecret-cua-ban>",
"DAUTHAU_METHOD": "md5_verify",
"MCP_GATEWAY_URL": "<url-gateway-duoc-cap>",
"MCP_GATEWAY_KEY": "<gateway-key-duoc-cap>"
}
}
}
}
Sau khi config, restart MCP client (Claude Code / Cursor) để nạp wrapper. AI assistant sẽ tự discover danh sách tool và bắt đầu dùng được.
Vị trí .mcp.json theo client
| Client | Đường dẫn |
|---|---|
| Claude Code | .mcp.json trong project root, hoặc ~/.claude.json (global) |
| Cursor | ~/.cursor/mcp.json |
| Windsurf | ~/.codeium/windsurf/mcp_config.json |
| Antigravity | xem doc client tương ứng |
Biến môi trường
Bắt buộc
| Env | Mô tả |
|---|---|
DAUTHAU_APIKEY |
Apikey từ tài khoản DauThau của bạn |
DAUTHAU_APISECRET |
Apisecret tương ứng (giữ local, dùng để ký hashsecret) |
MCP_GATEWAY_URL |
URL endpoint gateway (DauThau cấp khi đăng ký) |
MCP_GATEWAY_KEY |
Gateway subscription key (DauThau cấp) |
Tuỳ chọn
| Env | Default | Mô tả |
|---|---|---|
DAUTHAU_METHOD |
password_verify |
Phương thức xác thực chữ ký: password_verify (mặc định, dùng bcrypt) hoặc md5_verify (dùng md5). |
LOG_LEVEL |
info |
debug / info / warn / error — log ra stderr (stdout dành cho MCP framing). |
MCP_GATEWAY_TIMEOUT_MS |
30000 |
Timeout HTTPS request lên gateway, range 1000-120000. |
Bảo mật
- Apisecret KHÔNG bao giờ gửi qua mạng. Wrapper ký
hashsecret = md5(apisecret + "_" + timestamp)local, chỉ gửihashsecret+timestamp(Unix seconds) qua header. - Wrapper KHÔNG log giá trị nhạy cảm: apikey, apisecret, hashsecret, gateway key, raw body. Log chỉ chứa: tool name, latency, status, error message.
- Mọi credential giữ trong RAM scope process — KHÔNG persist ra disk/cache.
- Mỗi request 1 timestamp mới + 1 hashsecret mới — chống replay attack (gateway verify skew window phía server).
Lưu ý
- Khi bạn paste apisecret vào
.mcp.json, file đó phải được bảo vệ (chmod 600 trên Unix, ACL hạn chế trên Windows). KHÔNG commit.mcp.jsonchứa apisecret lên git. - Cold-start
npxlần đầu mỗi session khoảng 200-500ms để tải package vào cache. Sau đó session sau dùng cache local.
Troubleshooting
Thiếu env: DAUTHAU_APIKEY, ...
Kiểm tra block env trong .mcp.json đã có đủ 4 biến bắt buộc. Restart MCP client sau khi sửa.
Node.js >= 22 required
Wrapper yêu cầu Node 22+ (LTS). Cài LTS mới nhất tại https://nodejs.org/.
gateway timeout sau 30000ms
Mạng chậm hoặc gateway tạm thời không phản hồi. Tăng timeout qua MCP_GATEWAY_TIMEOUT_MS=60000 hoặc kiểm tra kết nối internet.
Clock skew (lỗi liên quan timestamp)
Đồng hồ máy lệch so với server > 60s. Sync NTP:
- macOS / Linux:
sudo sntp -sS time.google.comhoặcsudo timedatectl set-ntp on - Windows: mở PowerShell admin, chạy
w32tm /resync
Kiểm tra wrapper trước khi tin tưởng
npx -y @dauthau/mcp-dauthau@latest --version
npx -y @dauthau/mcp-dauthau@latest --help
Phát triển local
git clone https://github.com/vinades/mcp-dauthau.git
cd mcp-dauthau
npm install
npm run lint # tsc --noEmit
npm test # vitest unit + integration mock
npm run build # tsc → dist/
node dist/index.js --version
Đóng góp
Pull request và issue đều welcome. Trước khi PR:
- Đảm bảo
npm run lint && npm testpass. - Thêm test cho code mới (vitest, mục tiêu coverage ≥ 85% cho module core).
- KHÔNG commit
.env, key thật, hoặc thông tin nhạy cảm. - Mô tả PR ngắn gọn, đính kèm test plan.
Báo cáo lỗ hổng bảo mật: vui lòng dùng GitHub Security Advisory (private) trước khi public disclosure.
Liên kết
- Model Context Protocol — chuẩn giao thức Anthropic phát triển.
- @modelcontextprotocol/sdk — TypeScript SDK chính chủ.
- DauThau — dịch vụ tra cứu đấu thầu công Việt Nam.
License
GNU General Public License v2.0
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.