Interactive CLI tool for PGP encryption/decryption with SQLite key management.
Note: This is a personal side project created to learn more about encryption and PGP. It's a work in progress and should be used for educational purposes.
This project is actively being developed as a learning exercise. While functional, it may contain bugs or security considerations that need addressing. Use at your own discretion and avoid using it for highly sensitive production data.
- PGP Encryption/Decryption - Secure message encryption using OpenPGP
- SQLite Key Management - Store and manage multiple keypairs and contacts
- System Keychain Integration - Passphrases stored securely in your OS keychain
- Clipboard Integration - Seamlessly encrypt/decrypt from clipboard
- Multiple Input Methods - Clipboard, text editor, or inline terminal input
- Cross-Platform Support - Works on Linux, macOS, and Windows
- Smart Editor Detection - Auto-detects available editors (VS Code, Vim, Nano, etc.)
- Scriptable CLI - Non-interactive commands for CI/CD and scripting
- Node.js (v18 or higher recommended)
- pnpm (v10.19.0 or higher)
- Clone the repository:
git clone https://github.com/robertjbass/lpgp.git
cd lpgp- Run the installer:
./install.shThe installer will:
- Detect your operating system and shell
- Check for Node.js and install it if missing (using nvm)
- Check for pnpm and install it if missing
- Install all dependencies and compile native modules
- Build the project
- Optionally create an
lpgpcommand alias
- Run the tool and create or import your keys:
pnpm devUse the Key Management menu to generate new keypairs or import existing ones.
- Clone the repository:
git clone https://github.com/robertjass/lpgp.git
cd lpgp- Install dependencies:
pnpm install- Build the project:
pnpm build- Database initialization:
The SQLite database is automatically created on first run at ~/.lpgp/data.db. No manual setup required!
npx lpgppnpm devYou'll be greeted with an interactive menu:
╔════════════════════════════════════════╗
║ 🔐 PGP Encryption/Decryption Tool ║
╚════════════════════════════════════════╝
? What would you like to do?
🔒 Encrypt a message
🔓 Decrypt a message
👋 Exit
- Select "🔒 Encrypt a message"
- Choose your input method:
- 📋 Paste from clipboard - Automatically encrypts text from your clipboard
- 📝 Use an editor - Opens your preferred text editor
- ⌨️ Type inline - Enter text directly (press Enter, then Ctrl+D to finish)
- The encrypted message is displayed and automatically copied to your clipboard
- Select "🔓 Decrypt a message"
- Choose your input method for the encrypted text
- The decrypted message is displayed and automatically copied to your clipboard
For scripting and CI/CD, lpgp supports non-interactive commands:
# Generate a new keypair
lpgp generate --name "Your Name" --email "you@example.com" --passphrase "secret"
lpgp generate --name "Your Name" --email "you@example.com" --no-passphrase
# List all keypairs
lpgp list-keys
lpgp list-keys --json
# Export public key
lpgp export-public
lpgp export-public --fingerprint ABC123 --json
# Encrypt a message
lpgp encrypt "Hello World" --to user@example.com
lpgp encrypt --file message.txt --to ABC123 --output encrypted.pgp
echo "Hello" | lpgp encrypt --to user@example.com
# Decrypt a message
lpgp decrypt "-----BEGIN PGP MESSAGE-----..."
lpgp decrypt --file encrypted.pgp --passphrase "secret"
cat encrypted.pgp | lpgp decrypt
# Help
lpgp --help
lpgp encrypt --helpPassphrase sources for decryption:
--passphrasecommand line optionLPGP_PASSPHRASEenvironment variable- System keychain (if previously stored)
# Run the PGP tool (development)
pnpm dev
# Format code with Prettier
pnpm format
# Build the TypeScript project
pnpm build
# Run the built project
pnpm startlpgp/
├── src/
│ ├── pgp-tool.ts # Main CLI entry point
│ ├── cli-commands.ts # Non-interactive CLI command handlers
│ ├── encrypt.ts # Encryption logic
│ ├── decrypt.ts # Decryption logic
│ ├── key-manager.ts # Key management UI
│ ├── key-utils.ts # Key utility functions
│ ├── db.ts # SQLite database layer
│ ├── ui.ts # Centralized UI styling
│ └── schema.sql # Database schema
├── dist/ # Built output (not in git)
├── package.json
├── tsconfig.json
└── README.md
See TODO.md for the complete project roadmap. Completed and upcoming features:
- SQLite database integration
- System keychain passphrase storage
- Key generation and management
- Multi-recipient encryption
- Contact management
- File encryption/decryption (planned)
- GPG keyring import (planned)
As this is a learning project, please note:
- Passphrases are stored in your system keychain (macOS Keychain, Windows Credential Manager, etc.)
- Keys are stored in SQLite database at
~/.lpgp/data.db - The
.gitignoreexcludes database and.envfiles - This tool has not undergone professional security audit
- For production use, consider more secure key storage methods (e.g., hardware tokens)
This is primarily a personal learning project, but suggestions and feedback are welcome! Feel free to:
- Open issues for bugs or feature requests
- Submit pull requests with improvements
- Share your experience using the tool
Source Available Educational License - NOT Open Source
This software is source-available for educational purposes, security auditing, and learning only. Commercial use and use by for-profit enterprises is prohibited without explicit permission. See the LICENSE file for full terms.
The source code is publicly available to promote transparency, enable security audits, and support learning about encryption and web development - but this does not make it open source software.
- Built with OpenPGP.js for encryption
- Inquirer.js for beautiful CLI prompts
- Chalk for terminal styling
- Clipboardy for clipboard operations
Learning Focus: This project explores:
- PGP encryption and cryptography fundamentals
- Node.js CLI development with TypeScript
- Security best practices for handling sensitive data
- System keychain integration for secure credential storage
It's a work in progress and will continue to evolve as I learn more about encryption and secure communication.