Kobo MCP Server
Enables reading and writing to KoBoToolbox via MCP, including creating forms, deploying them, attaching media, and submitting data, all from chat.
README
Kobo MCP Server
An MCP server that lets Claude (Desktop, Code, or any MCP client) read and write to KoBoToolbox. Create forms from a chat, deploy them, attach media, submit data, all without leaving the conversation.
Forked and extended from PYI-SOE-LTD/kobo-mcp-server, which was read-only. This fork adds 10 new write tools (form creation in JSON or XLSForm, multilingual support, media attachments, deploy, update, clone, submissions).
β¨ Features
- π Multilingual forms β create surveys in multiple languages at once (e.g. French + Lingala)
- π Two creation modes β JSON schema (simple) or XLSForm Excel (standard)
- π Full lifecycle β create β attach media β deploy β submit β update β redeploy β clone
- πΌοΈ Media attachments β logos, reference images, audio prompts, video, from local file or URL
- π Token in
.envβ never hardcoded, never committed
π§° 16 tools exposed
Read (6)
listProjects Β· getProjectSummary Β· getProjectSchema Β· queryProjectData Β· getCountsBy Β· getTimeWindowSummary
Write β forms (7)
createForm Β· createFormFromXLSForm Β· deployForm Β· redeployForm Β· updateForm Β· createSubmission Β· cloneForm
Write β media (3)
attachMedia Β· listMedia Β· removeMedia
π Quick start
1. Get a KoBo API token
- Global: https://kf.kobotoolbox.org/token/
- OCHA/Humanitarian: https://eu.kobotoolbox.org/token/
- Self-hosted:
https://<your-host>/token/
2. Install
git clone https://github.com/tagnonkoua-ux/kobo-mcp-server.git
cd kobo-mcp-server
pip install -r requirements.txt
3. Configure
cp .env.example .env
# Edit .env and paste your KOBO_TOKEN
4. Register the MCP server in Claude
Claude Code (recommended):
claude mcp add kobo python /absolute/path/to/kobo-mcp-server/mcp_server.py
Or edit ~/.claude.json manually:
{
"mcpServers": {
"kobo": {
"command": "python",
"args": ["/absolute/path/to/kobo-mcp-server/mcp_server.py"],
"env": {
"KOBO_BASE": "https://kf.kobotoolbox.org/api/v2",
"KOBO_TOKEN": "your_token_here",
"PYTHONIOENCODING": "utf-8"
}
}
}
}
Claude Desktop: copy the same block into claude_desktop_config.json (see claude_desktop_config.json for the template).
π‘ On Windows, use double-backslashes in JSON paths:
"C:\\Users\\you\\kobo-mcp-server\\mcp_server.py".
5. Restart Claude
The 16 Kobo tools should now appear. Try:
"Create a customer satisfaction survey with 5 questions in French and English, deploy it, and give me the public link."
π Simple JSON schema for createForm
Mono-lingual
{
"title": "Customer satisfaction",
"language": "English (en)",
"questions": [
{"name": "your_name", "type": "text", "label": "Your name?", "required": true},
{"name": "rating", "type": "integer", "label": "Rate us 1-10",
"constraint": ". >= 1 and . <= 10"},
{"name": "city", "type": "select_one", "label": "City?",
"choices": ["Brazzaville", "Pointe-Noire", "Dolisie"]}
]
}
Multilingual (label as dict)
{
"title": "Survey",
"languages": ["English (en)", "FranΓ§ais (fr)", "Lingala (ln)"],
"default_language": "FranΓ§ais (fr)",
"questions": [
{"name": "name", "type": "text", "required": true,
"label": {"en": "Your name?", "fr": "Votre nom ?", "ln": "Nkombo na yo ?"}},
{"name": "city", "type": "select_one",
"label": {"en": "City?", "fr": "Ville ?", "ln": "Engumba ?"},
"choices": [
{"name": "bzv", "label": {"en": "Brazzaville", "fr": "Brazzaville", "ln": "Brazzaville"}},
{"name": "pnr", "label": {"en": "Pointe-Noire", "fr": "Pointe-Noire", "ln": "Pointe-Noire"}}
]}
]
}
Supported types
text, integer, decimal, select_one, select_multiple, date, time, datetime, note, geopoint, geotrace, geoshape, image, audio, video, file, barcode, calculate, acknowledge, range, rank, begin_group/end_group, begin_repeat/end_repeat.
Per-question fields
required Β· relevant (skip logic) Β· constraint Β· constraint_message Β· default Β· appearance Β· calculation Β· read_only Β· parameters Β· hint.
π§ͺ Testing
Run the live test suite against your Kobo account (creates ephemeral forms, cleans them up automatically):
python tests/test_write_ops.py
Expected: 11/11 passed.
The tests cover: list, create (mono & multilingual), deploy, submit, update + redeploy, clone, XLSForm upload, media attach/list/remove.
π Security
- Token lives in
.envonly β.envis.gitignored. - The original upstream repo had a hardcoded token in
run.sh. This fork loads from.envinstead. - The server logs only the first 6 chars of the token to stderr (e.g.
abc123...). - All HTTP goes to your configured Kobo host (default
kf.kobotoolbox.org) and KoBoCAT (kc.kobotoolbox.org) for submissions.
If you accidentally leak your token, regenerate it at https://kf.kobotoolbox.org/token/ β the old one stops working instantly.
π Other Kobo instances
Just change KOBO_BASE:
# OCHA / humanitarian
KOBO_BASE=https://eu.kobotoolbox.org/api/v2
# Self-hosted
KOBO_BASE=https://kobo.your-org.example.com/api/v2
The submission code derives the KoBoCAT host automatically by replacing kf. / kpi. with kc. in the hostname.
π οΈ Architecture
kobo-mcp-server/
βββ kobo_client.py # HTTP client for the KPI v2 + KoBoCAT APIs
βββ xlsform_builder.py # JSON β .xlsx XLSForm converter
βββ mcp_server.py # MCP stdio server (16 tools)
βββ server.py # Optional FastAPI HTTP server (legacy)
βββ tests/
β βββ test_write_ops.py
βββ requirements.txt
βββ .env.example
βββ README.md
π License
MIT β see LICENSE. Original work Β© PYI-SOE-LTD. Extensions Β© 2026.
π Credits
- Base server: PYI-SOE-LTD/kobo-mcp-server
- KoBoToolbox API: kobotoolbox/kpi
- MCP protocol: modelcontextprotocol.io
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.