workday-mcp-reference
A vendor-neutral reference implementation of a Workday MCP server that enables integration with Workday for employee data, compensation, benefits, time off, org info, inbox tasks, admin operations, and headcount management through natural language.
README
workday-mcp-reference
A vendor-neutral, clean-room reference implementation of a Workday MCP server. It reproduces the architecture of a production Workday Model Context Protocol server — OAuth broker, opaque session tokens with silent refresh, a REST + SOAP Workday client, regex SOAP parsing, text/HTML formatters, and per-tool gating — without any company-specific data. Use it as a starting point for your own Workday MCP integration.
Stack
- Python 3.11+, modern typing, absolute imports.
- MCP: official
mcpSDKFastMCP, streamable-HTTP transport. - HTTP:
requests(sharedSession+ retry on idempotent verbs only). - Logging: stdlib
logging. Metrics: a no-opMetricsprotocol (inject your own). - Tracing: optional OpenTelemetry, gated on
OTEL_EXPORTER_OTLP_ENDPOINT. - Config:
os.environ+python-dotenv.
Quick start
python -m venv .venv && source .venv/bin/activate
pip install -e ".[dev]" # add ,otel,redis as needed
cp .env.example .env # fill in your tenant + OAuth client
workday-mcp-reference # serves streamable-HTTP on :8000/mcp
How auth works
- An MCP client calls
/mcpwith no valid bearer → the server returns401+WWW-Authenticatepointing at/.well-known/oauth-protected-resource. - The client discovers the authorization server (RFC 8414), optionally registers
(RFC 7591), then opens
/authorize→ the server 302s the user to Workday. - Workday redirects to
/callback?code=…; the server exchanges the code, resolves the user email, stores the Workday tokens under an opaque UUID, and returns that UUID. The client uses the UUID as its bearer thereafter. - Each tool call resolves the live Workday token from the store, refreshing silently when it is within 5 minutes of expiry.
Layout
src/workday_mcp_reference/
config.py environment-driven configuration
metrics.py Metrics protocol + NoopMetrics
server.py FastMCP + Bearer gate + OAuth/health routes + main()
auth/
token_store.py opaque-id → Workday tokens, silent refresh
oauth.py authorize/callback broker + discovery metadata
workday/
client.py WorkdayClient (REST + SOAP), uniform envelope
parsers.py regex SOAP parsing (no lxml)
formatters.py text + optional HTML artifacts
tools/
__init__.py register_all + get_client/resolve_me_wid helpers
me.py exemplar tool module (workday_me)
pay.py compensation + one-time payment (REST + SOAP)
benefits.py enrollments, elections, total rewards
time.py time off: scheduled, balance, eligible types, request
org.py manager, reports, org chart, search, lookup
inbox.py inbox tasks: list, approve, deny
admin.py job profiles, pay groups, hire steps, BP status
headcount.py open positions, approvals, position detail (RaaS/WQL)
The eight category tools each take an action argument and dispatch to one
implementation — mirroring how a production server keeps the MCP tool surface
small. headcount.py depends on tenant-specific RaaS reports and WQL fields, so
its report names and field mappings are driven entirely by env config (see
.env.example); the other modules use standard Workday REST/SOAP APIs.
Adding a tool module
Copy tools/me.py. Expose def register(mcp: FastMCP) -> None, define your
@mcp.tool() functions inside it, and call get_client() / resolve_me_wid(client)
— never read tokens directly. Add your module name to _TOOL_MODULES in
tools/__init__.py.
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.