npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@ainote/mcp

v1.1.1

Published

MCP server for AI Note - Tasks, Dev Docs, and multi-device file sync (CLAUDE.md, memory files, Cursor rules, Windsurf rules)

Readme

AI Note MCP Server

npm version License: MIT

A Model Context Protocol (MCP) server that connects AI assistants to your AI Note task management system. This package enables direct interaction with your AI Note tasks through natural language conversations in Claude Desktop and other MCP-compatible platforms.

📚 Complete Project Guide - 전체 프로젝트 가이드 및 아키텍처 정보

Table of Contents

Access Methods

AI Note MCP server is available through three transport options to cover different integration scenarios:

1. stdio Mode (This Package) - For Personal Use

  • Installation: npm install -g @ainote/mcp
  • Usage: Claude Desktop and other stdio-based MCP clients
  • Setup: Local installation with API key configuration
  • Best for: Individual users connecting their personal AI Note account to Claude Desktop

2. Local SSE Bridge (ChatGPT / MCP Apps)

  • Command: ainote-mcp-http
  • Protocol: Server-Sent Events (SSE) + JSON-RPC over HTTP POST
  • Usage: ChatGPT Model Context Protocol connectors, other SSE-capable MCP clients
  • Setup: Run locally alongside your browser; supports API key or (optional) OAuth bearer tokens
  • Best for: Users wanting to expose AI Note tools to ChatGPT without deploying infrastructure

3. Hosted HTTP Endpoint - For Platform Integration

  • URL: https://api.ainote.dev/mcp
  • Protocol: JSON-RPC 2.0 over HTTP
  • Usage: Platform integrations (Kakao PlayMCP, etc.)
  • Setup: No installation required, direct API access
  • Best for: Third-party platforms and services integrating AI Note functionality

All transports expose the same tool catalog. Choose the option that matches your hosting model and client capabilities.

