Kobo MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Kobo MCP ServerCreate a simple feedback form with 3 questions and deploy it."
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
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
Related MCP server: MCP Server for LimeSurvey
π§° 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
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.txt3. Configure
cp .env.example .env
# Edit .env and paste your KOBO_TOKEN4. Register the MCP server in Claude
Claude Code (recommended):
claude mcp add kobo python /absolute/path/to/kobo-mcp-server/mcp_server.pyOr 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.pyExpected: 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/v2The 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
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/tagnonkoua-ux/kobo-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server