Prism
Multi-server MCP tool bridge that exposes banking, email, calendar, and custom API tools for AI clients via the Model Context Protocol.
README
Prism
Multi-server MCP tool bridge — expose banking, email, calendar, and custom API tools over the Model Context Protocol.
Prism lets you define multiple servers, each with its own bearer token and set of accounts. AI clients (Cursor, Claude Desktop, etc.) connect to a server's MCP endpoint and get access to only the tools and accounts that server is configured for.
Architecture
┌─────────────┐ ┌─────────────┐
│ AI Client │ │ AI Client │
│ (Cursor) │ │ (Claude) │
└──────┬───────┘ └──────┬───────┘
│ Bearer A │ Bearer B
▼ ▼
┌──────────────────────────────────┐
│ Prism │
│ /mcp/server-a /mcp/server-b │
│ ┌──────────┐ ┌──────────┐ │
│ │ 9 accts │ │ 3 accts │ │
│ │ 17 tools │ │ 11 tools │ │
│ └──────────┘ └──────────┘ │
└────┬────┬────┬────┬─────────────┘
│ │ │ │
▼ ▼ ▼ ▼
bunq IMAP Cal Cyans
Each server exposes the same tool types but scoped to its own accounts. A personal server sees all your email accounts; a shared server only sees the shared mailbox.
Tools (24)
| Category | Tool | Description |
|---|---|---|
| bunq | bunq_list_accounts |
List configured bank accounts |
bunq_list_transactions |
List transactions with date/amount filters | |
bunq_get_transaction |
Get full transaction details | |
bunq_get_transaction_notes |
Get notes and attachments on a transaction | |
email_list_accounts |
List configured email accounts | |
email_list_folders |
List mailbox folders with unread counts | |
email_search |
Search emails by sender, subject, date, flags | |
email_get_messages |
Fetch one or many messages (same-folder or folder+uid combos) | |
email_send |
Send a new message or reply (markdown, threaded, saved to Sent) | |
| Calendar | calendar_list_calendars |
List configured ICS calendars |
calendar_list_events |
List upcoming events with date range filter | |
calendar_get_event |
Get event details by UID | |
| Cyans | cyans_get_open_topics |
Get open topics for a user |
cyans_get_topic_details |
Get full topic with posts | |
cyans_search_topics |
Search topics by subject | |
cyans_add_post |
Add a post to a topic | |
| Picnic | picnic_list_accounts |
List configured Picnic accounts |
picnic_search_products |
Search grocery products by name | |
picnic_get_cart |
Get the current shopping cart | |
picnic_add_to_cart |
Add a product to the cart | |
picnic_remove_from_cart |
Remove a product from the cart | |
picnic_list_deliveries |
List past and upcoming deliveries (optional state filter) | |
picnic_get_delivery |
Get full details of a single delivery | |
| Utility | day_name |
Get day-of-week for a date |
sum |
Sum an array of numbers |
Quick Start
1. Clone and install
git clone https://github.com/YOUR_ORG/prism.git
cd prism
composer install
npm install && npx encore dev
2. Configure
Copy the example config and edit it:
cp prism.config.yaml.example prism.config.yaml
servers:
my-server:
label: "My Personal Server"
bearer_token: "generate-a-random-token"
accounts:
my-email:
type: email
label: "Personal Email"
imap:
host: "imap.example.com"
port: 993
encryption: ssl
username: "me@example.com"
password: "app-password"
validate_cert: true
smtp:
host: "smtp.example.com"
port: 465
encryption: ssl
identity:
email: "user@example.com"
name: "Example User"
my-picnic:
type: picnic
label: "Picnic NL"
username: "me@example.com"
password: "your-picnic-password"
country_code: "nl"
Set admin credentials:
# .env.local
APP_AUTH_USER=admin
APP_AUTH_PASSWORD=a-secure-password
3. Run with Docker
docker compose up -d
The app is served via Traefik. Configure the hostname in docker-compose.yml.
4. Connect your AI client
Add to your Cursor .mcp.json:
{
"mcpServers": {
"prism": {
"url": "https://your-host/mcp/my-server",
"headers": {
"Authorization": "Bearer generate-a-random-token"
}
}
}
}
Admin UI
Prism includes a built-in admin dashboard at /admin with:
- Server list — overview of all configured servers with account/tool counts
- Configuration tab — connection details and
.mcp.jsonsnippet - Accounts tab — accounts grouped by type
- Tools tab — all available tools for the server, linking to detail pages
- Tool detail — input schema, parameters table, and an interactive Try It panel for executing tools with YAML input/output
Each tab and tool detail page has its own URL for bookmarking.
Account Types
| Type | Config Keys | What It Connects To |
|---|---|---|
bunq |
api_key, environment, monetary_account_id |
bunq banking API |
email |
imap.*, smtp.*, identity.* |
Any IMAP mailbox + SMTP relay (read, search, send, save-to-Sent) |
calendar |
ics_url, summary |
Any ICS/iCal feed (Google Calendar, etc.) |
cyans |
dsn, username |
Cyans topic tracking API |
picnic |
username, password, country_code |
Picnic grocery delivery (unofficial API) |
Tech Stack
- PHP 8.2+ / Symfony 7.2
- Tailwind CSS via Webpack Encore
- Docker with Traefik reverse proxy
- MCP Protocol v2024-11-05 (JSON-RPC over HTTP with Bearer auth)
License
MIT
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.