Skip to main content

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.

Buy Me A Coffee

⚠️ 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.

Docker Build PyPI Publish

⚡ 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


Vytvořeno s ❤️ pro českou MCP komunitu

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

stravacz_mcp-1.0.0.tar.gz (8.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

stravacz_mcp-1.0.0-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

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

Hashes for stravacz_mcp-1.0.0.tar.gz
Algorithm Hash digest
SHA256 abf213dee045f35359ac6769c59a89b84f2aff1193a444d10484ae56fc8650e6
MD5 1b496c290d1596af193656958281da12
BLAKE2b-256 16cfcaa97b3a057f9b2bdda89ca02d3bfec3df6afb82d4c6a68c8bf283e9fc2a

See more details on using hashes here.

Provenance

The following attestation bundles were made for stravacz_mcp-1.0.0.tar.gz:

Publisher: pypi-publish.yml on mirecekd/stravacz-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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

Hashes for stravacz_mcp-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0dff96a3236aef24a300d2c900d471676a245f8324a2b7f3d1b9f71243291247
MD5 6f74647bac956078ac5c75df25751657
BLAKE2b-256 7f051c8070fb3140d1c85b2c832e64b3564f99148df6739d8f19ede46cd3f01f

See more details on using hashes here.

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

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page