cpp-espace-mcp

cpp-espace-mcp

MCP server for accessing the eSpace facilities management API, enabling work orders, events, equipment, and maintenance schedule operations from within Claude conversations.

Category
Visit Server

README

cpp-espace-mcp

MCP server that gives Claude Code access to the eSpace facilities management API — work orders, events, equipment, and maintenance schedules, all callable from within a Claude conversation. Built for Catholic Parishes in Partnership (CPP) staff.


Quick Start

If you just want to get this running on your machine:

# 1. Install Node.js LTS if you don't have it
winget install OpenJS.NodeJS.LTS
# (close and reopen PowerShell)

# 2. Clone and build
mkdir $env:USERPROFILE\code -Force
cd $env:USERPROFILE\code
git clone https://github.com/norm613/cpp-espace-mcp.git
cd cpp-espace-mcp
npm install
npm run build

# 3. Get your personal API key from your eSpace profile (see section below)

# 4. Register with Claude Code (user scope — available in every project)
claude mcp add espace --scope user --env ESPACE_API_KEY=YOUR_KEY_HERE -- cmd /c npx tsx "$env:USERPROFILE\code\cpp-espace-mcp\src\index.ts"

# 5. Verify
claude mcp list
# 'espace' should show: ✓ Connected

Then relaunch Claude Code. Ask it something like "check eSpace for any open work orders at PJCC" to confirm it works.


Why Each Person Runs Their Own Instance

The eSpace API key isn't just a password — it's your identity to eSpace. Every API call this server makes is attributed to whoever owns the key. If two people share a key, both show up in the audit trail as the same person.

That's why each CPP staff member who uses Claude with eSpace needs:

  1. Their own API key, generated under their own eSpace profile
  2. Their own clone of this repo on their local machine
  3. Their own Claude Code MCP registration using their own key

There's no shared server, no multi-tenant auth. One key = one person.


Getting Your API Key

  1. Sign in to eSpace on the web as yourself.
  2. Navigate to your user profile / account settings.
  3. Find the API access / tokens section and generate a new personal API key.
  4. Copy the UUID-format string. Store it like a password — anyone with this key can make changes as you.

If you can't find where to generate a key, check with whoever administers your eSpace account.


Prerequisites Checklist

Before running the install steps, make sure you have:

  • [ ] Windows 10/11 with PowerShell
  • [ ] Node.js LTSnode --version should return a number. If not: winget install OpenJS.NodeJS.LTS, then close/reopen PowerShell so PATH updates.
  • [ ] Gitgit --version should work. If not: winget install Git.Git.
  • [ ] Claude Code CLIclaude --version should work. Already installed if you've used Claude Code before.
  • [ ] An eSpace API key (see above)

Claude Code Configuration — Details

The command in the Quick Start registers the MCP server at user scope, meaning it's available in every Claude Code project you open (not tied to a specific folder). This is the right scope for eSpace — you'll want it available in Oscar, Robin, or any other vault.

If you need to update the key later (rotation, regenerated key, etc.):

claude mcp remove espace --scope user
claude mcp add espace --scope user --env ESPACE_API_KEY=NEW_KEY -- cmd /c npx tsx "$env:USERPROFILE\code\cpp-espace-mcp\src\index.ts"

To see current status:

claude mcp get espace

Data Safety Rules (Read This)

Claude must never create, update, or delete eSpace records without your explicit confirmation first.

eSpace manages real facility work orders, events, equipment, and maintenance schedules. Unauthorized writes can create false work orders, cancel events, or corrupt maintenance records.

Before any write operation (POST / PUT / DELETE), Claude will:

  1. Stop.
  2. Show you exactly what it plans to create, modify, or delete.
  3. Wait for your explicit "yes" before proceeding.

Read-only operations (listing, getting details) are always fine — no confirmation required.

If Claude ever performs a write without asking first, that's a bug — report it.


Available Tools (29 total)

