remark-mcp
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., "@remark-mcpList everything on my reMarkable tablet."
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.
remark-mcp
An MCP (Model Context Protocol) server that connects AI assistants to a reMarkable tablet over its local USB HTTP interface.
Once configured, you can ask Claude (or any MCP-capable client) to browse your tablet's documents and read them — the server fetches the PDF from the tablet and renders each page as an image that the AI can see.
Prerequisites
Node.js 18 or later
A reMarkable tablet connected via USB cable with the USB web interface enabled
On the tablet: Settings → Storage → USB web interface — make sure it is turned on
The tablet must be reachable at
http://10.11.99.1(the default USB address)
Installation
git clone <repo-url>
cd remark-mcp
npm installConnecting to Claude Code
Add the server to your Claude Code MCP configuration. In your project's .claude/settings.json (or the global ~/.claude/settings.json):
{
"mcpServers": {
"remarkable": {
"command": "/absolute/path/to/node",
"args": ["/absolute/path/to/remark-mcp/index.js"],
"env": {
"RM_MCP_LOG": "info",
"RM_MCP_LOG_FILE": "/absolute/path/to/remark-mcp/rm-mcp.log"
}
}
}
}Important: The
commandfield must be the full path to thenodeexecutable — Claude Code does not inherit your shell'sPATH, so a barenodewill fail. Find the path withwhich node(macOS/Linux) orwhere node(Windows).
Restart Claude Code after saving. You should see remarkable listed as an available MCP server.
Available Tools
Tool | Description |
| List all files and folders in the root of the tablet |
| List the contents of a folder by its ID |
| Download a document as a PDF and return each page as an image |
Example prompts
List everything on my reMarkable tablet.
Open the folder called "Work" and show me what's inside.
Show me the document "Meeting Notes" from my tablet.The download_pdf tool renders every page of the document as a PNG image at 2× viewport scale, so Claude can read handwritten notes and printed text.
Environment Variables
Variable | Values | Default | Description |
|
|
| Log verbosity |
| file path | (stderr) | Write logs to a file instead of stderr |
Note: stdout is reserved for the MCP protocol wire format. All logging goes to stderr or to
RM_MCP_LOG_FILE. Never redirect stdout to a file when running the server.
Running
The server uses the MCP stdio transport. It is normally launched automatically by the MCP client (Claude Code), but you can start it manually to test:
npm start
# or
node index.jsUtility Script
fetch-pdf.js is a standalone script for downloading a single PDF directly to disk — useful for debugging connectivity before using the MCP server:
node fetch-pdf.js <document-id>
# saves <document-id>.pdf in the current directoryTests
npm testTests use Node's built-in test runner (node:test) and stub out all external dependencies (network, PDF renderer, MCP SDK) so they run without a tablet attached.
Windows Notes
The server patches the pdf-to-png-converter path normalisation at runtime so that pdfjs-dist asset URLs use forward slashes on Windows. No manual changes to node_modules are required.
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/robbogd76/remark-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server