loading…
Search for a command to run...
loading…
A read-only MCP server for SimpleShop accounting data, enabling AI agents to find documents, download PDFs, inspect products, and review sales exports.
A read-only MCP server for SimpleShop accounting data, enabling AI agents to find documents, download PDFs, inspect products, and review sales exports.
Read-only FastMCP server for SimpleShop accounting data.
This server exposes a small MCP tool surface for AI agents that need to audit SimpleShop documents, download document PDFs, inspect products, and review product sales exports before copying data into another accounting system.
It is intentionally read-only. It does not create, update, delete, pay, cancel, send, or mutate SimpleShop records.
simpleshop-mcp ships as a Claude Code / Cowork plugin. In either client:
/plugin marketplace add mikz/simpleshop-mcp
/plugin install simpleshop-mcp@simpleshop-mcp
The server starts without credentials. To sign in, call the
simpleshop_login MCP tool. It supports mode: "auto" | "direct" | "prefab" | "web": Apps-capable clients get an inline Prefab form, and other clients can
use mode: "direct" with email and api_key in the tool call or a localhost
web form. The server validates credentials
against SimpleShop, persists them locally, and updates the running MCP server.
Requirements on the host machine:
uvx on PATH (install with uv)uvx will fetch one if missing)simpleshop://documents/{document_id}/pdf/{variant}.simpleshop_login
simpleshop_test_login
simpleshop_find_documents
simpleshop_download_documents
simpleshop_find_products
simpleshop_get_product_sales
simpleshop_get_metadata
simpleshop_login collects and validates credentials at runtime through direct
arguments, Prefab UI, or a localhost web form.
simpleshop_test_login takes no arguments and is the quickest way to confirm
the current credentials work. It reports not_logged_in when none are available.
Finder tools use a concrete query object with a required mode field:
{
"query": {
"mode": "search"
}
}
or:
{
"query": {
"mode": "by_ids",
"ids": [123]
}
}
by_ids mode requires IDs and ignores stray search filters so retry calls remain
robust when an agent carries over defaults from schema discovery.
For simpleshop_find_documents, omitting document_types defaults to
settlement/accounting documents used for payment reconciliation. Pass
document_types: ["order"] explicitly for order workflows.
Paid-date search uses paid_from and paid_to, which map to SimpleShop's
date_paid filter expression; pass the same date to both fields for an exact
paid day.
Document results include normalized payment_instructions for intended
receiving-account details and document paid state. They do not include matched
bank transaction evidence.
See TOOLS.md for full schemas, examples, cursor behavior, and privacy controls. The design rationale is in DESIGN.md.
Normal document and sales responses redact customer/buyer PII by default.
Set include_customer_pii: true only when the caller actually needs names,
emails, phone numbers, addresses, company IDs, VAT IDs, custom sales fields, raw
document payloads, or raw CSV exports.
Raw fields are guarded:
include_raw requires include_customer_pii: true.include_raw_csv requires include_customer_pii: true.simpleshop_get_product_sales supports max_sales_rows, total_rows,
returned_rows, and truncated for bounded exports.payment_instructions.The project currently pins:
fastmcp[apps]==3.3.0httpx==0.28.1keyring>=25.0,<26pydantic==2.13.4pydantic-settings==2.14.1Using mise:
mise install
mise run sync
Using uv directly:
uv sync --locked
The preferred path is runtime login through the simpleshop_login MCP tool.
Use mode: "auto" unless you need to force direct, prefab, or web.
After successful validation, credentials are stored locally and loaded on future
starts in this order:
SIMPLESHOP_LOGIN / SIMPLESHOP_API_KEY environment variablessimpleshop-mcp:<scope-id>, accounts login and api_key${XDG_CONFIG_HOME:-$HOME/.config}/simpleshop-mcp/scopes/<scope-id>/credentials.envscope-id is derived from the canonical server process cwd, so credentials
are isolated per MCP cwd. Legacy unscoped stores such as
${XDG_CONFIG_HOME:-$HOME/.config}/simpleshop-mcp/credentials.env are not read.
For headless clients, pre-seed credentials through a local .env, environment
variables, or the credentials file. To create a local .env:
cp .env.example .env
Credential format:
[email protected]
SIMPLESHOP_API_KEY=replace-with-api-key
Optional:
SIMPLESHOP_BASE_URL=https://api.simpleshop.cz/2.0/
SIMPLESHOP_TIMEOUT_SECONDS=30
Do not commit .env or real API credentials.
The plugin's MCP server config lives inline in
.claude-plugin/plugin.jsonand usesuvx --from ${CLAUDE_PLUGIN_ROOT} simpleshop-mcp. No.mcp.jsonis committed at the repo root, so workspace-mode Claude Code sessions in this directory do not try to launch the server. Run it with one of the commands below instead.
Run the MCP server over stdio:
uv run --locked simpleshop-mcp
With the installed script:
uv run --locked simpleshop-mcp
Run directly from GitHub with uvx:
[email protected] \
SIMPLESHOP_API_KEY=replace-with-api-key \
uvx --from git+https://github.com/mikz/simpleshop-mcp.git simpleshop-mcp
For local development with FastMCP reload:
mise run mcp
Example MCP server config:
[mcp_servers.simpleshop]
command = "uv"
args = ["run", "--locked", "simpleshop-mcp"]
cwd = "/path/to/simpleshop-mcp"
If you use mise:
[mcp_servers.simpleshop]
command = "mise"
args = ["run", "mcp"]
cwd = "/path/to/simpleshop-mcp"
Run from GitHub without cloning:
[mcp_servers.simpleshop]
command = "uvx"
args = ["--from", "git+https://github.com/mikz/simpleshop-mcp.git", "simpleshop-mcp"]
Pass credentials through your MCP host environment, not through committed config.
Run tests:
uv run --locked pytest
Run lint:
uv run --locked ruff check .
Check formatting on touched files:
uv run --locked ruff format --check src tests
Live smoke tests are intentionally opt-in because they use real SimpleShop credentials and may expose account data in local logs if run carelessly. See E2E.md.
src/
client.py SimpleShop HTTP client
models.py Pydantic models for normalized and raw API data
normalization.py Document normalization helpers
server.py FastMCP server and exposed tools
DESIGN.md Tool design rationale
TOOLS.md Tool reference and examples
E2E.md Live smoke-test guidance
tests/ Offline unit and contract tests
MIT. See LICENSE.
Выполни в терминале:
claude mcp add simpleshop-mcp -- npx