supernote
Supernote Knowledge Hub
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.
Why Supernote Knowledge Hub?
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.
Synthesis & AI in Action
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.
Web Interface
The integrated frontend allows you to review your notes and AI insights side-by-side.
Quick Start
1. Launch the Cloud
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
2. Bootstrap Your User
# 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
3. Connect Your Device
- 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.
4. Explore Your Insights
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
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.
Features Deep Dive
- 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.
Installation
# 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]
Local Development Setup
To set up the project for development, please refer to the Contributing Guide.
Parse a Notebook (Local)
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.
Run with Docker
# Build & Run server
docker build -t supernote .
docker run -d -p 8080:8080 -v $(pwd)/storage:/storage supernote serve
See Server Documentation for details.
Developer API
Integrate Supernote into your own Python applications:
from supernote.client import Supernote
# See library docstrings for usage examples
CLI Usage
# 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 machine
Notebook Operations (Local)
You 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 conversion
The notebook parser is a fork of the excellent supernote-tool with updated dependencies and modern type hints.
Contributing
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
Acknowledgments
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.
Choosing Your Private Cloud Experience
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.
Community Projects
- jya-dev/supernote-tool - Original parser foundation.
- awesome-supernote - Curated resource list.
- sn2md - Supernote to text/image converter.
1""" 2.. include:: ../README.md 3""" 4 5# Core notebook parsing (always available) 6from . import notebook # noqa: F401 7 8__all__ = [ 9 "models", 10] 11 12# Optional: Client library 13try: 14 from . import client # noqa: F401 15 16 __all__.extend(["client"]) 17except ImportError: 18 pass 19 20# Optional: Server 21try: 22 from . import server # noqa: F401 23 24 __all__.extend(["server"]) 25except ImportError: 26 pass 27 28__all__.extend(["notebook"])