data:image/s3,"s3://crabby-images/cceee/cceee3531a13a0b627e7eb16dfda2bea7499241c" alt="Logo"
gittech. site
for different kinds of informations and explorations.
Qlock: Local file encryption CLI tool written in Rust
qlock
(pronounced 'Queue Lock', or 'clock' if ur feelin spicy?)
A CLI tool written in Rust for encrypting files locally with XChaCha20Poly1305 and Argon2 hashing/key-derivation.
To encrypt files locally before uploading them to cloud storage or sending them over the network. A file named qlock_metadata.json
will be created in whichever directory you run this command from. This file is sensitive and should not be shared or sent over the network. You need your qlock_metadata.json
file along with a password you provide to encrypt/decrypt each file. Passwords are not stored locally so we suggest using a password manager.
Installation
git clone [email protected]:emmagamma/qlock.git
cd qlock/
cargo build --release && cp target/release/qlock /usr/local/bin/qlock
Usage
Basic Commands
# Encrypt file(s)
qlock -e <file path(s), or a directory>
# Decrypt file(s)
qlock -d <.qlock file path(s), or a directory containing .qlock files>
# List all encrypted keys
qlock ls
# List specific key
qlock ls <key name>
# Remove key metadata
qlock rm <key name>
Multiple Files
You can encrypt/decrypt multiple files in two ways:
# Method 1: Using numbered parameters
qlock -e file1.txt file2.txt \
-p1="password1" -p2="password2" \
-n1="key1" -n2="key2" \
-o1="encrypted1" -o2="encrypted2"
qlock -d file1.qlock file2.qlock \
-p1="password1" -p2="password2" \
-o1="decrypted1.txt" -o2="decrypted2.txt"
# Method 2: Using comma-separated lists
qlock -e file1.txt file2.txt \
-p "password1, password2" \
-n "key1, key2" \
-o "encrypted1, encrypted2"
qlock -d file1.qlock file2.qlock \
-p "password1, password2" \
-o "decrypted1.txt, decrypted2.txt"
Directory Encryption
# Encrypt all files in directory (ignores .qlock files and qlock_metadata.json)
qlock -e <folder>
# Decrypt all .qlock files in directory
qlock -d <folder>
Additional Options
# Auto-generate key names
qlock -e <file> -p <password> -a
# Force overwrite without prompts
qlock -e <file> -f
Output File Naming
- Without
-o
: Files are created next to originals - With
-o
:- Encryption:
.qlock
extension is added automatically - Decryption: Specify desired extension in output name
- Multiple files: 4-digit counter appended (e.g., output-0000.qlock)
- Encryption:
Security Notes
- Passwords are never stored
qlock_metadata.json
contains sensitive data - avoid network transmission- Losing passwords or metadata file means encrypted data cannot be recovered
- Consider using a password manager
Technical Details
The encryption process:
- Generates the random key for file encryption
- Derives a second key from a password you provide
- Encrypts the first key with password-derived key
- Stores each encrypted key and associated metadata in
qlock_metadata.json
Stored metadata includes:
- Encrypted key
- File content hash
- Nonces and salts
- Input/output filenames
- Key name
Roadmap
β Already Completed:
-
add flags to provide a name or auto-generate one. -
add ability to list the details for a just one key, by name. -
add password flag, so you can skip all prompts. -
add support for folders during encryption/decryption. -
add -f --force-overwrite to skip the checks before overwriting files. -
add some tests. -
add support for multiple file inputs with per-file parameters (numbered or comma-separated).
Next Up:
- improve test coverage with more edge cases
- add tab auto-completion for key names
- add alternative encryption schemes:
- focus on quantum-resistant algorithms
- avoid NIST recommendations where possible
- expose customizable parameters for encryption/hashing algorithms
- support global metadata file in $HOME with path tracking
- integrate with password managers for automated password storage
- refine directory handling with per-file parameter support
- implement parallel processing for large files/directories
- add integrity verification commands
- support key rotation and metadata backup