JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 20
  • Score
    100M100P100Q73501F
  • License MIT

MCP server for exploring Nostr protocol data

Package Exports

  • nostr-explore-mcp
  • nostr-explore-mcp/dist/index.js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (nostr-explore-mcp) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Nostr Explore MCP

A Model Context Protocol (MCP) server that enables AI assistants to explore and interact with the Nostr network, focusing on conversation discovery, content publishing, and notification monitoring.

Version 0.2.0 Changes

  • Renamed nostr_tweet_publisher to nostr_publish_note for better clarity
  • Added flexible authentication: tools now support both environment variable (NOSTR_PRIVATE_KEY) and direct nsec parameter
  • Improved code organization with shared signer utility for DRY principle

What You Can Do

This MCP server provides tools and resources for:

Conversation Exploration

  • Track conversations - Search and retrieve conversation threads based on keywords or hashtags
  • Get full thread context - Retrieve complete conversation threads from any event, including all parent messages
  • Monitor discussions - Find active discussions about specific topics with configurable depth

Content Publishing

  • Publish short notes - Post Twitter-style messages with hashtags, mentions, and replies
  • Create long-form articles - Publish full articles with markdown, summaries, and header images
  • View user timelines - Get all root posts from specific Nostr users

Notification Management

  • Monitor mentions - Track when specific pubkeys are mentioned across the network
  • Store notifications - Retrieve and manage notifications for monitored agents
  • Publish notification events - Create notification events based on source events

Real-time Resources

  • Event Feed Subscription - Subscribe to real-time Nostr event streams from specific users with optional filtering

Installation

Prerequisites

  • Node.js 18 or higher
  • npm or yarn package manager

Setup

  1. Clone the repository:
git clone https://github.com/yourusername/nostr-mcp-server.git
cd nostr-mcp-server
  1. Install dependencies:
npm install
  1. Build the project:
npm run build
  1. Configure your MCP client (e.g., Claude Desktop) to use the server by adding to your configuration:
{
  "mcpServers": {
    "nostr-explore": {
      "command": "node",
      "args": ["path/to/dist/index.js"]
    }
  }
}

Configuration

The server connects to the following Nostr relays by default:

  • wss://relay.primal.net
  • wss://tenex.chat

Authentication for Publishing

You can provide signing credentials in two ways:

  1. Environment Variable (Recommended for single-user setups): Set NOSTR_PRIVATE_KEY in your environment with your private key (hex or nsec format). When set, the nsec parameter becomes optional in publishing tools.

  2. Direct Parameter: Pass the nsec parameter directly to publishing tools. This takes precedence over the environment variable.

Usage

Once configured, the MCP server provides tools that can be accessed by AI assistants:

Examples

Publishing a short note:

// With nsec parameter
await nostr_publish_note({
  content: "Hello Nostr!",
  nsec: "your-nsec-key",  // Optional if NOSTR_PRIVATE_KEY is set
  hashtags: ["introductions"],
  mentions: ["npub1..."]
});

// With environment variable set (no nsec needed)
await nostr_publish_note({
  content: "Hello Nostr!",
  hashtags: ["introductions"],
  mentions: ["npub1..."]
});

Publishing long-form content:

// With nsec parameter
await nostr_publish_article({
  title: "Understanding Nostr",
  content: "Full article content in markdown...",
  summary: "An introduction to Nostr",
  image: "https://example.com/header.jpg",
  tags: [["t", "nostr"], ["t", "decentralization"]],
  nsec: "your-nsec-key"  // Optional if NOSTR_PRIVATE_KEY is set
});

// With environment variable set (no nsec needed)
await nostr_publish_article({
  title: "Understanding Nostr",
  content: "Full article content in markdown...",
  summary: "An introduction to Nostr",
  image: "https://example.com/header.jpg",
  tags: [["t", "nostr"], ["t", "decentralization"]]
});

Searching for conversations:

await nostr_conversation_tracker({
  query: "#bitcoin",
  limit: 10,
  thread_depth: 2
});

Getting a full conversation thread:

await get_conversation({
  eventId: "nevent1..." // or hex event ID
});

Available Tools

The server provides the following tools:

Conversation Tools

  • get_conversation - Retrieve a full conversation thread from any Nostr event
  • nostr_conversation_tracker - Search and retrieve conversation threads by keywords/hashtags
  • user_root_notes - Get all root posts from a specific user

Publishing Tools

  • nostr_publish_note - Publish short notes with hashtags, mentions, and replies
  • nostr_publish_article - Publish long-form articles with markdown support

Notification Tools

  • start_notification_monitoring - Start monitoring mentions for a specific pubkey
  • stop_notification_monitoring - Stop monitoring for a specific pubkey
  • get_notifications - Retrieve stored notifications
  • publish_notification - Create and publish notification events

Available Resources

Nostr Feed

The nostr://feed/ resource provides a real-time stream of Nostr events for a given public key, with optional filtering by event kinds.

URI Format: nostr://feed/{pubkey-or-npub}/{kinds}?relays=wss://relay1.com,wss://relay2.com

  • {pubkey-or-npub}: The public key (in hex or npub format) of the user whose feed you want to subscribe to.
  • {kinds}: (Optional) A comma-separated list of event kinds to filter by (e.g., 1,6,30023).
  • ?relays=...: (Optional) A comma-separated list of relay URLs to use for the subscription. If not provided, the server's default relays will be used.

Example Usage:

To subscribe to all events from a user:

nostr://feed/npub1...

To subscribe to text notes (kind 1) and long-form posts (kind 30023) from a user, using a specific relay:

nostr://feed/npub1.../1,30023?relays=wss://relay.damus.io

Development

Building

npm run build

Testing

npm test

Project Structure

nostr-explore-mcp/
├── src/
│   ├── index.ts                    # Main server entry point
│   ├── resources/                  # Resource implementations
│   │   └── feed.ts                 # Nostr event feed resource
│   ├── tools/                      # Tool implementations
│   │   ├── getConversation.ts      # Conversation retrieval
│   │   ├── nostr/
│   │   │   ├── conversationTracker.ts # Conversation search
│   │   │   └── contentPublisher.ts    # Long-form publishing
│   │   ├── nostrNotePublisher.ts   # Short note publishing
│   │   ├── notifications.ts        # Notification management
│   │   └── userRootNotes.ts        # User timeline
│   └── utils/                      # Shared utilities
│       └── signer.ts               # Shared signing logic
├── dist/                           # Compiled JavaScript
├── package.json
└── tsconfig.json

Contributing

Contributions are welcome! Please:

  1. Fork the repository
  2. Create a feature branch
  3. Commit your changes
  4. Push to the branch
  5. Create a Pull Request

Resources

License

MIT License - see LICENSE file for details

Support

For issues, questions, or suggestions, please open an issue on GitHub.

Authors

@pablof7z