Skip to content

gamosoft/NoteDiscovery

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

๐Ÿ“ NoteDiscovery

GitHub Stars Build Latest Version License

Your Self-Hosted Knowledge Base

๐ŸŒ Visit the official website

๐Ÿš€ Try the Live Demo โ€” Contents reset daily, for demonstration purposes only

What is NoteDiscovery?

NoteDiscovery is a lightweight, self-hosted note-taking application that puts you in complete control of your knowledge base. Write, organize, and discover your notes with a beautiful, modern interfaceโ€”all running on your own server.

Note Discovery

๐ŸŽฏ Who is it for?

  • Privacy-conscious users who want complete control over their data
  • Developers who prefer markdown and local file storage
  • Knowledge workers building a personal wiki or second brain
  • Teams looking for a self-hosted alternative to commercial apps
  • Anyone who values simplicity, speed, and ownership

๐Ÿ’– Thanks for using NoteDiscovery!

If this project has been useful to you, consider supporting its development, it truly makes a difference!

Buy Me a Coffee at ko-fi.com

โœจ Why NoteDiscovery?

vs. Commercial Apps (Notion, Evernote, Obsidian Sync)

Feature NoteDiscovery Commercial Apps
Cost 100% Free $xxx/month/year
Privacy Your server, your data Their servers, their terms
Speed Lightning fast Depends on internet
Offline Always works Limited or requires sync
Customization Full control Limited options
No Lock-in Plain markdown files Proprietary formats

Key Benefits

  • ๐Ÿ”’ Total Privacy - Your notes never leave your server
  • ๐Ÿ” Optional Authentication - Simple password protection for self-hosted deployments
  • ๐Ÿ’ฐ Zero Cost - No subscriptions, no hidden fees
  • ๐Ÿš€ Fast & Lightweight - Instant search and navigation
  • ๐ŸŽจ Beautiful Themes - Multiple themes, easy to customize
  • ๐Ÿ”Œ Extensible - Plugin system for custom features
  • ๐Ÿ“ฑ Responsive - Works on desktop, tablet, and mobile
  • ๐Ÿ“‚ Simple Storage - Plain markdown files in folders
  • ๐Ÿงฎ Math Support - LaTeX/MathJax for beautiful equations
  • ๐Ÿ“„ HTML Export - Share notes as standalone HTML files
  • ๐Ÿ•ธ๏ธ Graph View - Interactive visualization of connected notes
  • โญ Favorites - Star your most-used notes for instant access
  • ๐Ÿ“‘ Outline Panel - Navigate headings with click-to-jump TOC

๐Ÿš€ Quick Start

Quick Setup

Linux/macOS:

mkdir -p notediscovery/data && cd notediscovery
docker run -d --name notediscovery -p 8000:8000 \
  -v $(pwd)/data:/app/data \
  ghcr.io/gamosoft/notediscovery:latest

Windows (PowerShell):

mkdir notediscovery\data; cd notediscovery
docker run -d --name notediscovery -p 8000:8000 `
  -v ${PWD}/data:/app/data `
  ghcr.io/gamosoft/notediscovery:latest

Open http://localhost:8000 โ€” done! ๐ŸŽ‰

๐Ÿ’ก Your notes are saved in ./data/. Themes, plugins, locales and default configuration values are included in the image.

Using Docker Compose

Two docker-compose files are provided:

File Use Case
docker-compose.ghcr.yml Recommended - Uses pre-built image from GitHub Container Registry
docker-compose.yml For development - Builds from local source

Option 1: Pre-built image (fastest)

Linux/macOS:

mkdir -p notediscovery/data && cd notediscovery
curl -O https://raw.githubusercontent.com/gamosoft/notediscovery/main/docker-compose.ghcr.yml
docker-compose -f docker-compose.ghcr.yml up -d

Windows (PowerShell):

mkdir notediscovery\data; cd notediscovery
Invoke-WebRequest -Uri https://raw.githubusercontent.com/gamosoft/notediscovery/main/docker-compose.ghcr.yml -OutFile docker-compose.ghcr.yml
docker-compose -f docker-compose.ghcr.yml up -d

Option 2: Build from source (for development)

git clone https://github.com/gamosoft/notediscovery.git
cd notediscovery
docker-compose up -d

See Advanced Docker Setup for volume details.

Running Locally (Without Docker)

For development or if you prefer running directly:

# Clone the repository
git clone https://github.com/gamosoft/notediscovery.git
cd notediscovery

# Install dependencies
pip install -r requirements.txt

# Run the application
python run.py

# Access at http://localhost:8000

Requirements:

  • Python 3.8 or higher
  • pip (Python package manager)

Advanced Docker Setup

The image includes bundled config, themes, plugins, and locales. To customize, you must:

  1. Map the volume in your docker-compose or docker run command
  2. Provide content - the file/folder must exist with valid content (empty = app might break!)
Volume Purpose Bundled?
data/ Your notes โŒ You must create
config.yaml App settings โœ… Yes
themes/ Custom themes โœ… Yes
plugins/ Custom plugins โœ… Yes
locales/ Translations โœ… Yes

Dashboard Integration

NoteDiscovery Icon

An official icon for NoteDiscovery is now available on Dashboard Icons!
Use it in your self-hosted dashboards like Homepage, Homarr, Dashy, Heimdall, etc...

๐Ÿ“š Documentation

Want to learn more?

  • ๐ŸŽจ THEMES.md - Theme customization and creating custom themes
  • โœจ FEATURES.md - Complete feature list and keyboard shortcuts
  • ๐Ÿท๏ธ TAGS.md - Organize notes with tags and combined filtering
  • ๐Ÿ“‹ TEMPLATES.md - Create notes from reusable templates with dynamic placeholders
  • ๐Ÿงฎ MATHJAX.md - LaTeX/Math notation examples and syntax reference
  • ๐Ÿ“Š MERMAID.md - Diagram creation with Mermaid (flowcharts, sequence diagrams, and more)
  • ๐Ÿ”Œ PLUGINS.md - Plugin system and available plugins
  • ๐ŸŒ API.md - REST API documentation and examples
  • ๐Ÿ” AUTHENTICATION.md - Enable password protection for your instance
  • ๐Ÿ”ง ENVIRONMENT_VARIABLES.md - Configure settings via environment variables

๐ŸŒ Multiple Languages

NoteDiscovery supports multiple languages! Currently available:

  • ๐Ÿ‡บ๐Ÿ‡ธ English (en-US) - Default
  • ๐Ÿ‡ช๐Ÿ‡ธ Espaรฑol (es-ES)
  • ๐Ÿ‡ฉ๐Ÿ‡ช Deutsch (de-DE)
  • ๐Ÿ‡ซ๐Ÿ‡ท Franรงais (fr-FR)

To change language: Go to Settings (gear icon) โ†’ Language dropdown.

To add your own language: See the Contributing Guidelines for instructions on creating translation files.

Docker users: Mount your custom locales folder to add or override translations:

volumes:
  - ./locales:/app/locales  # Custom translations

๐Ÿ’ก Pro Tip: If you clone this repository, you can mount the documentation/ folder to view these docs inside the app:

# In your docker-compose.yml
volumes:
  - ./data:/app/data              # Your personal notes
  - ./documentation:/app/data/docs:ro  # Mount docs subfolder inside the data folder (read-only)

Then access them at http://localhost:8000 - the docs will appear as a docs/ folder in the file browser!

๐Ÿค Contributing

Before submitting a pull request, especially for major changes, please:

  • Read our Contributing Guidelines
  • Open an issue first to discuss major features or significant changes
  • Ensure your code follows the project's style and philosophy

๐Ÿ”’ Security Considerations

NoteDiscovery is designed for self-hosted, private use. Please keep these security considerations in mind:

Network Security

  • โš ๏ธ Do NOT expose directly to the internet without additional security measures
  • Run behind a reverse proxy (nginx, Caddy) with HTTPS for production use
  • Keep it on your local network or use a VPN for remote access
  • By default, the app listens on 0.0.0.0:8000 (all network interfaces)

Authentication

  • Password protection is DISABLED by default (default password: admin)
  • โš ๏ธ ENABLE AUTHENTICATION AND CHANGE THE DEFAULT PASSWORD if exposing to a network!
  • See AUTHENTICATION.md for complete setup instructions
  • To disable auth, set authentication.enabled: false in config.yaml
  • Change password with Docker: docker-compose exec notediscovery python generate_password.py
  • Perfect for single-user or small team deployments
  • For multi-user setups, consider a reverse proxy with OAuth/SSO

Data Privacy

  • Your notes are stored as plain text markdown files in the data/ folder
  • No data is sent to external services
  • Regular backups are recommended

Best Practices

  • Run on localhost or a private network only
  • Use Docker for isolation and easier security management
  • Keep your system and dependencies updated
  • Review and audit any plugins you install
  • Set appropriate file permissions on the data/ directory

TL;DR: Perfect for personal use on your local machine or home network. Enable built-in password protection if needed, or use a reverse proxy with authentication if exposing to wider networks.

๐Ÿ“„ License

MIT License - Free to use, modify, and distribute.


Made with โค๏ธ for the self-hosting community