Simpro MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Simpro MCP Servershow open quotes for Acme"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Simpro MCP server
Lets an AI agent work with your Simpro account — look up quotes, jobs, customers, and the catalogue, read and update line items, and pull together figures that would normally mean clicking through several screens. You ask in plain English; the agent does the lookups and changes in Simpro for you.
It reaches every part of the Simpro API, so even if there isn't a purpose-built tool for something, the agent can still get to it.
⚠️ This tool can write and delete, not just read. It reaches the full Simpro API, including the endpoints that update and delete records. An AI agent driving it can — by mistake or by following a bad instruction — modify or destroy quotes, jobs, customers, catalogue items, and more in your live Simpro account, in bulk, with no undo. It acts with whatever permissions the key or login you give it has. Don't hand it to an agent you don't trust, don't let it run unattended against production, and give it a Simpro login/key scoped to only what it actually needs. If you want read-only safety, create a Simpro user with read-only permissions and authenticate as that user.
This software is provided "as is", without warranty of any kind, express or implied. You run it at your own risk; the authors accept no liability for any loss, damage, or changes made to your Simpro data through its use.
There are three ways to run it. Most people want the first one.
1. Install into Claude Desktop (the easy way)
No command line, no setup files. You install the .mcpb bundle from Claude Desktop's
extension settings, fill in a short form, and log in to Simpro once in your browser. After
that the agent stays signed in and you just chat.
What you need from Simpro
You authenticate with a Simpro OAuth app, which signs you in through Simpro's own login screen — the recommended way. Create one in Simpro under Setup → Integrations → API → New API Key (choose an OAuth / "Authorization Code" application), then note:
Thing | Where to find it |
Build URL | The web address you log in to, e.g. |
Company ID | Almost always |
Client ID | From the OAuth app you create. |
Client secret | From the same OAuth app. Treat it like a password. |
One important step: in your Simpro OAuth app, set the Redirect URI to
http://localhost:8237/callback. This is where Simpro sends you back after you log in. It
must match exactly. If port 8237 is already in use on your machine, pick another and set
the matching Auth redirect port on the install screen — but the registered redirect URI
must use the same port.
Installing
Download the latest
simpro-mcp-server.mcpbfile from the Releases page.In Claude Desktop, open Settings → Extensions, click Advanced settings, then Install extension (you may first need to enable developer/extension installs there). Pick the
simpro-mcp-server.mcpbfile you downloaded. An install screen appears.Fill in:
Build URL and Company ID
Authentication mode — leave on
authorization_code(the browser login).Client ID and Client secret from your Simpro OAuth app.
Leave Auth redirect port at
8237unless you registered a different one.
Click install.
Logging in (the OAuth flow)
The first time the agent uses the tool, a browser tab opens at the Simpro login screen. Log in and approve access. The tab shows "✓ Authorised" — close it and return to your chat.
That one login is all you need. The tool caches a refresh token, so it stays signed in across restarts and you won't be prompted again until that token is revoked or expires. If that ever happens, it just opens the login tab again.
That's it — start a chat and ask something like "show me open quotes for Acme" or "what's on job 4521?".
Page size is an optional setting on the install screen. Leave it at 50. It just caps how many rows come back at once so big lists don't overwhelm a single answer — the agent can always ask for more.
Other ways to authenticate
The Authentication mode field on the install screen offers three choices:
Mode | What it is | When to use |
| Browser login as you. Acts with your Simpro permissions. | Default — recommended. |
| Machine login with no user. Acts with the OAuth app's full access. | Unattended/automation where there's no person to log in. Also needs Client ID + secret; no browser step. |
| A legacy standalone API key. | Only if you can't create an OAuth app. Paste the key into the Simpro API Key field. Static keys are deprecated by Simpro. |
Keeping your credentials safe
Your client secret, refresh token, and any API key are stored by Claude Desktop and used
only to talk to your own Simpro build. Anyone with them can act in Simpro with the same
access you've granted, so don't share the .mcpb install or those values with people who
shouldn't have that access. If a credential is ever exposed, revoke the OAuth app or key in
Simpro and create a new one.
Related MCP server: ServiceTitan MCP Server
2. HTTP Proxy Mode (for a shared/hosted setup)
For teams running this on a server behind something that already handles sign-in (for example a Cowork or Copilot setup). In this mode the server holds no Simpro key of its own — each request brings its own login, attached by whatever signs your users in. The server just passes it through to Simpro.
⚠️ Not designed to be internet-facing. This mode must run behind a gateway or reverse proxy (an MCP gateway, Context Forge, or something like nginx/Traefik) that terminates TLS and authenticates users. It does no auth of its own and is not hardened for direct exposure — never publish it straight to the internet. The container intentionally isn't published on the host by default; the gateway reaches it on a private network.
To use this mode, set SIMPRO_TRANSPORT=proxy (the supplied Docker setup defaults to the
safer broker mode below). If you're deploying with Portainer or Context Forge, see
docs/deploy.md for the stack layout.
You won't set an API key here — in fact the server refuses to start if one is present, because in this mode the per-user login is the only thing that should be granting access.
Important — this mode does no checking of its own. Whatever Authorization header
arrives with a request is forwarded straight through to Simpro, untouched. The server does
not verify that the credential is valid, unexpired, or that the request came from
someone allowed to make it — Simpro is the only thing that decides whether the credential
works. That's by design: this mode assumes the layer in front of it (the gateway or sign-in
system) has already authenticated the user and attached a trustworthy header. Only run
this mode behind such a layer. If you expose it directly, anyone who can reach it can have
their header passed to Simpro as-is.
Settings
These are set as environment variables (in your .env file or by your container platform).
Setting | Required | What it does |
| yes | Set to |
| yes | Your Simpro build address, e.g. |
| no | Your company ID. Defaults to |
| no | Port the server listens on. Defaults to |
| no | Network interface to bind. Defaults to |
| no | Web path the server is reached at. Defaults to |
Do not set SIMPRO_API_KEY in this mode — the server will refuse to start.
You can also tune how much data comes back at once:
Setting | Default | What it does |
|
| Rows per page for list results when not specified. Max 250. |
|
| Largest single answer allowed before it's held back and the agent is asked to narrow the request. ~100,000 suits Claude Code; raise toward |
3. OAuth Broker Mode (for the AI agent connector)
For connecting Simpro to an AI agent as a proper connector, where each person signs in to Simpro themselves through the normal Simpro login screen — no shared key, no per-person setup file.
This is the mode the supplied Docker setup defaults to. It's the safer default: the
server authenticates users itself instead of trusting a credential handed to it from
upstream. It still belongs behind a reverse proxy that terminates TLS and routes
PUBLIC_URL to it — but the container is never the thing deciding to trust an inbound
header.
Simpro's own sign-in is an older OAuth 2.0 design that modern agent connectors won't connect to directly. This server sits in the middle and brings it up to the modern OAuth 2.1 standard they require — adding the security steps Simpro is missing while still handing off to the real Simpro login. From a user's point of view it's just "click connect, log in to Simpro." The exact steps it adds are written up in How the broker upgrades Simpro's sign-in further down.
The server sits in front of Simpro and runs the sign-in handshake. A user adds the connector in their agent, gets sent to Simpro to log in, and from then on the agent acts as that person in Simpro. Their Simpro access is sealed inside the token the agent holds; the server keeps no database of logins.
This mode needs a public web address and a Simpro OAuth app (created in Simpro under
Setup → Integrations). In that OAuth app, set the Redirect URL to your public
address followed by /callback — for example https://simpro.yourcompany.com/callback.
Settings
Set these as environment variables, on top of SIMPRO_BASE_URL (and optionally
SIMPRO_COMPANY_ID) from above.
Setting | Required | What it does |
| yes | Set to |
| yes | The public web address people reach the connector at, e.g. |
| yes | From your Simpro OAuth app. |
| yes | From your Simpro OAuth app. Keep it secret. |
| recommended | The secret used to seal each person's Simpro access inside their agent token. Generate one with |
| no | Only set if your Simpro login URL is non-standard. Otherwise worked out automatically from |
| no | Same — only set if non-standard. |
PORT, HOST, MCP_PATH, and the two page-size settings from HTTP Proxy Mode above
apply here too.
Which mode do I want?
You want to… | Use |
Use Simpro from Claude Desktop on your own machine | Install into Claude Desktop (option 1) |
Run a shared server where sign-in is handled elsewhere | HTTP Proxy Mode (option 2) |
Offer Simpro as a connector people sign in to individually | OAuth Broker Mode (option 3) |
How the broker upgrades Simpro's sign-in
This section is for the technically curious or anyone reviewing the security of the connector. You don't need it to use any of the three modes above.
Modern agent connectors only connect to authorization servers that meet the OAuth 2.1 bar. Simpro's OAuth is an older 2.0 implementation — it doesn't do PKCE, doesn't support the client identity schemes those connectors use, and hands out long-lived tokens. Rather than ask Simpro to change, the broker stands in front of it as a compliant OAuth 2.1 authorization server in its own right, and quietly relays to Simpro behind the scenes. Concretely, it adds:
PKCE (S256), enforced by us. The connecting client must send a code challenge on
/authorizeand prove it on/token; a mismatch is rejected. Simpro itself does no PKCE, so the broker is the party actually enforcing it — closing the stolen-authorization-code gap that plain 2.0 leaves open.Modern client identity — no shared secret baked into the client. The connecting client tells the broker who it is in one of two standard ways, and the broker accepts whichever a given client uses:
CIMD (client-ID-metadata-document): the client_id is a URL the broker fetches and validates per request — it must be self-referential and list the exact redirect address being used. Nothing is pre-registered. The fetch runs behind an anti-SSRF guard so that URL can't be used to probe the server's internal network.
DCR (dynamic client registration, RFC 7591): a client can
POST /registerto mint its own client_id up front. The broker advertises this endpoint in its metadata. Registration is open (no auth), so it's rate-/size-capped and evicts the oldest entries at the cap; registered clients are persisted so they survive a restart. A client may register as public (no secret) or confidential (the broker issues a secret and then requires it at the token step).
Either way, the downstream client's identity never reaches Simpro: the broker holds one fixed Simpro registration and relays under that.
Exact redirect matching. The address the client is sent back to must match the one registered, character for character — not just "starts with."
Short-lived, audience-bound tokens. The token the client receives is one the broker issues, stamped with an expiry and tied to this specific server as its audience. The real Simpro tokens are encrypted (sealed) inside it. The broker stores no tokens itself — every token is self-contained — and the refresh token it issues has a capped 30-day lifetime so a leaked one can't be replayed indefinitely.
The net effect: the agent talks to something that looks like a clean, modern OAuth 2.1 provider, the user still logs in at the genuine Simpro screen, and the weaker parts of Simpro's flow are shored up in the middle. The whole exchange is correlated in memory only for the few seconds the handshake takes, which is why this mode must run as a single instance — don't put it behind a load balancer.
Building it yourself
If you're working on the code rather than just using it:
npm install
npm run build # compile
npm test # run the unit tests
npm run build:mcpb # produce the simpro-mcp-server.mcpb install file
npm start # run it locallyThere's a unit-test suite (npm test) covering the pure, deterministic pieces — search
ranking, output formatting, line-item paths, and the auth crypto/store helpers. There's no
linter, and nothing mocks the network, so fully checking a change still means building it
and trying it against a real Simpro account. Architecture notes and the Simpro API quirks
worth knowing are in CLAUDE.md.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/ozmarks/simpro-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server