Skip to main content

GPGNotes - A CLI note-taking tool with GPG encryption, tagging, and Git sync

Project description

GPGNotes

Tests Lint License

A CLI note-taking tool with GPG encryption, automatic tagging, full-text search, and Git synchronization.

Features

  • Markdown Notes - Write notes in plain markdown with YAML frontmatter
  • GPG Encryption - Every note is encrypted individually with GPG
  • Full-Text Search - Fast SQLite FTS5-powered search across all notes
  • Auto-Tagging - Intelligent tag generation using TF-IDF
  • Folders - Tag-based virtual folders for organizing notes
  • Todo Tracking - Aggregate tasks from markdown checkboxes across all notes
  • Git Sync - Automatic synchronization with private GitHub repositories
  • Daily Notes - Captain's Log style quick entries with summaries (docs)
  • Note Templates - Built-in templates (meeting, project, bug, journal, research) with custom template support
  • Version History - Git-based version tracking with history, diff, and restore commands
  • Markdown Rendering - Rich terminal preview with formatted display
  • URL Import - Web clipper to import content from URLs
  • Pagination - Interactive pagination for list and search results
  • AI Enhancement - Optional LLM-powered note refinement (docs)
  • Import/Export - Support for PDF, DOCX, RTF formats (docs)
  • TUI Mode - Full-screen text user interface for browsing and managing notes

Installation

Prerequisites

  • Python 3.11 or higher
  • GPG (GnuPG) installed on your system
    • Linux: sudo apt install gnupg (Debian/Ubuntu)
    • macOS: brew install gnupg

Install from PyPI

pip install gpgnotes

With optional dependencies:

pip install gpgnotes[llm]      # AI enhancement
pip install gpgnotes[import]   # PDF/DOCX import/export
pip install gpgnotes[tui]      # Full-screen TUI interface

Install from source

git clone https://github.com/oscarvalenzuelab/GPGNotes.git
cd GPGNotes
pip install -e .

Quick Start

1. Initialize

notes init

This guides you through:

  • Selecting a GPG key
  • Testing encryption
  • Configuring your editor
  • Setting up Git sync (optional)

Don't have a GPG key? Create one:

gpg --full-generate-key

2. Create a note

notes new "My First Note"

3. Search and manage

notes search "keyword"
notes list
notes open <note-id>
notes sync

Command Reference

Command Description
notes new "Title" Create a new note
notes new --template meeting Create note from template
notes new --folder work Create note in folder
notes list List all notes
notes list --preview List with content preview
notes list --folder work List notes in folder
notes list --page-size 10 List with custom pagination
notes recent Show 5 most recent notes
notes search "query" Full-text search
notes search --tag work Search by tag
notes search --folder work Search within folder
notes folders List all folders with counts
notes move <id> --folder work Add note to folder
notes move <id> --unfolder work Remove note from folder
notes todos List incomplete tasks
notes todos --all Include completed tasks
notes todos --folder work Tasks from specific folder
notes open <id> Open note by ID
notes open "title" Open by title (fuzzy match)
notes open --last Open most recent note
notes show <id> --render Display note with formatting
notes preview <id> Rich markdown preview
notes history <id> Show version history
notes diff <id> --from <commit> Compare versions
notes restore <id> --version <commit> Restore previous version
notes template list List all templates
notes template show <name> Preview a template
notes tags List all tags
notes delete <id> Delete a note
notes sync Sync with Git
notes config --show Show configuration
notes daily "entry" Quick daily log entry (docs)
notes daily --time "entry" Entry with timestamp
notes today Open today's daily note
notes yesterday Open yesterday's note
notes daily show View today's entries
notes daily summary --month Generate monthly summary
notes enhance <id> AI enhancement (docs)
notes import file.pdf Import file (docs)
notes import <url> Import from URL (web clipper)
notes clip <url> Web clipper shortcut
notes export <id> Export note (docs)
notes tui Launch full-screen TUI interface

Interactive Mode

Run notes without arguments for interactive mode with:

  • Tab completion for note titles
  • Command history (Up/Down arrows)
  • Quick search by typing

TUI Mode

Run notes tui for a full-screen terminal interface with:

  • Split-pane view with folders, notes list, and preview
  • Keyboard navigation (n=new, e=edit, d=delete, s=search, y=sync, r=refresh, q=quit)
  • Auto-sync on launch to cache GPG passphrase
  • Decrypted note preview after authentication

Requires: pip install gpgnotes[tui]

Security

  • GPG Encryption: All notes encrypted with AES256
  • Local-first: Your data stays on your machine
  • Private repos: Git sync for private repositories only
  • Encrypted secrets: API keys stored with GPG encryption

Documentation

License

Apache License 2.0 - see LICENSE for details.


Note: This is an early release. Always backup your notes!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gpgnotes-0.4.1.tar.gz (82.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gpgnotes-0.4.1-py3-none-any.whl (85.9 kB view details)

Uploaded Python 3

File details

Details for the file gpgnotes-0.4.1.tar.gz.

File metadata

  • Download URL: gpgnotes-0.4.1.tar.gz
  • Upload date:
  • Size: 82.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for gpgnotes-0.4.1.tar.gz
Algorithm Hash digest
SHA256 9eb54802123e02acb2fd3b92a040078e4462a419ba528909c1e9e8ea3074798d
MD5 390add8394d7b20a8fbbfc61470c2d68
BLAKE2b-256 b7acea56008cee9de82281b993a12ed7ea81f40ca68d447b9e7de584bd029f38

See more details on using hashes here.

Provenance

The following attestation bundles were made for gpgnotes-0.4.1.tar.gz:

Publisher: publish.yml on oscarvalenzuelab/GPGNotes

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file gpgnotes-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: gpgnotes-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 85.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for gpgnotes-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1c12399b26e6587d3bbfa306f8f90212feecb7b2a10a6b73df4ea98fe240a767
MD5 9ee82b05f7759b6fbf54afbcfe51b89c
BLAKE2b-256 0c2fdd0032a9806b02a1eec085bcd7f6d0454fe8834bda8da0179e68d0e8ac65

See more details on using hashes here.

Provenance

The following attestation bundles were made for gpgnotes-0.4.1-py3-none-any.whl:

Publisher: publish.yml on oscarvalenzuelab/GPGNotes

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page