UNPKG

create-mcp-i-app

Version:

Bootstrap MCP applications with identity features (temporary - use create-mcpi-app after Oct 7)

236 lines (169 loc) 7.81 kB
<div align="center"> <a href="https://github.com/modelcontextprotocol-identity/xmcp-i"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/modelcontextprotocol-identity/xmcp-i/main/assets/mcp-i-logo-dark.png"> <img alt="MCP-I logo" src="https://raw.githubusercontent.com/modelcontextprotocol-identity/xmcp-i/main/assets/mcp-i-logo-light.png" height="128"> </picture> </a> <h1>create-mcpi-app</h1> <a href="https://github.com/modelcontextprotocol-identity/xmcp-i"><img alt="MCP-I" src="https://img.shields.io/badge/MCP--I-000000.svg?style=for-the-badge&labelColor=000"></a> <a href="https://www.npmjs.com/package/@kya-os/create-mcpi-app"><img alt="NPM version" src="https://img.shields.io/npm/v/@kya-os/create-mcpi-app.svg?style=for-the-badge&labelColor=000000"></a> <a href="https://github.com/modelcontextprotocol-identity/xmcp-i/blob/main/license.md"><img alt="License" src="https://img.shields.io/npm/l/@kya-os/create-mcpi-app.svg?style=for-the-badge&labelColor=000000"></a> </div> ## Create AI Agents You Actually Own Bootstrap MCP applications with cryptographic identity built-in. Get complete control over your agent's capabilities and permissions. ## Quick Start ```bash npx create-mcpi-app@latest my-agent cd my-agent npm run dev ``` Your agent now has its own cryptographic identity! - **Generated Identity**: Ed25519 keys and DID automatically created - **Claim Ownership**: Register at knowthat.ai to claim your agent - **Secure Operation**: All responses cryptographically signed by your agent - **Permission Control**: Delegate and revoke capabilities as needed ## Command Line Options ```bash npx create-mcpi-app [agent-name] [options] ``` ## Platform Options Choose where to deploy your owned agent: - `-p, --platform <platform>` - Target deployment platform (default: "standalone") - `standalone` - Self-contained agent server - `vercel` - Vercel edge runtime with KV identity storage - `lambda` - AWS Lambda with DynamoDB identity persistence - `nextjs` - Next.js API routes with integrated identity - `express` - Express.js server with identity middleware ## General Options - `-t, --template <template>` - Agent template (default: "typescript") - `--no-install` - Skip dependency installation - `--no-git` - Skip git initialization - `--yes` - Skip interactive prompts and use defaults - `--verbose` - Detailed output during agent creation ## Examples ```bash # Create a standalone agent you can own npx create-mcpi-app my-personal-agent # Quick creation without prompts npx create-mcpi-app my-quick-agent --yes ``` ## Generated Project Structure ``` my-agent/ ├── src/ │ ├── server.ts # Main agent server with identity │ └── tools/ │ ├── index.ts # Tool exports │ └── hello.ts # Example tool with identity integration │ ├── identity-info.ts # Display agent identity information │ ├── sign-message.ts # Sign messages with agent's key │ └── verify-signature.ts # Verify ownership and signatures ├── package.json # Dependencies including xmcp-i ├── tsconfig.json # TypeScript configuration ├── .env.example # Environment variables for identity ├── .gitignore # Includes identity security rules ├── .eslintrc.json # Code quality configuration └── README.md # Agent-specific documentation ``` **Security Note**: Identity management is now handled by the `mcpi` CLI. Development identities are stored in `.mcpi/identity.json` (gitignored) and production identities use environment variables. ## Platform-Specific Features ### Vercel - Edge Identity - **Edge Runtime**: Fast cold starts with cached identity context - **KV Storage**: Secure identity persistence with Vercel KV - **Environment**: Automatic identity configuration via environment variables - **Zero Config**: Deploy with `vercel --prod` and identity works immediately ### AWS Lambda - Serverless Identity - **Cold Start Optimized**: Minimal initialization time with identity caching - **DynamoDB**: Secure, scalable identity storage with DynamoDB - **IAM Policies**: Pre-configured identity permissions and access control - **Serverless**: Ready-to-deploy serverless framework configuration ### Next.js - Full-Stack Identity - **API Routes**: Identity-enabled API endpoints with automatic verification - **SSR Support**: Server-side identity rendering and ownership verification - **Middleware**: Request-level identity verification and permission checking - **Client Integration**: Full-stack identity features for complete applications ### Express - Identity Middleware - **Middleware Stack**: Identity verification middleware for existing apps - **Flexible Routing**: Identity-aware route handlers and permission checking - **Production Ready**: Battle-tested middleware for production workloads - **Custom Auth**: Extensible identity providers and authentication flows ### Standalone - **File-based Persistence**: Local identity storage - **Self-contained Deployment**: No external dependencies - **Docker Ready**: Containerized deployment support - **Process Management**: PM2 and systemd configurations ## Adding to Existing Projects For existing Node.js/TypeScript projects, use the MCP-I CLI: ```bash npm install -g @kya-os/cli mcpi init ``` This automatically detects your framework (Next.js, Express, or standalone) and adds identity features without disrupting your existing codebase. ## Getting Started with MCP-I ### Step 1: Install MCP-I ```bash cd my-existing-agent npm install @kya-os/mcp-i ``` ### Step 2: Generate Identity ```bash # Install CLI globally npm install -g @kya-os/cli # Initialize identity (development) mcpi init # Check identity status mcpi check ``` ### Step 3: Integrate Identity ```javascript import { enableMCPIdentity } from "@kya-os/mcp-i"; const server = await enableMCPIdentity({ name: "my-agent", description: "My AI agent with identity" }); ``` ## Troubleshooting ### Common Issues #### Identity Generation Fails ```bash # Regenerate identity manually mcpi rotate --force mcpi init ``` #### Platform Detection Issues ```bash # Force platform selection with verbose output npx create-mcpi-app my-agent --platform vercel --verbose ``` #### Dependencies Issues ```bash # Skip install and run manually npx create-mcpi-app my-agent --no-install cd my-agent && npm install ``` #### Identity File Missing ```bash # Ensure identity exists before starting npm run init npm run dev ``` ### Debug Mode ```bash # Enable verbose logging for troubleshooting npx create-mcpi-app my-agent --verbose # Check generated files without installation npx create-mcpi-app my-agent --no-install --verbose ``` ## Next Steps After creating your agent: 1. **Start Development**: `npm run dev` to start your agent locally 2. **View Your Identity**: Run `mcpi check` to see your agent's DID 3. **Learn More**: Read the full [MCP-I documentation](https://github.com/modelcontextprotocol-identity/xmcp-i) for advanced features 4. **Deploy**: Use platform-specific deployment guides in the MCP-I repo ## Learn More - [MCP-I Documentation](https://github.com/modelcontextprotocol-identity/xmcp-i) - Core framework and advanced features - [Model Context Protocol](https://modelcontextprotocol.io) - Core protocol specification - [KYA-OS](https://kya-os.com) - Learn more about the KYA-OS ecosystem ## License This project is licensed under the MIT License - see the [LICENSE](https://github.com/modelcontextprotocol-identity/xmcp-i/blob/main/license.md) file for details.