Neoficiální Model Context Protocol server pro strava.cz - český systém objednávání stravy v jídelnách
Project description
Stravacz MCP Server
MCP (Model Context Protocol) server pro strava.cz - systém a webová/mobilní aplikace pro objednávání stravy v českých jídelnách, například školních. Strávníci mohou prostřednictvím systému kontrolovat jídelníčky, přihlašovat a odhlašovat jídlo, sledovat historii objednávek, platby a přeplatky.
⚠️ Upozornění
!! K používání tohoto projektu je potřeba trošku umět s dockerem/pythonem a vědět, jak funguje připojení MCP k danému LLM klientu !!
💡 Poznámka: Tento projekt není nijak spojen se systémem strava.cz. Jedná se o neoficiální MCP server vytvořený komunitou na základě projektů strava-cz-python a strava-cli.
⚡ Rychlý start
🐳 Docker (doporučeno)
# CLI (stdio) verze
docker run --rm -i ghcr.io/mirecekd/stravacz-mcp:latest-cli \
--user USERNAME --password PASSWORD --canteen_number CANTEEN_NUMBER
# HTTP streaming verze (port 8809)
docker run -p 8809:8809 ghcr.io/mirecekd/stravacz-mcp:latest-http \
--user USERNAME --password PASSWORD --canteen_number CANTEEN_NUMBER
📦 uvx (PyPI)
# Instalace z PyPI a spuštění
uvx --from stravacz-mcp stravacz-mcp-server \
--user USERNAME --password PASSWORD --canteen_number CANTEEN_NUMBER
🔧 Dostupné transport metody
Stravacz MCP Server podporuje tři transport metody podle vzoru bakalari-mcp:
| Transport | Port | Docker Image | Popis |
|---|---|---|---|
| CLI (stdio) | - | ghcr.io/mirecekd/stravacz-mcp:latest-cli |
Přímá MCP komunikace přes stdin/stdout |
| HTTP Streaming | 8809 | ghcr.io/mirecekd/stravacz-mcp:latest-http |
Nativní HTTP streaming transport |
| HTTP Proxy | 8805 | ghcr.io/mirecekd/stravacz-mcp:latest-proxy |
HTTP server pomocí mcp-proxy |
🛠️ MCP Tools
Server poskytuje následující nástroje pro práci se strava.cz:
get_menu(datum=None)
Získání jídelníčku pro zadané datum (YYYY-MM-DD) nebo dnešní datum.
is_ordered(meal_id)
Kontrola, jestli je jídlo s daným ID objednané.
order_meals(*meal_ids)
Objednání více jídel podle jejich ID.
print_menu(include_soup=True, include_empty=False)
Formátované vypsání menu s možností filtrace.
get_user_info()
Získání informací o přihlášeném uživateli a jídelně.
logout()
Odhlášení ze strava.cz systému.
📋 MCP konfigurace
Claude Desktop (CLI verze)
{
"mcpServers": {
"stravacz-mcp": {
"command": "docker",
"args": [
"run", "--rm", "-i", "ghcr.io/mirecekd/stravacz-mcp:latest-cli",
"--user", "YOUR_USER",
"--password", "YOUR_PASSWORD",
"--canteen_number", "YOUR_CANTEEN_NUMBER"
],
"transportType": "stdio"
}
}
}
Claude Desktop (HTTP streaming)
{
"mcpServers": {
"stravacz-mcp": {
"url": "http://localhost:8809",
"transportType": "http"
}
}
}
🏗️ Vývoj a build
Lokální vývoj
# Klonování repositáře
git clone https://github.com/mirecekd/stravacz-mcp.git
cd stravacz-mcp
# Instalace závislostí
pip install -e .
# Spuštění ze zdrojových kódů
python src/stravacz_mcp_server/server.py --user USER --password PASS --canteen_number NUM
Docker build
# Build všech verzí
./build-all.sh
# Nebo jednotlivě
./build-cli.sh # CLI verze
./build-http.sh # HTTP streaming verze
./build-proxy.sh # HTTP proxy verze
Python packaging
# Build Python balíčku
python -m build
# Lokální instalace z wheel
pip install dist/stravacz_mcp-1.0.0-py3-none-any.whl
🔍 Technické detaily
Závislosti
- strava-cz >= 1.0.0 - Hlavní knihovna pro strava.cz API
- fastmcp >= 0.9.0 - MCP framework
- aiohttp >= 3.8.0 - Async HTTP klient
Async wrapper
Server používá async wrapper pro původně synchronní strava-cz knihovnu pomocí asyncio.to_thread(), což umožňuje neblokující operace.
Multi-arch Docker images
Všechny Docker images podporují:
- linux/amd64 (Intel/AMD x64)
- linux/arm64 (Apple Silicon, ARM64)
⚠️ Důležité upozornění
Tento projekt používa neoficiální web scraping API pro strava.cz. Server může přestat fungovat při změnách na webu strava.cz. Používejte zodpovědně a neautomatizujte masivní množství požadavků.
📄 Licence
MIT License - viz LICENSE soubor.
🤝 Přispívání
Contributions jsou vítané! Prosím vytvořte issue nebo pull request.
🔗 Související projekty
- strava-cz-python - Původní Python knihovna pro strava.cz
- bakalari-mcp - Podobný MCP server pro Bakaláři
- strava-cli - CLI nástroj pro strava.cz
Vytvořeno s ❤️ pro českou MCP komunitu
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file stravacz_mcp-1.0.0.tar.gz.
File metadata
- Download URL: stravacz_mcp-1.0.0.tar.gz
- Upload date:
- Size: 8.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
abf213dee045f35359ac6769c59a89b84f2aff1193a444d10484ae56fc8650e6
|
|
| MD5 |
1b496c290d1596af193656958281da12
|
|
| BLAKE2b-256 |
16cfcaa97b3a057f9b2bdda89ca02d3bfec3df6afb82d4c6a68c8bf283e9fc2a
|
Provenance
The following attestation bundles were made for stravacz_mcp-1.0.0.tar.gz:
Publisher:
pypi-publish.yml on mirecekd/stravacz-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
stravacz_mcp-1.0.0.tar.gz -
Subject digest:
abf213dee045f35359ac6769c59a89b84f2aff1193a444d10484ae56fc8650e6 - Sigstore transparency entry: 570310372
- Sigstore integration time:
-
Permalink:
mirecekd/stravacz-mcp@4f88d05caa386522099cae32470baf133b6b268e -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/mirecekd
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-publish.yml@4f88d05caa386522099cae32470baf133b6b268e -
Trigger Event:
release
-
Statement type:
File details
Details for the file stravacz_mcp-1.0.0-py3-none-any.whl.
File metadata
- Download URL: stravacz_mcp-1.0.0-py3-none-any.whl
- Upload date:
- Size: 11.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0dff96a3236aef24a300d2c900d471676a245f8324a2b7f3d1b9f71243291247
|
|
| MD5 |
6f74647bac956078ac5c75df25751657
|
|
| BLAKE2b-256 |
7f051c8070fb3140d1c85b2c832e64b3564f99148df6739d8f19ede46cd3f01f
|
Provenance
The following attestation bundles were made for stravacz_mcp-1.0.0-py3-none-any.whl:
Publisher:
pypi-publish.yml on mirecekd/stravacz-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
stravacz_mcp-1.0.0-py3-none-any.whl -
Subject digest:
0dff96a3236aef24a300d2c900d471676a245f8324a2b7f3d1b9f71243291247 - Sigstore transparency entry: 570310373
- Sigstore integration time:
-
Permalink:
mirecekd/stravacz-mcp@4f88d05caa386522099cae32470baf133b6b268e -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/mirecekd
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-publish.yml@4f88d05caa386522099cae32470baf133b6b268e -
Trigger Event:
release
-
Statement type: