Brewman MCP Server
Wraps the Brewman Web (V7) API to read and write Brewman data (orders, outlets, stock, config) via tools, with the API token stored securely as an environment variable.
README
brewman-mcp-server
An MCP server that wraps the Brewman Web (V7) API so Claude can read and write
Brewman data through tools — without ever seeing the raw API token. Built for Flying
Tumbler as the fast read/write layer alongside the browser-driven brewman-operator
skill (which handles production, duty, ullages, containers, distribution and reports —
the things the API can't do).
The token is held as a server environment variable. It is never in code, never in chat, never logged.
What it exposes
Tools (all calls are POST to /webapi/...; the tenant id is injected automatically):
| Tool | Type | Purpose |
|---|---|---|
brewman_get_user_context |
read | Verify token + get the tenant id. Call first. |
brewman_get_reference |
read | Any config list: product_brands, stock_locations, package_types, price_lists, pricing_categories, sales_areas/codes, credit_terms, vat_codes, gl_codes, stock_groups, units_of_measure, outlet_types/ratings/sub_types, couriers, delivery_areas, collection_times, outlet_groups, suppliers_manufacturers, outlets. |
brewman_get_stock_levels |
read | Current in-stock qty per item id. |
brewman_get_stock_incoming_outgoing |
read | Incoming/outgoing totals. |
brewman_get_price_list_lines |
read | All product prices on a price list. |
brewman_evaluate_prices |
read | Price items on a list (list price + discounts). |
brewman_get_outlets_by_filter |
read | Outlets (all or by id). |
brewman_create_outlet |
write | Create a customer. |
brewman_update_outlet |
write | Update a customer. |
brewman_get_orders_by_filter |
read | Orders (header + lines) by filter. |
brewman_build_order_lines |
read | Preview an order's lines/pricing WITHOUT saving. |
brewman_create_order |
write | Create an order (Open status). |
brewman_cancel_order |
write/destructive | Cancel an order. |
brewman_get_current_posting_items |
read | What's queued for accounts posting. |
brewman_request |
advanced | Generic passthrough to ANY of the ~90 Brewman methods. |
Full API reference (Swagger): https://brewman.premiersystems.com/swagger/index.html
Setup
1. Create a dedicated Brewman API user + token
In Brewman, create a new user just for the API (so anything it creates is attributed to "API" in the UI, not to you). Generate an API token from that user's screen and note the tenant (group) id shown there.
2. Configure environment variables
Copy .env.example → .env (local) or set them in your host's project settings:
BREWMAN_API_TOKEN— the token (secret)BREWMAN_TENANT_ID— the tenant/group id- optional:
BREWMAN_BASE_URL,BREWMAN_TENANT_FIELD,TRANSPORT,PORT
3a. Deploy to Vercel (matches the FT Meta MCP setup)
npm install
vercel # link/deploy
# In the Vercel dashboard: Project → Settings → Environment Variables:
# BREWMAN_API_TOKEN, BREWMAN_TENANT_ID
vercel --prod
MCP endpoint: https://<your-app>.vercel.app/mcp (rewritten to /api/mcp).
3b. Or run anywhere as a Node service / locally
npm install
npm run build
BREWMAN_API_TOKEN=... BREWMAN_TENANT_ID=... npm start # http on :3000 -> /mcp
4. Connect it to Claude / Cowork
Add the deployed URL as a custom MCP connector (same way the FT Meta MCP is wired):
https://<your-app>.vercel.app/mcp. Then the brewman-operator skill will use these
tools for orders/outlets/stock/config and fall back to the browser for everything else.
Verify
# health check
curl https://<your-app>.vercel.app/mcp # -> {"ok":true,...}
Then from Claude, call brewman_get_user_context — it should return your user + tenant id.
Safety
- Reads are free. Writes (
create_order,create/update_outlet,cancel_order, and any write viabrewman_request) change live data exactly like the UI — the operator confirms with Patrick before calling them. - The API is BETA; schemas may change. The dedicated tools cover the common cases; use
brewman_requestwith the Swagger schema for anything else. - Not available via API (use the browser/
brewman-operatorskill): production/batches, duty & excise returns, ullages, container tracking, distribution journeys, BI reports.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.