poemcp

poemcpはRustで書かれたプロジェクトで、詩の生成や解析に特化した機能を提供します。主に開発者向けに設計されており、詩の構造やスタイルを理解し、生成するためのツールとして利用されることを目指しています。Rustの特性を活かし、高速かつ安全な実行が可能です。

GitHubスター

0

ユーザー評価

未評価

お気に入り

0

閲覧数

23

フォーク

0

イシュー

0

README
MCP Server with Combined Tools

This project implements a Model Context Protocol (MCP) server in Rust using the poem framework. The server provides multiple tools for managing counters, adding numbers, validating IP addresses, and checking if an IP is in a CIDR range. The tools are exposed via a Server-Sent Events (SSE) endpoint, allowing clients to interact with the server in real-time.

Features
  • Counter:

    • Increment, decrement, and get the current value of a counter.
  • Adder:

    • Add two integers together.
  • IP Validator:

    • Validate if a given string is a valid IPv4 address.
  • CIDR Checker:

    • Check if an IP address is within a specified CIDR range.
Endpoints
  • /sse: A Server-Sent Events (SSE) endpoint that exposes the tools in real-time.
Tools
  • Increment: Increment the counter by 1.
  • Decrement: Decrement the counter by 1.
  • Get Value: Retrieve the current counter value.
  • Add: Add two numbers together.
  • Is Valid IPv4: Check if a string is a valid IPv4 address.
  • Is IP in CIDR: Check if an IP address is within a CIDR range.
Setup
Requirements
  • Rust 1.60 or higher
  • Cargo (Rust's package manager and build system)
Installation
  1. Clone the repository:

    git clone https://github.com/yourusername/mcp-server.git
    cd mcp-server
    
  2. Build the project:

    cargo build --release
    
  3. Run the server:

    cargo run
    

The server will start and listen on http://127.0.0.1:8000.

Dependencies
  • poem: A web framework for Rust.
  • poem_mcpserver: A library for implementing MCP servers with tools and SSE endpoints.
  • tokio: Asynchronous runtime for Rust.
Example Usage

Once the server is running, you can connect to the /sse endpoint via an SSE client. Here's an example using JavaScript in the browser:

const eventSource = new EventSource('http://127.0.0.1:8000/sse');

eventSource.onmessage = function(event) {
    console.log('Received data:', event.data);
};
License

This project is licensed under the MIT License. See the LICENSE file for more details.