@lifeng688/anki-mcp

@lifeng688/anki-mcp

MCP stdio server for controlling local Anki via AnkiConnect. Enables LLMs to manage Anki decks and notes through a standardized tool interface.

Category
Visit Server

README

@lifeng688/anki-mcp

MCP stdio server for controlling local Anki via AnkiConnect. Enables LLMs (Claude, Cursor, Cline) to manage Anki decks and notes through a standardized tool interface.

v0.1.0 — Initial MVP release. Safety-first, read-heavy toolset with dryRun support for writes.

Quick Install

npm install @lifeng688/anki-mcp

Or try it instantly:

npx @lifeng688/anki-mcp

Prerequisites

  1. Anki desktop installed
  2. AnkiConnect add-on (code 2055492159) — install via Tools → Add-ons → Get Add-ons
  3. Node.js >= 18.0.0

Verify AnkiConnect is running:

curl -X POST http://127.0.0.1:8765 \
  -H "Content-Type: application/json" \
  -d '{"action":"version","version":6}'
# Expected: {"result":6,"error":null}

Core Features

  • Deck management — List and create decks (including hierarchical :: decks)
  • Note operations — Add, search, update, and inspect notes
  • Batch operations — Add multiple notes with per-item result tracking
  • Safety firstdryRun support for batch writes, duplicate prevention, field validation
  • Unified responses — Consistent success/error envelope across all tools
  • Security-focused — Localhost only, no DB access, no card content logging

Available Tools

Tool Description Side Effects
ping Server health check None
check_anki_connection Verify AnkiConnect reachable None
list_decks List all decks None
create_deck Create a new deck Creates deck
list_note_models List note models None
get_note_model_fields Get model fields None
add_note Add single note Creates note
add_notes Batch add notes Creates notes
search_notes Search notes None
get_notes_info Get note details None
update_note_fields Update note fields Modifies note

See Tool Schema Reference for full input/output specs.

MCP Client Configuration

Claude Desktop

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "anki": {
      "command": "node",
      "args": ["$(npm root)/@lifeng688/anki-mcp/dist/index.js"]
    }
  }
}

With environment variables:

{
  "mcpServers": {
    "anki": {
      "command": "node",
      "args": ["$(npm root)/@lifeng688/anki-mcp/dist/index.js"],
      "env": {
        "ANKI_CONNECT_URL": "http://127.0.0.1:8765",
        "ANKI_CONNECT_VERSION": "6",
        "ANKI_DEFAULT_DECK": "Default::MCP",
        "ANKI_DEFAULT_MODEL": "Basic",
        "ANKI_LOG_LEVEL": "warn"
      }
    }
  }
}

Note: Replace $(npm root)/@lifeng688/anki-mcp/dist/index.js with the actual resolved path. You can find it with:

npm root -g
# or
npm root

Cursor / Cline

Same JSON format — add to your MCP server configuration. Point args to the installed dist/index.js inside the @lifeng688/anki-mcp package directory.

Global Install

npm install -g @lifeng688/anki-mcp

Then configure your client to point to:

<global-npm-root>/@lifeng688/anki-mcp/dist/index.js

Environment Variables

Variable Default Description
ANKI_CONNECT_URL (none) Full AnkiConnect HTTP endpoint (highest priority). Overrides HOST:PORT.
ANKI_CONNECT_HOST 127.0.0.1 Host part, used when ANKI_CONNECT_URL is not set.
ANKI_CONNECT_PORT 8765 Port part, used when ANKI_CONNECT_URL is not set.
ANKI_CONNECT_VERSION 6 AnkiConnect API version
ANKI_CONNECT_KEY (empty) AnkiConnect API key (if configured)
ANKI_DEFAULT_DECK Default Default deck for note operations
ANKI_DEFAULT_MODEL Basic Default note model
ANKI_REQUEST_TIMEOUT_MS 10000 HTTP request timeout in milliseconds
ANKI_LOG_LEVEL info Log verbosity: error / warn / info / debug

URL Resolution Priority:

  1. ANKI_CONNECT_URL — if set, used as-is (must point to localhost)
  2. ANKI_CONNECT_HOST + ANKI_CONNECT_PORT — composed as http://{HOST}:{PORT}
  3. http://127.0.0.1:8765 — hardcoded default

Security

  • This server only connects to http://127.0.0.1:8765 (localhost)
  • It does not read/write Anki SQLite databases directly
  • It does not upload any data externally
  • ANKI_CONNECT_KEY is never logged
  • Dangerous operations (delete, sync, import, export) are not in v0.1.0

First-Time Setup

  1. Create a Test::MCP deck before making real changes
  2. Run ping and check_anki_connection to verify connectivity
  3. Use add_notes with dryRun: true to preview before writing
  4. Never expose port 8765 to the network

Documentation

License

MIT — See LICENSE for details.

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
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
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
VeyraX MCP

VeyraX MCP

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

Official
Featured
Local
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
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
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
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