- Notifications
You must be signed in to change notification settings - Fork113
Desktop Extensions: One-click local MCP server installation in desktop apps
License
anthropics/mcpb
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
⚠️ IMPORTANT NOTICE: This project is being renamed from DXT (Desktop Extensions) to MCPB (MCP Bundles)If you're looking for the DXT tools, they have been renamed to MCPB. Please update your dependencies and tooling:
dxt
CLI is nowmcpb
.dxt
files are now.mcpb
files@anthropic-ai/dxt
package will be moved to@anthropic-ai/mcpb
MCP Bundles (.mcpb
) are zip archives containing a local MCP server and amanifest.json
that describes the server and its capabilities. The format is spiritually similar to Chrome extensions (.crx
) or VS Code extensions (.vsix
), enabling end users to install local MCP servers with a single click.
This repository provides three components: The bundle specification inMANIFEST.md, a CLI tool for creating bundles (seeCLI.md), and the code used by Claude for macOS and Windows to load and verify MCPB bundles (src/index.ts).
- For developers of local MCP servers, we aim to make distribution and installation of said servers convenient
- For developers of apps supporting local MCP servers, we aim to make it easy to add support for MCPB bundles
Claude for macOS and Windows uses the code in this repository to enable single-click installation of local MCP servers, including a number of end user-friendly features - such as automatic updates, easy configuration of MCP servers and the variables and parameters they need, and a curated directory. We are committed to the open ecosystem around MCP servers and believe that its ability to be universally adopted by multiple applications and services has benefits developers aiming to connect AI tools to other apps and services. Consequently, we're open-sourcing the MCP Bundle specification, toolchain, and the schemas and key functions used by Claude for macOS and Windows to implement its own support of MCP Bundles. It is our hope that themcpb
format doesn't just make local MCP servers more portable for Claude, but other AI desktop applications, too.
At the core, MCPB are simple zip files containing your entire MCP server and amanifest.json
. Consequently, turning a local MCP server into a bundle is straightforward: You just have to put all your required files in a folder, create amanifest.json
, and then create an archive.
To make this process easier, this package offers a CLI that helps you with the creation of both themanifest.json
and the final.mcpb
file. To install it, run:
npm install -g @anthropic-ai/mcpb
- In a folder containing your local MCP server, run
mcpb init
. This command will guide you through the creation of amanifest.json
. - Run
mcpb pack
to create amcpb
file. - Now, any app implementing support for MCPB can run your local MCP server. As an example, open the file with Claude for macOS and Windows to show an installation dialog.
You can find the full spec for themanifest.json
and all its mandatory and optional fields inMANIFEST.md. Examples for bundles can be found inexamples.
AI tools like Claude Code are particularly good at creating MCP bundles when informed about the spec. When prompting an AI coding tool to build a bundle, briefly explain what your bundle aims to do - then add the following context to your instructions.
I want to build this as a MCP Bundle, abbreviated as "MCPB". Please follow these steps:
- Read the specifications thoroughly:
- https://github.com/anthropics/mcpb/blob/main/README.md - MCPB architecture overview, capabilities, and integrationpatterns
- https://github.com/anthropics/mcpb/blob/main/MANIFEST.md - Complete bundle manifest structure and field definitions
- https://github.com/anthropics/mcpb/tree/main/examples - Reference implementations including a "Hello World" example
- Create a proper bundle structure:
- Generate a valid manifest.json following the MANIFEST.md spec
- Implement an MCP server using @modelcontextprotocol/sdk with proper tool definitions
- Include proper error handling, security measures, and timeout management
- Follow best development practices:
- Implement proper MCP protocol communication via stdio transport
- Structure tools with clear schemas, validation, and consistent JSON responses
- Make use of the fact that this bundle will be running locally
- Add appropriate logging and debugging capabilities
- Include proper documentation and setup instructions
- Test considerations:
- Validate that all tool calls return properly structured responses
- Verify manifest loads correctly and host integration works
Generate complete, production-ready code that can be immediately tested. Focus on defensive programming, clear error messages, and following the exact MCPB specifications to ensure compatibility with the ecosystem.
Amanifest.json
is the only required file.
bundle.mcpb (ZIP file)├── manifest.json # Required: Bundle metadata and configuration├── server/ # Server files│ └── index.js # Main entry point├── node_modules/ # Bundled dependencies├── package.json # Optional: NPM package definition├── icon.png # Optional: Bundle icon└── assets/ # Optional: Additional assets
bundle.mcpb (ZIP file)├── manifest.json # Required: Bundle metadata and configuration├── server/ # Server files│ ├── main.py # Main entry point│ └── utils.py # Additional modules├── lib/ # Bundled Python packages├── requirements.txt # Optional: Python dependencies list└── icon.png # Optional: Bundle icon
bundle.mcpb (ZIP file)├── manifest.json # Required: Bundle metadata and configuration├── server/ # Server files│ ├── my-server # Unix executable│ ├── my-server.exe # Windows executable└── icon.png # Optional: Bundle icon
We recommend implementing MCP servers in Node.js rather than Python to reduce installation friction. Node.js ships with Claude for macOS and Windows, which means your bundle will work out-of-the-box for users without requiring them to install additional Python runtimes (or you to package them manually).
Python Bundles:
- Bundle all required packages in
server/lib/
directory - OR bundle a complete virtual environment in
server/venv/
- Use tools like
pip-tools
,poetry
, orpipenv
to create reproducible bundles - Set
PYTHONPATH
to include bundled packages viamcp_config.env
Node.js Bundles:
- Run
npm install --production
to createnode_modules
- Bundle the entire
node_modules
directory with your bundle - Use
npm ci
oryarn install --frozen-lockfile
for reproducible builds - Server entry point specified in manifest.json's
server.entry_point
Binary Bundles:
- Static linking preferred for maximum compatibility
- Include all required shared libraries if dynamic linking used
- Test on clean systems without development tools
We welcome contributions! Please see ourContributing Guide for details.
# Clone the repositorygit clone https://github.com/anthropics/mcpb.gitcd mcpb# Install dependenciesnpm install# Build the projectnpm run build# Run testsnpmtest
- Update version in
package.json
- Create a pull request with version bump
- After merge, create a GitHub release
- Package will be automatically published to npm
This project is licensed under the MIT License - see theLICENSE file for details.
About
Desktop Extensions: One-click local MCP server installation in desktop apps
Resources
License
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Packages0
Uh oh!
There was an error while loading.Please reload this page.
Contributors15
Uh oh!
There was an error while loading.Please reload this page.