notebooklm-mcp
The NotebookLM MCP Server provides full automation of Google NotebookLM via MCP protocol or HTTP REST API.
Q&A & Research
Ask questions and receive citation-backed answers with 5 citation formats (none, inline, footnotes, json, expanded)
Multi-turn conversations with session management (create, list, reset, close)
Content Generation
Audio overviews: podcast-style discussions in 80+ languages
Videos: brief or explainer style with 6 visual styles (classroom, documentary, animated, corporate, cinematic, minimalist)
Infographics: horizontal (16:9) or vertical (9:16)
Reports, presentations, and data tables — all support custom instructions and 80+ languages
Content Download & Export
Download audio (MP3), video (MP4), infographics (PNG)
Export presentations to Google Slides, data tables to Google Sheets
Source Management
Add sources: files (PDF, DOCX, TXT), URLs, plain text, YouTube videos, Google Drive links
List and delete sources from notebooks
Notebook Library Management
Add notebooks manually or via auto-discovery (auto-generates name, description, tags)
List, search, select, update, remove notebooks; view library stats
Scrape NotebookLM homepage to discover all notebooks with IDs and names
Bulk delete notebooks
Notes Management
Create notes with markdown formatting
Save chat conversations to a note
Convert notes into source documents for RAG
Authentication & Maintenance
Browser-based Google login setup, re-authentication, and de-authentication
Check server health (auth status, active sessions, config)
Deep cleanup across 8 data categories with optional library preservation
Integration & Deployment
MCP protocol clients: Claude Code, Cursor, Codex
HTTP REST API for n8n, Zapier, Make.com
Docker/Docker Compose support with noVNC for headless visual authentication
Enables querying Google's NotebookLM service to retrieve zero-hallucination answers synthesized from user-uploaded documentation, with support for multiple notebooks and citation-backed responses.
Supports HTTP REST API integration with Make.com, allowing automation scenarios to query NotebookLM knowledge bases for documentation-driven responses.
Provides HTTP REST API integration for n8n workflows, allowing automation tasks to query NotebookLM knowledge bases and receive synthesized answers from documentation.
Offers HTTP REST API access for Zapier integrations, enabling automated workflows to query NotebookLM notebooks and retrieve documentation-based answers.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@notebooklm-mcpsummarize the key points from our API documentation notebook"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
NotebookLM REST API + MCP server
Automate Google NotebookLM at scale. 33-endpoint HTTP REST API for n8n / Zapier / Make / curl, plus an MCP server for Claude Code / Cursor / Codex. Citation-backed Q&A, full Studio generation (audio · video · infographic · report · presentation · data table), multi-account rotation with auto-reauth.
v1.7.5 — production-grade, batch-tested on overnight runs of 1 000+ questions. New:
batch_to_vaultis now a first-class MCP tool (no HTTP server required) on top of the existingPOST /batch-to-vaultendpoint. See RTFM integration for the full pattern. Compare withPleasePrompto/notebooklm-mcpv2.0.0 to see when this project is the right pick (REST API, full Studio, auto-reauth) and when the MCP-only upstream is.
Features
Q&A with Citations
Ask questions to NotebookLM and get accurate, citation-backed answers
Source citation extraction with 5 formats: none, inline, footnotes, json, expanded (97% excerpt success rate)
Session management for multi-turn conversations with auto-reauth on session expiry
Content Generation
Generate multiple content types from your notebook sources:
Content Type | Formats | Options |
Audio Overview | Podcast-style discussion | Language (80+), custom instructions |
Video | Brief, Explainer | 6 visual styles, language, custom instructions |
Infographic | Horizontal, Vertical | Language, custom instructions |
Report | Summary, Detailed | Language, custom instructions |
Presentation | Overview, Detailed | Language, custom instructions |
Data Table | Simple, Detailed | Language, custom instructions |
Video Visual Styles: classroom, documentary, animated, corporate, cinematic, minimalist
Content Download
Download Audio — WAV audio files
Download Video — MP4 video files
Download Infographic — PNG image files
Text-based content (report, presentation, data_table) is returned in the API response
Source Management
Add sources: Files (PDF, TXT, DOCX), URLs, Text, YouTube videos, Google Drive
List sources: View all sources in a notebook
Notebook Library
Multi-notebook management with validation and smart selection
Auto-discovery: Automatically generate metadata via NotebookLM queries
Search notebooks by keyword in name, description, or topics
Scrape notebooks: List all notebooks from NotebookLM with IDs and names
Bulk delete: Delete multiple notebooks at once
Integration Options
MCP Protocol — Claude Code, Cursor, Codex, any MCP client
HTTP REST API — n8n, Zapier, Make.com, custom integrations
Docker — Isolated deployment with Docker or Docker Compose
RTFM retrieval layer —
/batch-to-vaultwrites citation-backed answers as markdown + JSON sidecars (nblm-answer-v1schema), indexable by RTFM (FTS5 + semantic) for unlimited offline queries. Ideal for academic / SOTA workflows. Guide.
Quick Start
Option 0 — Claude Code marketplace (one-liner, recommended for Claude Code users)
The fastest way to get NotebookLM into Claude Code. Distributed via the roomi-fields/claude-plugins marketplace alongside RTFM (the retrieval companion — see RTFM integration guide):
/plugin marketplace add roomi-fields/claude-plugins
/plugin install notebooklm@roomi-fieldsThat registers the MCP server, runs npx -y @roomi-fields/notebooklm-mcp@<pinned-version> automatically (Node ≥ 18 required), and lets you upgrade with two commands when a new release ships: /plugin marketplace update roomi-fields then /reload-plugins. Then run npm run setup-auth once to log into Google. To install RTFM at the same time: /plugin install rtfm@roomi-fields.
Option 1 — HTTP REST API (n8n, Zapier, Make, curl, any HTTP client)
git clone https://github.com/roomi-fields/notebooklm-mcp.git
cd notebooklm-mcp
npm install && npm run build
npm run setup-auth # One-time Google login
npm run start:http # Start REST API on port 3000# Citation-backed Q&A, single curl, JSON response
curl -X POST http://localhost:3000/ask \
-H 'Content-Type: application/json' \
-d '{"question": "Summarize chapter 3", "notebook_id": "your-id", "source_format": "json"}'The full surface is 33 documented endpoints — see the REST API reference. For overnight batches of 1 000+ questions, see the batch pattern.
Option 2 — MCP Mode (Claude Code, Cursor, Codex)
# Build (same package, MCP transport)
git clone https://github.com/roomi-fields/notebooklm-mcp.git
cd notebooklm-mcp
npm install && npm run build
# Claude Code
claude mcp add notebooklm node /path/to/notebooklm-mcp/dist/index.js
# Cursor — add to ~/.cursor/mcp.json
{
"mcpServers": {
"notebooklm": {
"command": "node",
"args": ["/path/to/notebooklm-mcp/dist/index.js"]
}
}
}Then say: "Log me in to NotebookLM" → Chrome opens → log in with Google.
Option 3 — Docker (NAS, server, headless)
# Build and run
docker build -t notebooklm-mcp .
docker run -d --name notebooklm-mcp -p 3000:3000 -p 6080:6080 -v notebooklm-data:/data notebooklm-mcp
# Authenticate via noVNC
# 1. Open http://localhost:6080/vnc.html
# 2. Run: curl -X POST http://localhost:3000/setup-auth -d '{"show_browser":true}'
# 3. Login to Google in the VNC windowSee Docker Guide for NAS deployment (Synology, QNAP).
Documentation
Full docs site: https://roomi-fields.github.io/notebooklm-mcp/ · OpenAPI 3.1 spec
Guide | Description |
Step-by-step setup for HTTP and MCP modes | |
Environment variables and security | |
Complete HTTP endpoint documentation (33 endpoints) | |
Production batch pattern with auto-reauth and rotation | |
Pipeline pattern: NotebookLM as one-shot ingestion, RTFM as retrieval layer. | |
Workflow automation setup | |
Common issues and solutions | |
Multi-notebook management | |
Autonomous metadata generation | |
Audio, video, infographic, report, presentation | |
Multiple accounts with TOTP auto-reauth | |
Docker and Docker Compose deployment | |
Run Claude Desktop + HTTP simultaneously | |
Feature matrix vs the upstream MCP-only server | |
Profile locking (solved in v1.3.6+) | |
i18n system for multilingual UI support |
Roadmap
See ROADMAP.md for planned features and version history.
Latest releases:
v1.7.5 — Three end-user bugs fixed: (1)
/plugin marketplace update roomi-fields+/reload-pluginsnow actually upgrades the running MCP (npx pin inplugin.json); (2)list_notebooks_from_nblmno longer hardcodes"Notebook"as title — id-based scrape returns real names; (3)get_health.current_accountno longer returns a stale email afterre_authv1.7.4 — Expose
create_notebookanddelete_notebooks_from_nblmas MCP tools (handlers existed but lacked a tool definition + dispatch case); 30/30 alignment audit passesv1.7.3 — Fix:
list_notebooks_from_nblmMCP tool was declared but unreachable (missing dispatch case) — now resolves correctlyv1.7.2 — Claude Code plugin manifest (
.claude-plugin/plugin.json) + cross-file version sync script enforced in CI; README "Install via Claude Code marketplace" one-linerv1.7.0 —
batch_to_vaultexposed as a first-class MCP tool (parity with the HTTP endpoint, no localhost server required); sharedrunBatchToVaulthelper deduplicates the loop across both transportsv1.6.0 —
/batch-to-vaultendpoint + RTFM integration (nblm-answer-v1JSON Schema published at schemas.roomi-fields.com/nblm-answer-v1.json) for caching NotebookLM answers as a searchable markdown vaultv1.5.9 — Restore
mcpNamefield for MCP Registry npm-package ownership verificationv1.5.8 — NotebookLM 2026 UI adaptations (icon-label sanitization, Discussion-panel recovery, count-based source detection) — PR #5 by @KhizarJamshaidIqbal
v1.5.7 — Citation extraction selector fix (
.highlighted) and Docker multi-stage build — PR #1 by @JulienCANTONIv1.5.6 — Citation extraction major rewrite (97% success rate), browser-verified auth at startup, profile auto-sync
v1.5.5 — Multi-account state-path bug fix, Windows startup scripts, hidden-window MCP proxy
v1.5.4 — Mid-session auto-reauth with stored credentials, TOTP support
v1.5.3 — Docker deployment with noVNC for visual authentication + NAS support (Synology, QNAP)
v1.5.2 — Notebook scraping from NotebookLM + Bulk delete + Bug fixes
v1.5.1 — Multilingual UI support (FR/EN) with i18n selector system + E2E tests (76 tests)
v1.5.0 — Complete Studio content generation (video, infographic, presentation, data_table) + Notes management + Delete sources
v1.4.0 — Content management (sources, audio, generation) + Multi-account
Not yet implemented:
Discover sources (Web/Drive search with Fast/Deep modes)
Edit notes (create, delete, and convert are implemented)
Disclaimer
This tool automates browser interactions with NotebookLM. Use a dedicated Google account for automation. CLI tools like Claude Code can make mistakes — always review changes before deploying.
See full Disclaimer below.
Contributing
Found a bug? Have an idea? Open an issue or submit a PR!
See CONTRIBUTING.md for guidelines.
License
MIT — Use freely in your projects. See LICENSE.
Author
Romain Peyrichou — @roomi-fields
About browser automation: While I've built in humanization features (realistic typing speeds, natural delays, mouse movements), I can't guarantee Google won't detect or flag automated usage. Use a dedicated Google account for automation.
About CLI tools and AI agents: CLI tools like Claude Code, Codex, and similar AI-powered assistants are powerful but can make mistakes:
Always review changes before committing or deploying
Test in safe environments first
Keep backups of important work
AI agents are assistants, not infallible oracles
I built this tool for myself and share it hoping it helps others, but I can't take responsibility for any issues that might occur. Use at your own discretion.
Built with frustration about hallucinated APIs, powered by Google's NotebookLM
⭐ Star on GitHub if this saves you debugging time!
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/roomi-fields/notebooklm-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server