UNPKG

anki-mcp-http

Version:

Model Context Protocol server for Anki - enables AI assistants to interact with your Anki flashcards

82 lines 4.34 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var GuiSelectedNotesTool_1; Object.defineProperty(exports, "__esModule", { value: true }); exports.GuiSelectedNotesTool = void 0; const common_1 = require("@nestjs/common"); const mcp_nest_1 = require("@rekog/mcp-nest"); const zod_1 = require("zod"); const anki_connect_client_1 = require("../../../clients/anki-connect.client"); const anki_utils_1 = require("../../../utils/anki.utils"); let GuiSelectedNotesTool = GuiSelectedNotesTool_1 = class GuiSelectedNotesTool { ankiClient; logger = new common_1.Logger(GuiSelectedNotesTool_1.name); constructor(ankiClient) { this.ankiClient = ankiClient; } async guiSelectedNotes(_args, context) { try { this.logger.log('Getting selected notes from Card Browser'); await context.reportProgress({ progress: 50, total: 100 }); const noteIds = await this.ankiClient.invoke('guiSelectedNotes'); await context.reportProgress({ progress: 100, total: 100 }); this.logger.log(`Retrieved ${noteIds.length} selected note(s) from Card Browser`); if (noteIds.length === 0) { return (0, anki_utils_1.createSuccessResponse)({ success: true, noteIds: [], noteCount: 0, message: 'No notes are currently selected in the Card Browser', hint: 'Open the Card Browser (guiBrowse) and select some cards/notes first.', }); } return (0, anki_utils_1.createSuccessResponse)({ success: true, noteIds, noteCount: noteIds.length, message: `Retrieved ${noteIds.length} selected note ID(s) from Card Browser`, hint: 'Use notesInfo to get details about these notes, or updateNoteFields/deleteNotes to modify them.', }); } catch (error) { this.logger.error('Failed to get selected notes', error); if (error instanceof Error) { if (error.message.includes('browser') || error.message.includes('not open')) { return (0, anki_utils_1.createErrorResponse)(error, { hint: 'Card Browser is not open. Use guiBrowse to open it first.', }); } } return (0, anki_utils_1.createErrorResponse)(error, { hint: 'Make sure Anki is running and the Card Browser is open', }); } } }; exports.GuiSelectedNotesTool = GuiSelectedNotesTool; __decorate([ (0, mcp_nest_1.Tool)({ name: 'guiSelectedNotes', description: 'Get the IDs of notes currently selected in the Card Browser. Returns array of note IDs (empty if no selection). ' + 'IMPORTANT: Only use when user explicitly requests getting selected notes. ' + 'This tool is for note editing/creation workflows, NOT for review sessions. ' + 'The Card Browser must be open with cards selected.', parameters: zod_1.z.object({}), }), __metadata("design:type", Function), __metadata("design:paramtypes", [Object, Object]), __metadata("design:returntype", Promise) ], GuiSelectedNotesTool.prototype, "guiSelectedNotes", null); exports.GuiSelectedNotesTool = GuiSelectedNotesTool = GuiSelectedNotesTool_1 = __decorate([ (0, common_1.Injectable)(), __metadata("design:paramtypes", [anki_connect_client_1.AnkiConnectClient]) ], GuiSelectedNotesTool); //# sourceMappingURL=gui-selected-notes.tool.js.map