Personal Swiss recipe knowledge base with promotion-aware meal planning, exposed via MCP. Companion to cellarbrain.
Project description
recipebrain
Personal Swiss recipe knowledge base with promotion-aware meal planning, exposed via MCP.
Companion to cellarbrain. Standalone — no Python coupling. Interop via MCP at runtime, orchestrated by the chat host.
Status
Pre-alpha. Skeleton only. No scraping, no real MCP tools, no queries yet.
Quickstart
git clone https://github.com/<owner>/recipebrain.git
cd recipebrain
python -m venv .venv
.venv/Scripts/activate # Windows
# source .venv/bin/activate # macOS/Linux
pip install -e ".[dev]"
cp recipebrain.toml.example recipebrain.toml
pytest
recipebrain --help
Documentation
| Doc | Topic |
|---|---|
| docs/01-vision-and-usecases.md | Vision, user persona, 10 use cases |
| docs/02-requirements.md | Functional & non-functional requirements |
| docs/03-data-sources.md | Swiss recipe & promotion sources |
| docs/04-entity-model.md | Parquet table schemas, views |
| docs/05-mcp-tools.md | 15 MCP tools + resources |
| docs/06-architecture.md | Pipeline, modules, build phasing |
| docs/decisions/ | Architecture Decision Records |
Relationship to cellarbrain
recipebrain and cellarbrain are independent Python packages that interoperate via MCP:
- cellarbrain answers "which wine pairs with this dish?"
- recipebrain answers "which dish pairs with this wine I want to open?"
- Together (both MCP servers configured in the same host) = end-to-end meal planning with wine pairing.
No shared library. No Python imports between them. The chat host orchestrates cross-server tool calls. See docs/06-architecture.md for details.
Privacy
All data stays local. No cloud sync, no telemetry, no accounts. Recipe data is scraped from public websites and stored as local Parquet files. Your cook log, pantry, and preferences never leave your machine.
Releasing
PyPI publishing uses trusted publishers (OIDC). Configure the pypi environment in GitHub repo settings with PyPI's trusted publisher binding. Then push a version tag:
git tag v0.0.1
git push origin v0.0.1
The publish.yml workflow handles the rest.
License
MIT — see LICENSE.
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 recipebrain-0.0.17.tar.gz.
File metadata
- Download URL: recipebrain-0.0.17.tar.gz
- Upload date:
- Size: 260.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c0bfca6dae6e46601fcef7e0d546e63d5a04bc4d82113f7d1873add41d356bfc
|
|
| MD5 |
7e3516bcf43c5a86193d47366f6f9052
|
|
| BLAKE2b-256 |
52d49eb5596668da114e830bf8df0a36f5ff3d48cfaa9729a12df0ad27703733
|
Provenance
The following attestation bundles were made for recipebrain-0.0.17.tar.gz:
Publisher:
publish.yml on urban-buss/recipebrain
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
recipebrain-0.0.17.tar.gz -
Subject digest:
c0bfca6dae6e46601fcef7e0d546e63d5a04bc4d82113f7d1873add41d356bfc - Sigstore transparency entry: 1592618779
- Sigstore integration time:
-
Permalink:
urban-buss/recipebrain@ab99d22ee161c307a5f2b6527bcea9de98ea897a -
Branch / Tag:
refs/tags/v0.0.17 - Owner: https://github.com/urban-buss
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ab99d22ee161c307a5f2b6527bcea9de98ea897a -
Trigger Event:
push
-
Statement type:
File details
Details for the file recipebrain-0.0.17-py3-none-any.whl.
File metadata
- Download URL: recipebrain-0.0.17-py3-none-any.whl
- Upload date:
- Size: 180.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4705c8c68b37246e178e30664cbbee1ef86b41f120252bc6b1bcfa31604a9e26
|
|
| MD5 |
cf2a892198327fa1ab9a6139bd97a657
|
|
| BLAKE2b-256 |
248864ecbca0d90e1b4fec86c85e04e874cd2ce5d596e8a1846d056cc53baf10
|
Provenance
The following attestation bundles were made for recipebrain-0.0.17-py3-none-any.whl:
Publisher:
publish.yml on urban-buss/recipebrain
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
recipebrain-0.0.17-py3-none-any.whl -
Subject digest:
4705c8c68b37246e178e30664cbbee1ef86b41f120252bc6b1bcfa31604a9e26 - Sigstore transparency entry: 1592618789
- Sigstore integration time:
-
Permalink:
urban-buss/recipebrain@ab99d22ee161c307a5f2b6527bcea9de98ea897a -
Branch / Tag:
refs/tags/v0.0.17 - Owner: https://github.com/urban-buss
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ab99d22ee161c307a5f2b6527bcea9de98ea897a -
Trigger Event:
push
-
Statement type: