mcp-server-anki

mcp-server-anki

Enables AI tools to manage Anki flashcards, including deck management, card search, creation, editing, deletion, and statistics.

Category
Visit Server

README

MCP Server Anki

<div align="center"> <img src="./src/public/icons8-anki-480.png" alt="Anki Logo" width="120" height="120">

MCP TypeScript AnkiConnect

δΈ­ζ–‡ζ–‡ζ‘£ | English </div>

A Model Context Protocol (MCP) server that bridges Anki with AI tools, enabling intelligent flashcard management and learning assistance.

πŸ’‘ Compatibility: This server works with any MCP-compatible AI tool including Claude Code, Cline, Zed AI, and more. We use Claude Code as an example in this documentation, but the setup process is similar for other tools.

🌟 Features

  • πŸ“š Deck Management: Get deck lists, view deck statistics
  • πŸ” Card Search: Search cards using Anki's advanced query syntax
  • βž• Smart Creation: Create and manage Anki cards with AI assistance
  • ✏️ Card Editing: Update existing card fields and content
  • πŸ—‘οΈ Card Deletion: Delete unwanted cards and notes
  • πŸ“Š Data Analysis: Get learning statistics and progress information
  • πŸ”§ Template Management: View and use different note types

πŸ“‹ Prerequisites

  1. Anki Desktop - Download Anki
  2. AnkiConnect Plugin - Install in Anki (Code: 2055492159)
  3. Node.js - Version 16 or higher
  4. MCP-compatible AI Tool - Such as:

πŸš€ Quick Start

1. Install AnkiConnect

In Anki:

  1. Tools β†’ Add-ons β†’ Get Add-ons
  2. Enter code: 2055492159
  3. Restart Anki

2. Configure Your MCP Client

The following examples use Claude Code, but the configuration is similar for other MCP-compatible tools.

Option A: Using Command Line

# For Claude Code
claude mcp add anki -- npx mcp-server-anki

# For other tools, consult their documentation for the equivalent command

Option B: Manual Configuration

Add the server to your MCP client's configuration file:

{
  "mcp": {
    "servers": {
      "anki": {
        "command": "npx",
        "args": ["mcp-server-anki"]
      }
    }
  }
}

πŸ“– Usage Guide

Basic Workflow

  1. Start Anki - Ensure Anki is running with AnkiConnect enabled
  2. Start MCP Server - Automatically started by Claude Code
  3. Use AI Tools - Interact with Anki through Claude Code

Example Conversations

User: Show me the learning progress for my "English Vocabulary" deck

Claude: I'll check the statistics for your "English Vocabulary" deck...
[Calls get_deck_stats tool]

User: Create a new English word card for "ephemeral"

Claude: I'll create this word card for you...
[Calls add_note tool]

πŸ› οΈ Available Tools

Tool Name Description Parameters
get_deck_names Get all deck names None
get_cards_in_deck Get cards from a specific deck deckName
get_deck_stats Get deck statistics deckName
search_cards Search cards query
add_note Add new note deckName, modelName, fields, tags
update_note Update existing note fields noteId, fields
get_note_info Get detailed note information noteId
delete_notes Delete one or more notes noteIds
get_models Get all note types None
get_model_fields Get note type fields modelName

πŸ—οΈ Project Structure

mcp-server-anki/
β”œβ”€β”€ src/
β”‚   β”œβ”€β”€ index.ts           # MCP server entry point
β”‚   β”œβ”€β”€ ankiConnect.ts      # AnkiConnect API client
β”‚   └── tools/              # MCP tool definitions
β”‚       β”œβ”€β”€ deckTools.ts    # Deck-related tools
β”‚       β”œβ”€β”€ cardTools.ts    # Card-related tools
β”‚       └── noteTools.ts    # Note-related tools
β”œβ”€β”€ dist/                   # Compiled JavaScript
β”œβ”€β”€ package.json
β”œβ”€β”€ tsconfig.json
└── README.md

πŸ”§ Development

Build Commands

# Development mode (watch for changes)
npm run dev

# Production build
npm run build

Architecture

Claude Code (MCP Client) ←→ Anki MCP Server ←→ AnkiConnect ←→ Anki Desktop

πŸ“ API Documentation

get_deck_names

Get a list of all deck names.

Returns:

["Default", "English Vocabulary", "Programming"]

search_cards(query)

Search cards using Anki query syntax.

Parameters:

  • query: Anki query string (e.g., deck:English is:due)

Query Syntax Examples:

  • deck:DeckName - Specific deck
  • tag:TagName - By tag
  • is:due - Due cards
  • is:new - New cards
  • added:7 - Cards added in last 7 days

add_note

Add a new note to Anki.

Parameters:

  • deckName: Target deck name
  • modelName: Note type (e.g., "Basic", "Cloze")
  • fields: Field content object
  • tags: Tag array (optional)

Example:

{
  "deckName": "English Vocabulary",
  "modelName": "Basic",
  "fields": {
    "Front": "ephemeral",
    "Back": "lasting for a very short time"
  },
  "tags": ["vocabulary", "adjective"]
}

update_note

Update fields of an existing note.

Parameters:

  • noteId: The ID of the note to update
  • fields: Object with field names and new values

Example:

{
  "noteId": 1234567890,
  "fields": {
    "Back": "lasting for an extremely short time"
  }
}

get_note_info

Get detailed information about a specific note.

Parameters:

  • noteId: The ID of the note to query

Returns:

{
  "noteId": 1234567890,
  "modelName": "Basic",
  "fields": {
    "Front": "ephemeral",
    "Back": "lasting for a very short time"
  },
  "tags": ["vocabulary", "adjective"]
}

delete_notes

Delete one or more notes.

Parameters:

  • noteIds: Array of note IDs to delete

Example:

{
  "noteIds": [1234567890, 9876543210]
}

πŸ”§ Building from Source

If you want to contribute or customize the server:

# Clone the repository
git clone https://github.com/here-tunan/mcp-server-anki.git
cd mcp-server-anki

# Install dependencies
npm install

# Build TypeScript
npm run build

To use your local build with Claude Code, configure it with:

{
  "mcp": {
    "servers": {
      "anki": {
        "command": "node",
        "args": ["/path/to/mcp-server-anki/dist/index.js"]
      }
    }
  }
}

🀝 Contributing

Issues and Pull Requests are welcome!

πŸ“„ License

Apache License

πŸ”— Links

❓ FAQ

Q: AnkiConnect connection failed?

A: Ensure Anki is running and AnkiConnect plugin is installed and enabled. Default port is 8765.

Q: How to customize note types?

A: After creating custom note types in Anki, use get_models and get_model_fields tools to view available fields.

Q: Mobile support?

A: Currently only supports desktop Anki due to AnkiConnect dependency.


Made with ❀️ for Anki learners and AI enthusiasts

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
Qdrant Server

Qdrant Server

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

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