Category Tools Typical use
Work Orders get-work-order, list-work-orders, create-work-order, update-work-order, delete-work-order, get-work-order-tasks, add-work-order-task, update-work-order-task, get-work-order-costs, get-work-order-attachments, get-work-order-priorities, get-work-order-statuses "Show me all open work orders at SPE," "Create a work order for the boiler at PJCC," "What's the cost breakdown on work order 1234?"
Events get-event, list-events, get-event-occurrences, get-event-spaces "List next week's events at STC," "What spaces are booked for Holy Thursday?"
Maintenance get-maintenance, list-maintenance, get-maintenance-types, get-maintenance-spaces, get-frequency-types "Show me all scheduled maintenance coming due," "What PM frequency types are defined?"
Equipment get-equipment, list-equipment, get-equipment-types "List the HVAC equipment at SJD," "What equipment types do we track?"
Ministry / Org get-locations, get-users, get-categories, get-service-categories, get-editors, get-task-templates "List all the locations in our eSpace tenant," "Who has editor permissions?"

Full tool registration list is in src/index.ts.


Troubleshooting

claude mcp list shows eSpace as "Failed to connect"

The mcp list output doesn't include the real error. To see it, run the stdio command by hand:

$env:ESPACE_API_KEY = "your-key"
cmd /c npx tsx "$env:USERPROFILE\code\cpp-espace-mcp\src\index.ts"

Common causes:

  • Node.js not installednode --version returns nothing → winget install OpenJS.NodeJS.LTS
  • Node installed but PATH not refreshed — close and reopen PowerShell
  • Firewall blocking npmnpm install hung or failed during setup → talk to IT
  • Wrong API key — you'll see a 401 from eSpace; generate a new key and re-register
  • Repo not builtnpm run build was skipped; run it
  • File path has spaces or quotes — the path in the claude mcp add command should be wrapped in double quotes

"Add to user config" succeeded but path looks wrong (C:/ instead of /c)

If you ran claude mcp add from Git Bash, path conversion may have mangled the /c flag on cmd /c. Remove and re-add from PowerShell, not Git Bash:

claude mcp remove espace --scope user
claude mcp add espace --scope user --env ESPACE_API_KEY=YOUR_KEY -- cmd /c npx tsx "$env:USERPROFILE\code\cpp-espace-mcp\src\index.ts"

The key works for others but not me

Make sure the key is yours — generated under your eSpace profile. Keys are user-specific; another person's key won't authenticate you (and will wrongly attribute your actions).

Claude says it did something but eSpace doesn't reflect the change

  • Did Claude confirm with you first? If no confirmation prompt, the write was likely blocked (safety rule) and Claude only simulated it.
  • Is your key read-only in eSpace? Check your eSpace profile for write permissions.

I need to update types after an eSpace API change

cd $env:USERPROFILE\code\cpp-espace-mcp
git pull
npm install
npm run generate:types
npm run build

Development

npm run dev              # run with tsx (hot reload during development)
npm run build            # compile TypeScript to dist/
npm run start            # run the compiled output
npm run generate:types   # regenerate TS interfaces + Zod schemas from swagger.json

Types in src/models/ are auto-generated from swagger.json. Don't edit them manually — regenerate with npm run generate:types.

Architecture is a layered pattern:

MCP Tool Handlers (one tool per API operation)
  → eSpaceProvider (singleton orchestrator)
    → Services (WorkOrderService, EventService, MaintenanceService, etc.)
      → eSpaceClient (JWT token lifecycle)
        → HttpClient (generic HTTP with bearer token injection)

Auth flow: POST { apiKey } to /api/v2/requesttoken → receive a JWT (valid ~1 year) → include it as Authorization: Bearer <jwt> on all subsequent requests.


For Claude Sessions Working on This Repo

See CLAUDE.md — it has project-specific instructions for a Claude instance opened inside this repo (safety rules, architecture pointers, type regeneration steps).


License

Private — all rights reserved. See LICENSE.

This repository is published publicly so authorized CPP staff can clone and install it without needing a GitHub account, but the code itself is not open-source. No license is granted to copy, modify, or redistribute.

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

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.

Official
Featured