Status: Under Development
effect-mcp
is a TypeScript library designed to implement Model Context Protocol (MCP) transports using the Effect framework. Our mission is to develop a robust and flexible MCP transport library with a clear, extensible architecture and practical documentation.
We aim to provide:
- Transport Agnostic Architecture: Allow developers to define MCP servers independent of the underlying transport.
- Comprehensive Documentation: Clear guidelines and examples for users and contributors.
effect-mcp
will enable creating transport-agnostic MCP servers. Developers will be able to plug in different transport mechanisms based on their application's needs:
- StdioTransport: Can be integrated into an existing
@effect/cli
application - SseTransport: Can be added to an existing HTTP API.
- JsonRpc Messaging
- Session Management
- SseTransport
- StdioTransport
- Tools using AiToolkit
- Prompts using PromptKit
- Resources using ResourceKit
-
listChanged
support for capabilities
While the project is still in development, you can set up the development environment to explore and contribute:
- Clone the Repository:
git clone https://github.com/jpowersdev/effect-mcp.git
- Navigate to the Project Directory:
cd effect-mcp
- Install Dependencies:
pnpm install
We welcome contributions! Here's how you can get involved:
- Review Open Issues: Check the issue tracker for tasks and feature requests.
- Fork the Repository: Click the 'Fork' button at the top right of the repository page.
- Create a New Branch: Use a descriptive name for your branch.
git checkout -b feature/your-feature-name
- Make Your Changes: Implement your feature or fix.
- Commit Your Changes: Write clear, concise commit messages.
git commit -m 'Add feature: your feature description'
- Push to Your Fork:
git push origin feature/your-feature-name
- Submit a Pull Request: Navigate to the original repository and create a pull request from your forked branch.
Note: Please adhere to the project's coding standards and include relevant tests for your contributions.
This project is licensed under the MIT License. See the LICENSE file for details.
For questions or further information, please open an issue on the issue tracker.