Skip to main content

Model Context Protocol with AGP as transport

Project description

AGP-MCP Integration

Leverage AGP as a transport mechanism for MCP, enabling efficient load balancing and dynamic discovery across MCP servers.

Installation

pip install agp-mcp

Overview

AGP-MCP provides a seamless integration between AGP (Agent Gateway Protocol) and MCP (Model Context Protocol), allowing you to:

  • Create MCP servers that can be discovered and accessed through AGP
  • Connect MCP clients to servers using AGP as the transport layer
  • Handle multiple concurrent sessions
  • Leverage AGP's load balancing and service discovery capabilities

Usage

Server Setup

from agp_mcp import AGPServer
import mcp.types as types
from mcp.server.lowlevel import Server

# Create an MCP server application
app = Server("example-server")

# Define your tools
example_tool = types.Tool(
    name="example",
    description="An example tool",
    inputSchema={
        "type": "object",
        "required": ["url"],
        "properties": {
            "url": {
                "type": "string",
                "description": "example URL input parameter",
            }
        },
    },
)

@app.list_tools()
async def list_tools() -> list[types.Tool]:
    return [example_tool]

# Configure and start the AGP server
config = {
    "endpoint": "http://127.0.0.1:12345",
    "tls": {
        "insecure": True,
    },
}

async with AGPServer(config, "org", "namespace", "server-name") as agp_server:
    # Handle incoming sessions
    async for session in agp_server:
        async with agp_server.new_streams(session) as streams:
            await app.run(
                streams[0],
                streams[1],
                app.create_initialization_options(),
            )

Client Setup

from agp_mcp import AGPClient

# Configure the client
config = {
    "endpoint": "http://127.0.0.1:12345",
    "tls": {
        "insecure": True,
    },
}

async with AGPClient(
    config,
    "org",
    "namespace",
    "client-id",
    "org",
    "namespace",
    "server-name"
) as client:
    async with client.to_mcp_session() as mcp_session:
        # Initialize the session
        await mcp_session.initialize()

        # List available tools
        tools = await mcp_session.list_tools()
        print(f"Available tools: {tools}")

Features

  • Automatic Reconnection: AGP automatically handles reconnection to the server if the connection is lost
  • Concurrent Sessions: Support for multiple concurrent sessions with proper resource management
  • TLS Support: Built-in support for secure TLS connections
  • Dynamic Discovery: Leverage AGP's service discovery capabilities to find and connect to MCP servers
  • Load Balancing: Utilize AGP's load balancing features for optimal server distribution

Configuration

The configuration object supports the following options:

config = {
    "endpoint": "http://127.0.0.1:12345",  # Server endpoint
    "tls": {
        "insecure": True,  # Set to False for production
        # Add other TLS options as needed
    },
}

Error Handling

The library provides comprehensive error handling and logging. All operations are wrapped in try-except blocks to ensure proper cleanup of resources.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

Apache-2.0

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

agp_mcp-0.1.5.tar.gz (9.4 kB view details)

Uploaded Source

Built Distribution

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

agp_mcp-0.1.5-py3-none-any.whl (8.7 kB view details)

Uploaded Python 3

File details

Details for the file agp_mcp-0.1.5.tar.gz.

File metadata

  • Download URL: agp_mcp-0.1.5.tar.gz
  • Upload date:
  • Size: 9.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for agp_mcp-0.1.5.tar.gz
Algorithm Hash digest
SHA256 31905b9ce55bdb823ff9bb8ed2874b66b77c4e4882d0348d3d17f3ee2d926abc
MD5 8ca5649d26dbea623fc0f935b6aeb3de
BLAKE2b-256 1fad754461d04f77bcf5e71a60b32ad90a7830e87eaf52890dcf463d1df6fb1f

See more details on using hashes here.

File details

Details for the file agp_mcp-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: agp_mcp-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 8.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for agp_mcp-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 9322c959fe9272c13e653a54806321d4de0b345eb95c5622f958a1492d09dbaa
MD5 6b27ec941f96e860467f451f04741c09
BLAKE2b-256 8b6ec8d3037e8e626ed72d8e264ae36fa3fe029a353ac9e5dee68a81937b8040

See more details on using hashes here.

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