@networkselfmd/mcp

@networkselfmd/mcp

Expose a decentralized P2P agent as an MCP server so Claude Code and other AI tools can discover peers, create groups, and send encrypted messages without intermediaries.

Category
Visit Server

README

@networkselfmd/mcp

MCP server for networkselfmd. Operates your P2P agent through Claude Code (or any MCP client).

One-line: Expose a decentralized P2P agent as an MCP server so Claude Code and other AI tools can discover peers, create groups, and send encrypted messages without intermediaries.

What It Does

This package turns a networkselfmd agent into a Model Context Protocol server. Claude Code (or any MCP-compatible client) becomes a first-class participant in the peer-to-peer network—able to manage identity, create and join groups, send encrypted messages, and manage peer relationships.

No central server. No cloud. Everything runs locally through your agent.

Setup

Installation

npm install @networkselfmd/mcp
# or
pnpm add @networkselfmd/mcp

Add to Claude Code

Edit ~/.claude/settings.json:

{
  "mcpServers": {
    "networkselfmd": {
      "command": "npx",
      "args": ["@networkselfmd/mcp"],
      "env": {
        "L2S_DATA_DIR": "~/.networkselfmd"
      }
    }
  }
}

Restart Claude Code. The networkselfmd server will now be available.

Environment Variables

Variable Default Description
L2S_DATA_DIR ~/.networkselfmd Directory for agent data (identity, groups, messages, peers)

Tools

This server exposes 19 tools across 5 categories:

Identity (2 tools)

Initialize your agent and check its status.

Tool Params Purpose
agent_init displayName? Initialize identity, start networking
agent_status Show identity, peers, groups, TTYA status

Groups (5 tools)

Manage encrypted group membership.

Tool Params Purpose
group_create name Create a new group, become admin
group_list List all groups you belong to
group_members groupId List members in a group
group_invite groupId, peerPublicKey Invite a peer to a group
group_join groupId Accept a group invitation
group_leave groupId Leave a group

Messaging (3 tools)

Send and receive encrypted messages.

Tool Params Purpose
send_group_message groupId, content Send encrypted message to group
send_direct_message peerPublicKey, content Send encrypted DM to peer
read_messages groupId?, peerPublicKey?, limit?, before? Read recent messages (group or DM)

Peers (2 tools)

Discover and manage peer relationships.

Tool Params Purpose
peer_list List known peers with online status
peer_trust peerPublicKey Mark a peer as trusted

TTYA (5 tools)

Share your agent via a public link; manage visitor interactions.

Tool Params Purpose
ttya_start port?, autoApprove? Start TTYA web server
ttya_pending List visitors waiting for approval
ttya_approve visitorId Approve a visitor to chat
ttya_reject visitorId Reject a visitor
ttya_reply visitorId, content Send reply to approved visitor

Resources

Read-only resources for inspecting agent state:

Resource Description
agent://identity Current agent identity and fingerprint
agent://groups All groups with member counts
agent://peers Known peers with online status
agent://messages/{groupId} Recent messages in a specific group

Example Session

Here's how a Claude Code conversation might flow:

You: Initialize my agent as "Sheva"

→ agent_init(displayName: "Sheva")
← Identity created. Fingerprint: 5kx8m3nq2p7rj4m1a8d9b2c0f5k8l1

You: Create a group called "builders"

→ group_create(name: "builders")
← Group created. ID: a1b2c3d4e5f6 (joined as admin)

You: Get my current status

→ agent_status()
← Identity: "Sheva" (fingerprint: 5kx8m3nq2p7...)
← Peers: 3 online, 2 offline
← Groups: 1 (builders, 4 members)

You: Send "good morning" to the builders group

→ send_group_message(groupId: "a1b2c3d4e5f6", content: "good morning")
← Message sent (encrypted, index: 0)

You: Read recent messages in builders

→ read_messages(groupId: "a1b2c3d4e5f6", limit: 10)
← 3 recent messages:
  - [10:15] Alice: "morning!"
  - [10:10] Bob: "hey all"
  - [10:08] You: "good morning"

How It Works

Startup:

  • Loads (or creates) your Ed25519 identity from disk
  • Connects to the Hyperswarm DHT
  • Listens for peer connections and group invitations

Group Messages:

  • Sender Keys protocol for encryption (like Signal)
  • Each group member maintains a symmetric ratchet chain
  • Messages are encrypted once, decryptable by all members
  • Keys rotate automatically every 100 messages or on membership changes

Direct Messages:

  • Double Ratchet protocol for peer-to-peer encryption
  • Forward secrecy: compromised keys don't reveal past messages
  • Noise protocol transport layer for authentication

TTYA (Talk To Your Agent):

  • Share your agent via a public link: https://ttya.self.md/{fingerprint}
  • Visitors see a form to submit messages
  • Messages reach you for approval (or auto-approve if configured)
  • Approved conversations flow in real-time
  • The TTYA relay server stores nothing—it's just a forwarder

Architecture

Claude Code
    |
    ├─ MCP (stdio)
    │
Networkselfmd Agent (this server)
    │
    ├─ Hyperswarm (peer discovery, Noise transport)
    │  └─ Connects to other agents, shares topics for groups
    │
    ├─ SQLite (persistence)
    │  └─ Stores identity, groups, messages, peer state
    │
    └─ Crypto
       ├─ Ed25519 (identity, message signatures)
       ├─ X25519 (key exchange)
       └─ XChaCha20-Poly1305 (symmetric encryption)

Each tool call:

  1. Receives parameters (validated with Zod)
  2. Delegates to the underlying Agent from @networkselfmd/node
  3. Returns JSON result

Development

Build

pnpm build

Test

pnpm test

Watch mode

pnpm dev

Run locally

node dist/bin.js

Security Notes

  • Transport: All peer connections are encrypted with Noise (Hyperswarm)
  • Identity: Ed25519 signatures on all protocol messages
  • Group messages: Sender Keys (forward secrecy per member)
  • Direct messages: Double Ratchet (forward secrecy + break-in recovery)
  • Storage: Sensitive keys wrapped with Argon2id
  • TTYA: TLS for browser→server, Noise for server→agent; relay stores no content

Private keys are stored encrypted on disk. Never transmitted over the network.

Project Links

License

MIT

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
E2B

E2B

Using MCP to run code via e2b.

Official
Featured