Skip to main content

Open-source Model Context Protocol server for PrismHR โ€” PEO workflow tools + Microsoft 365 connectors for Claude and other MCP-aware agents.

Project description

MCP Registry

The MCP registry provides MCP clients with a list of MCP servers, like an app store for MCP servers.

๐Ÿ“ค Publish my MCP server | โšก๏ธ Live API docs | ๐Ÿ‘€ Ecosystem vision | ๐Ÿ“– Full documentation

Development Status

2025-10-24 update: The Registry API has entered an API freeze (v0.1) ๐ŸŽ‰. For the next month or more, the API will remain stable with no breaking changes, allowing integrators to confidently implement support. This freeze applies to v0.1 while development continues on v0. We'll use this period to validate the API in real-world integrations and gather feedback to shape v1 for general availability. Thank you to everyone for your contributions and patienceโ€”your involvement has been key to getting us here!

2025-09-08 update: The registry has launched in preview ๐ŸŽ‰ (announcement blog post). While the system is now more stable, this is still a preview release and breaking changes or data resets may occur. A general availability (GA) release will follow later. We'd love your feedback in GitHub discussions or in the #registry-dev Discord (joining details here).

Current key maintainers:

Contributing

We use multiple channels for collaboration - see modelcontextprotocol.io/community/communication.

Often (but not always) ideas flow through this pipeline:

  • Discord - Real-time community discussions
  • Discussions - Propose and discuss product/technical requirements
  • Issues - Track well-scoped technical work
  • Pull Requests - Contribute work towards issues

Quick start:

Pre-requisites

Running the server

# Start full development environment
make dev-compose

This starts the registry at localhost:8080 with PostgreSQL. The database uses ephemeral storage and is reset each time you restart the containers, ensuring a clean state for development and testing.

Note: The registry uses ko to build container images. The make dev-compose command automatically builds the registry image with ko and loads it into your local Docker daemon before starting the services.

By default, the registry seeds from the production API with a filtered subset of servers (to keep startup fast). This ensures your local environment mirrors production behavior and all seed data passes validation. For offline development you can seed from a file without validation with MCP_REGISTRY_SEED_FROM=data/seed.json MCP_REGISTRY_ENABLE_REGISTRY_VALIDATION=false make dev-compose.

The setup can be configured with environment variables in docker-compose.yml - see .env.example for a reference.

Alternative: Running a pre-built Docker image

Pre-built Docker images are automatically published to GitHub Container Registry:

# Run latest stable release
docker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:latest

# Run latest from main branch (continuous deployment)
docker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:main

# Run specific release version
docker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:v1.0.0

# Run development build from main branch
docker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:main-20250906-abc123d

Available tags:

  • Releases: latest, v1.0.0, v1.1.0, etc.
  • Continuous: main (latest main branch build)
  • Development: main-<date>-<sha> (specific commit builds)

Publishing a server

To publish a server, we've built a simple CLI. You can use it with:

# Build the latest CLI
make publisher

# Use it!
./bin/mcp-publisher --help

See the publisher guide for more details.

Other commands

# Run lint, unit tests and integration tests
make check

There are also a few more helpful commands for development. Run make help to learn more, or look in Makefile.

Architecture

Project Structure

โ”œโ”€โ”€ cmd/                     # Application entry points
โ”‚   โ””โ”€โ”€ publisher/           # Server publishing tool
โ”œโ”€โ”€ data/                    # Seed data
โ”œโ”€โ”€ deploy/                  # Deployment configuration (Pulumi)
โ”œโ”€โ”€ docs/                    # Documentation
โ”œโ”€โ”€ internal/                # Private application code
โ”‚   โ”œโ”€โ”€ api/                 # HTTP handlers and routing
โ”‚   โ”œโ”€โ”€ auth/                # Authentication (GitHub OAuth, JWT, namespace blocking)
โ”‚   โ”œโ”€โ”€ config/              # Configuration management
โ”‚   โ”œโ”€โ”€ database/            # Data persistence (PostgreSQL)
โ”‚   โ”œโ”€โ”€ service/             # Business logic
โ”‚   โ”œโ”€โ”€ telemetry/           # Metrics and monitoring
โ”‚   โ””โ”€โ”€ validators/          # Input validation
โ”œโ”€โ”€ pkg/                     # Public packages
โ”‚   โ”œโ”€โ”€ api/                 # API types and structures
โ”‚   โ”‚   โ””โ”€โ”€ v0/              # Version 0 API types
โ”‚   โ””โ”€โ”€ model/               # Data models for server.json
โ”œโ”€โ”€ scripts/                 # Development and testing scripts
โ”œโ”€โ”€ tests/                   # Integration tests
โ””โ”€โ”€ tools/                   # CLI tools and utilities
    โ””โ”€โ”€ validate-*.sh        # Schema validation tools

Authentication

Publishing supports multiple authentication methods:

  • GitHub OAuth - For publishing by logging into GitHub
  • GitHub OIDC - For publishing from GitHub Actions
  • DNS verification - For proving ownership of a domain and its subdomains
  • HTTP verification - For proving ownership of a domain

The registry validates namespace ownership when publishing. E.g. to publish...:

  • io.github.domdomegg/my-cool-mcp you must login to GitHub as domdomegg, or be in a GitHub Action on domdomegg's repos
  • me.adamjones/my-cool-mcp you must prove ownership of adamjones.me via DNS or HTTP challenge

Community Projects

Check out community projects to explore notable registry-related work created by the community.

More documentation

See the documentation for more details if your question has not been answered here!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

prismhr_mcp-0.1.0.dev4.tar.gz (41.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

prismhr_mcp-0.1.0.dev4-py3-none-any.whl (52.7 kB view details)

Uploaded Python 3

File details

Details for the file prismhr_mcp-0.1.0.dev4.tar.gz.

File metadata

  • Download URL: prismhr_mcp-0.1.0.dev4.tar.gz
  • Upload date:
  • Size: 41.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for prismhr_mcp-0.1.0.dev4.tar.gz
Algorithm Hash digest
SHA256 6687e08aa20ef3a6a112491715dd22e187b269b2e1174e1f73984833626b9d9c
MD5 55b70f025675ba0b39de05fc332147e9
BLAKE2b-256 7b4c8573434ecdbed96eaa7c21f174b598320c2a8f9a96b94795b9ca3fb0eddf

See more details on using hashes here.

Provenance

The following attestation bundles were made for prismhr_mcp-0.1.0.dev4.tar.gz:

Publisher: publish.yml on nikulk2992-jpg/prismhr-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file prismhr_mcp-0.1.0.dev4-py3-none-any.whl.

File metadata

File hashes

Hashes for prismhr_mcp-0.1.0.dev4-py3-none-any.whl
Algorithm Hash digest
SHA256 3f9f8f7fb5ca9e691f1489acab193dd6445aa44109b38d7ae8c846bbbdafe9f6
MD5 19292de385aebfe5f3b4cd0ad481a362
BLAKE2b-256 bbd0ca94607ffb17eda9323d47d1e3d6973e8351654f097ab0ffe3cc35b1bf53

See more details on using hashes here.

Provenance

The following attestation bundles were made for prismhr_mcp-0.1.0.dev4-py3-none-any.whl:

Publisher: publish.yml on nikulk2992-jpg/prismhr-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page