The AI-powered intelligence layer for your Ratta Supernote.
This toolkit is a self-hosted implementation of the Supernote Private Cloud protocol. While Ratta's official private cloud provides a solid and reliable sync foundation, this project extends that experience with an AI-driven synthesis engine—transforming your handwritten notes into structured, searchable knowledge using Google Gemini.
This project is designed to be fully compatible with the official Supernote Private Cloud protocol, while adding specialized features for knowledge workers and researchers:
- 📜 AI Synthesis: Automatically transcribes handwriting and generates high-level summaries (Daily, Weekly, Monthly).
- 🔍 Semantic Search: Find concepts across all your notebooks—not just filenames—using vectorized content.
- 🛡️ Private & Secure: You own your database. Run it on your NAS, local PC, or a low-power server, just like Supernote Private Cloud.
- 🖥️ Modern Web UI: A sleek, reactive frontend to browse, review, and search your notes from any browser.
- 🤖 Agent Ready (MCP): Securely connect your notes to AI agents (Claude, ChatGPT) via the built-in Model Context Protocol server. Supports dynamic IndieAuth for secure, remote access.
Beyond simple storage, Supernote provides an active processing pipeline to increase the utility of your notes:
- Sync: Your device uploads
.notefiles using the official Private Cloud protocol. - Transcribe: The server extract pages and use Gemini Vision to OCR your handwriting.
- Synthesize: AI Analyzers review your journals to find tasks, themes, and summaries.
- Index: Every word is vectorized, enabling semantic search across your entire library.
The integrated frontend allows you to review your notes and AI insights side-by-side.
The easiest way to start is with the all bundle and a Gemini API key:
export SUPERNOTE_GEMINI_API_KEY="your-api-key"
pip install "supernote[all]"
supernote serve# Create the initial admin account
supernote admin user add you@example.com --url http://localhost:8080
# Authenticate your CLI
supernote cloud login you@example.com --url http://localhost:8080- On your Supernote, go to Settings > Sync > Private Cloud.
- Enter your server URL (e.g.,
http://192.168.1.5:8080). - Log in with the email and password you created in Step 2.
- Tap Sync to begin processing your notes.
Once your notes sync and process, you can view the AI synthesis from the terminal or browser:
# Get a high-level summary and transcription
supernote cloud insights /Notes/NOTE/Journal.note
# Semantic search across all notebooks
supernote cloud search "What were my project goals for February?"You can access the insights from the MCP server at http://<your ip:port>/mcp
Tip
Semantic Search: Supernote doesn't just look for words—it understands concepts. Searching for "budget" will find notes about "expenses" or "money," even if the specific word isn't there.
- Official Protocol Compatibility: Implements the official Supernote Private Cloud protocol for seamless device synchronization. While Ratta's official service provides a robust and managed sync experience, this project allows for local data ownership and custom background processing.
- Notebook Parsing: Native, high-fidelity conversion of
.notefiles to PDF, PNG, SVG, or plain text. - Developer API: Modern
asyncioclient to build your own automation around Supernote data. - Observability: Built-in request tracing and background task monitoring.
# Install specific components
pip install supernote # Notebook parsing only
pip install supernote[server] # + Private server & AI features
pip install supernote[client] # + API Client
# Full installation (recommended for server users)
pip install supernote[all]To set up the project for development, please refer to the Contributing Guide.
from supernote.notebook import parse_notebook
notebook = parse_notebook("mynote.note")
notebook.to_pdf("output.pdf")The notebook parser is a fork and slightly lighter dependency version of supernote-tool. All credit goes to the original authors for providing an amazing low-level utility.
# Build & Run server
docker build -t supernote .
docker run -d -p 8080:8080 -v $(pwd)/storage:/storage supernote serveSee Server Documentation for details.
Integrate Supernote into your own Python applications:
from supernote.client import Supernote
# See library docstrings for usage examples# Server & Admin
supernote serve # Start the cloud
supernote admin user list # Manage your users
# AI Synthesis & Insights
supernote cloud insights /Note.note # View synthesis from CLI
# File Operations
supernote cloud ls / # List remote files
supernote cloud download /Note.note # Download to local machineYou can use the built-in parser outside of the cloud server:
from supernote.notebook import parse_notebook
note = parse_notebook("journal.note")
note.to_pdf("journal.pdf") # Multi-layer PDF conversionThe notebook parser is a fork of the excellent supernote-tool with updated dependencies and modern type hints.
We welcome contributions! Please see our Contributing Guide for details on:
- Local development setup
- Project architecture
- Using Ephemeral Mode for fast testing
- AI Skills for agentic interaction
This project is in support of the amazing Ratta Supernote product and community. It aims to be a complementary, unofficial offering that is fully compatible with the official Private Cloud protocol.
The official Supernote Private Cloud by Ratta is a rock-solid, production-grade implementation of the protocol. This toolkit serves as a community-driven extension for users who need deep data analysis and advanced integrations.
| Capability | Official Private Cloud (Ratta) | Supernote Hub (This Project) |
|---|---|---|
| Core Sync | ✅ Robust & Validated | ✅ Protocol Compatible |
| AI Analysis | Basic OCR (Device-side) | Adv. OCR & Multi-stage Synthesis |
| Search | Path/Filename | Semantic Concept Search |
| Stack | Java / Spring Boot | Python / Asyncio |
| Focus | Stability & Stability | Innovation & Extensibility |
This toolkit is a great fit if:
- You want AI-generated summaries and insights from your notebooks.
- You want to perform semantic searches across your entire handwriting library.
- You want to integrate your notes into local scripts via a Python API or CLI.
- You want to use the Model Context Protocol (MCP) to chat with your notes using AI agents.
- jya-dev/supernote-tool - Original parser foundation.
- awesome-supernote - Curated resource list.
- sn2md - Supernote to text/image converter.