Features

  • 📝 Task Management: Create, update, delete, and list tasks directly from Claude Desktop
  • 📄 Dev Docs: Manage CLAUDE.md, Cursor rules, Windsurf rules, and dev documents centrally via MCP
  • 🗂️ Dev Category Hierarchy: Auto-organized under dev/ with subcategories (claude, cursor, windsurf, copilot, docs)
  • 🏷️ Category Support: Organize tasks with categories
  • 🔍 Advanced Filtering: 18+ filter options including date ranges, location, overdue tasks
  • Priority Management: Mark tasks as important
  • 📅 Smart Due Dates: Human-readable format with relative time (e.g., '26.1.25 14:30 - 오늘)
  • 🔒 Dual Authentication: Support for both User API Key (24-char) and MCP Key (64-char)
  • 📊 Usage Tracking: Automatic API usage statistics per MCP key
  • 🌊 Streaming API: Real-time streaming for bulk operations and large datasets
  • 🤖 Bot Integration: Telegram bot support via Clawdbot + mcporter

Quick Start (No Account Needed)

You can start using AI Note MCP without an existing account. The MCP server includes onboarding tools that let you sign up and get an API key directly from Claude:

1. Add to your MCP config (no API key yet)

{
  "mcpServers": {
    "ainote": {
      "command": "npx",
      "args": ["-y", "@ainote/mcp"]
    }
  }
}

2. Restart Claude Desktop

3. Ask Claude to sign you up

"Sign me up for AI Note with email [email protected] and password mypassword123"

Claude will call the signup_and_get_key tool and return your MCP API key.

4. Add the API key to your config

{
  "mcpServers": {
    "ainote": {
      "command": "npx",
      "args": ["-y", "@ainote/mcp"],
      "env": {
        "AINOTE_API_KEY": "<your-key-from-step-3>"
      }
    }
  }
}

5. Restart Claude Desktop again

Now all tools (tasks, dev docs, etc.) are available.

CLI Signup

You can also sign up directly from the terminal:

npx @ainote/mcp signup

This will interactively ask for email, password, and name, then return your MCP API key.

Onboarding MCP Tools

These tools also work inside Claude (no API key needed):

| Tool | Description | |------|-------------| | signup_and_get_key | Create account + get MCP key | | login_and_get_key | Login + get MCP key (existing account) | | get_setup_guide | Setup instructions |

Prerequisites

  • Node.js >= 18.0.0
  • npm or yarn
  • Claude Desktop with MCP support enabled

Installation

Option 1: Install from npm

npm install -g @ainote/mcp

Option 2: Install from source

git clone https://github.com/ainote-dev/ainote-mcp.git
cd ainote-mcp-server
npm install

Update

Update from npm (Recommended)

To update to the latest version when installed via npm:

npm update -g @ainote/mcp

Or to install a specific version:

npm install -g @ainote/[email protected]

Update from source

If you installed from source:

cd ainote-mcp-server
git pull origin main
npm install

After updating, restart Claude Desktop to load the new version.

Configuration

To connect the MCP server with Claude Desktop, follow these steps.

Step 1: Get your AI Note API Key

You need an API key from your AI Note account to allow Claude to access your tasks. You can find or generate your API key in the AI Note app's settings screen.

Step 2: Configure Claude Desktop

Add the ainote-mcp server to your Claude Desktop configuration file. This file is located at:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json

Open the file and add the following JSON block inside the mcpServers object. Replace your-api-key-here with your actual AI Note API key.

{
  "mcpServers": {
    "ainote": {
      "command": "ainote-mcp",
      "env": {
        "AINOTE_API_KEY": "your-api-key-here"
      }
    }
  }
}

Note: If you need to connect to a self-hosted or different AI Note server, you can add the AINOTE_API_URL environment variable as well.

"env": {
  "AINOTE_API_KEY": "your-api-key-here",
  "AINOTE_API_URL": "https://your-custom-api-url.com"
}

Step 3: Restart Claude Desktop

After saving the configuration file, restart Claude Desktop completely. The new MCP server will be loaded, and you can start managing your AI Note tasks through Claude.

Usage

Once configured, you can interact with your AI Note tasks through Claude:

Example Conversations

You: "Show me my pending tasks"
Claude: I'll retrieve your pending tasks from AI Note...

You: "Create a new task to review the quarterly report by Friday"
Claude: I'll create that task for you with a due date set for Friday...

You: "Mark task ID 123 as completed"
Claude: I'll mark that task as completed...

HTTP Endpoint

For platform integrations and services that prefer HTTP over stdio, AI Note provides a direct HTTP endpoint:

Endpoint URL

POST https://api.ainote.dev/mcp
Content-Type: application/json

Authentication

Authorization: Bearer YOUR_API_KEY

Request Format (JSON-RPC 2.0)

{
  "jsonrpc": "2.0",
  "method": "tools/list",
  "id": 1
}

Response Format

{
  "jsonrpc": "2.0",
  "result": {
    "tools": [...]
  },
  "id": 1
}

Supported Methods

  • ping - Health check
  • capabilities - Server capabilities
  • tools/list - List available tools
  • tools/call - Execute a specific tool

Platform Integration Examples

  • Kakao PlayMCP: Use the HTTP endpoint for seamless integration
  • Custom Applications: Build your own MCP client using the HTTP API
  • Enterprise Solutions: Direct server-to-server communication

This HTTP endpoint provides identical functionality to the stdio version, making AI Note MCP accessible to a broader range of platforms and integration scenarios.

4. Streaming API - For Large Data Operations

  • URL: POST https://api.ainote.dev/mcp/stream
  • Protocol: Server-Sent Events (SSE)
  • Usage: Bulk operations, large task lists, real-time progress
  • Best for: Applications that need to handle large datasets or show progress indicators

Streaming Methods

| Method | Description | |--------|-------------| | tasks/list | Stream task list with filters | | tasks/create | Create single task with progress | | tasks/analyze | Get task statistics and insights | | tasks/bulk_update | Update multiple tasks with progress | | tasks/bulk_create | Create up to 1000 tasks at once |

Streaming Events

event: progress
data: {"status": "starting", "total": 100}

event: data
data: {"type": "task", "data": {...}}

event: result
data: {"status": "success", "count": 100}

5. Telegram Bot Integration - Via Clawdbot

  • Setup Guide: CLAWDBOT_SETUP.md
  • Tool: mcporter for MCP server bridging
  • Usage: Natural language task management in Telegram
# Quick setup
npm install -g mcporter
mcporter call ainote.list_tasks

Local Development Bridge (ainote-mcp-http)

Run the bundled HTTP/SSE bridge when you need a local endpoint for ChatGPT or other MCP clients that speak SSE:

ainote-mcp-http

By default the server listens on http://localhost:3030 and exposes two endpoints:

  • GET /sse – establishes the SSE stream and returns the sessionId
  • POST /messages?sessionId=... – receives JSON-RPC payloads from the client
  • GET /health – simple health probe for monitoring

Configuration

Environment variable | Description | Default ---|---|--- AINOTE_API_KEY | API key used for MCP key authentication | required AINOTE_API_URL | Target AI Note API base URL | https://ainote-5muq.onrender.com AINOTE_MCP_HTTP_PORT | Local port for the SSE server | 3030 AINOTE_MCP_ALLOWED_ORIGINS | Comma-separated list of allowed browser origins | any AINOTE_MCP_ALLOWED_HOSTS | Comma-separated list of allowed Host headers | any AINOTE_ENABLE_OAUTH_AUTH | Set to true to allow Bearer tokens (OAuth) | false

When OAuth is enabled the server expects Authorization: Bearer ... headers from the client and forwards them to the AI Note API.

Available Tools

list_tasks

List tasks from AI Note with advanced filtering options.

Basic Parameters:

  • status (optional): Filter by status - "pending" or "completed"
  • limit (optional): Maximum number of tasks (default: 25, max: 500)
  • search (optional): Search keyword in task content
  • is_important (optional): Filter important tasks only

Location & Category:

  • location (optional): Filter by location (partial match, e.g., "여의도")
  • category_id (optional): Filter by category UUID

Date Range Filters:

  • due_date_start / due_date_end: Filter by due date range
  • completed_date_start / completed_date_end: Filter by completion date
  • created_date_start / created_date_end: Filter by creation date

Special Filters:

  • overdue (optional): Filter overdue incomplete tasks
  • due_today (optional): Filter tasks due today
  • has_notification (optional): Filter by notification status

Sorting:

  • sort_by (optional): Sort field - "due_date", "created_at", "completed_at", "updated_at", "is_important"
  • sort_order (optional): Sort direction - "asc" or "desc"

create_task

Create a new task in AI Note.

Parameters:

  • content (required): Task description
  • is_important (optional): Mark as important (boolean)
  • due_date (optional): Due date in ISO format
  • category_id (optional): Category ID to assign

update_task

Update an existing task.

Parameters:

  • id (required): Task ID
  • content (optional): New task content
  • is_important (optional): Update important status
  • completed_at (optional): Mark as completed (ISO format) or null to uncomplete

delete_task

Soft delete a task.

Parameters:

  • id (required): Task ID to delete

list_categories

List all available categories.

Parameters: None


Dev Doc Tools (v1.1.0+)

Manage AI coding tool configuration files and dev documents centrally. All docs are organized under the dev/ category hierarchy.

list_dev_docs

List dev documents with optional filtering.

Parameters:

  • category (optional): Subcategory filter (claude, cursor, windsurf, copilot, docs)
  • search (optional): Search keyword in document title
  • content_type (optional): Filter by type - "markdown", "json", "yaml", "text"

get_dev_doc

Get a single dev document by title or id.

Parameters:

  • title or id (one required): Document identifier
  • category (optional): Subcategory to disambiguate title
  • include_versions (optional): Include version history

create_dev_doc

Create a new dev document under dev/ category.

Parameters:

  • title (required): Document title (e.g., "project-a-claude.md")
  • content (required): Document content
  • category (optional): Subcategory (default: "docs")
  • content_type (optional): Auto-detected from title extension

update_dev_doc

Update a dev document with replace, append, or prepend modes.

Parameters:

  • title or id (one required): Document identifier
  • content (required): New content
  • mode (optional): "replace" (default), "append", or "prepend"

delete_dev_doc

Soft delete a dev document.

Parameters:

  • title or id (one required): Document identifier

list_dev_categories

List all subcategories under dev/ with document counts.

Parameters: None

Example: Store CLAUDE.md in ainote

You: "Save this project's CLAUDE.md content to ainote"
Claude: I'll create a dev doc in the claude category...
→ create_dev_doc(title: "myproject-claude.md", content: "...", category: "claude")

You: "Update my cursor rules in ainote"
Claude: I'll update the cursor rules doc...
→ update_dev_doc(title: "api-rules.mdc", category: "cursor", content: "...")

You: "Show me all my dev docs"
Claude: I'll list all documents under dev/...
→ list_dev_docs()

API Reference

The MCP server communicates with the AI Note API using the following endpoints:

  • GET /api/mcp/tasks - List tasks
  • POST /api/mcp/tasks - Create task
  • PUT /api/mcp/tasks/:id - Update task
  • DELETE /api/mcp/tasks/:id - Delete task
  • GET /api/mcp/categories - List categories

All requests require authentication via the Authorization header with your API key.

Development

Running Locally

# Clone the repository
git clone https://github.com/ainote-dev/ainote-mcp.git
cd ainote-mcp-server

# Install dependencies
npm install

# Run the server
npm start

Testing with Claude Desktop

  1. Update your Claude Desktop config to point to your local development server
  2. Set environment variables for testing
  3. Restart Claude Desktop
  4. Check the MCP connection status in Claude Desktop settings

Project Structure

ainote-mcp-server/
├── index.js          # Main server implementation
├── package.json      # Package configuration
├── README.md         # English documentation
├── README-ko.md      # Korean documentation
└── LICENSE           # MIT license

Troubleshooting

Common Issues

  1. "API key not found" error

    • Ensure AINOTE_API_KEY is set in your environment or Claude config
    • Check that the API key is valid and has proper permissions
  2. "Connection refused" error

    • Verify the API URL is correct
    • Check network connectivity
    • Ensure the AI Note API server is running
  3. "Tool not found" error

    • Restart Claude Desktop after configuration changes
    • Verify the MCP server is properly configured in Claude Desktop
  4. Tasks not appearing

    • Check API key permissions
    • Verify you're querying the correct status (pending/completed)
    • Try using the search parameter

Debug Mode

To enable debug logging:

export DEBUG=mcp:*

Contributing

We welcome contributions! Please follow these steps:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

Development Guidelines

  • Follow the existing code style
  • Add tests for new features
  • Update documentation as needed
  • Ensure all tests pass before submitting PR

License

This project is licensed under the MIT License - see the LICENSE file for details.

Support

Acknowledgments