Vylt is a high-performance vault encryption engine designed to securely encrypt large media and gallery folders, split archives into multiple parts, and protect metadata using optional double-layer symmetric encryption powered by the native ciph ChaCha20 streaming engine with FD-safe and shared-memory–friendly design.
Project description
🔐 Vylt — Vault/Media Encryption Engine
- Version: v0.1.0
- Author: @ankit-chaubey
- License: Apache-2.0
🧠 Why Vylt Exists
In a world where data privacy is increasingly opaque, Vylt was created from a simple belief:
Your data should never leave your control — not even for encryption.
Vylt is a local-first, offline-only vault encryption system designed for people who:
- do not trust third‑party services with raw data
- want cryptographic guarantees, not marketing promises
- prefer tools that are honest about irreversible security
- complete gallery and folder support with multi-layer encryption.
- all encryption happens directly on your device—zero internet exposure.
- fully secured for protecting your private photos, videos, and personal data.
This project was built originally for personal use and later shared so others can preserve privacy with confidence.
🧱 Security Architecture (3‑Layer Protection)
Vylt uses three distinct cryptographic layers, all executed entirely on your device:
🔐 Layer 1 — Vylt Container Layer
-
Custom archive format (
.vylt) -
Secure header with:
- archive ID
- part number & total parts
- metadata length
- SHA‑256 integrity hashes
-
Optional metadata shielding
🔒 Layer 2 & 3 — ciph secure encryption engine
Powered by ciph (C-based SHA-256/ChaCha20-Poly1305 streaming engine):
- Two internal encryption stages
- Streaming, FD-safe, constant-memory
- No temp plaintext leaks
📌 Important: Each ciph layer itself contains multiple cryptographic rounds. All encryption happens offline — Vylt never connects to the internet.
Projects:
🗄️ Metadata Shield (Optional)
When --seal-meta is enabled:
- File names & folder structure are encrypted separately
- Metadata size becomes variable (stored in header)
- Archive still lists correctly after decrypting metadata
Without shield:
- Metadata remains visible
- Faster listing
- Same data security level
⚠️ CRITICAL SECURITY WARNINGS
🚨 Password Loss = Permanent Data Loss
- If you forget the data password → your files are gone forever
- Metadata password cannot recover encrypted data
- No backdoors. No recovery. No master key.
➡️ Write your password down. Store it safely. Verify twice.
⚠️ Do NOT Rename or Modify .vylt Parts
- Archive ID & part numbering are required for recovery
- Renaming or altering filenames may break multi‑part discovery
⚠️ Threading Guidance
-
Default:
1thread (safe) -
Recommended maximum: 4 threads
-
Using more threads than your system supports may:
- slow encryption
- increase memory pressure
- reduce stability
📦 Installation
pip install vylt
Or editable (development):
pip install -e .
PyPI: https://pypi.org/project/vylt/
🚀 Usage
Encrypt (no metadata shield)
vylt encrypt myfolder
Encrypt with metadata shield
vylt encrypt myfolder --seal-meta
List archive contents
vylt list myfolder.*.vylt
Decrypt archive
vylt decrypt myfolder.*.vylt
🧪 Automated Testing & Integrity
Vylt includes full workflow tests:
- single file
- large files
- nested folders
- shielded & unshielded metadata
- SHA‑256 integrity verification
Tests run via GitHub Actions on every push.
🔧 Configuration
Vylt reads config from:
~/.vylt.json
Example:
{
"threads": 2,
"reuse_data_password_for_meta": true,
"max_password_attempts": 5,
"password_from_env": "VYLT_PASSWORD"
}
This allows CI / workflow automation without prompts.
🧭 Roadmap
Planned future work:
- ☁️ remote cloud sync (encrypted blobs only)
- ⏱️ scheduled backups
- 📱 full‑device encryption mode
- 📚 formal archive specification docs
🧑💻 Author & Developer
-
VYLT — design, format, CLI, orchestration Author: Ankit Chaubey (@ankit-chaubey)
-
Powered By CIPH — cryptographic encryption engine
🌟 Support & Community
If this project helped you:
- ⭐ Star the repo
- 🍴 Fork it
- 🔗 Share with privacy‑conscious friends
If you modify or redistribute:
- follow the Apache‑2.0 license
- keep credit and repository links
📜 License
Apache License 2.0
Copyright © 2026 Ankit Chaubey
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at:
https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
⚠️ Disclaimer
This tool uses strong cryptography.
If you forget your password, your data cannot be recovered.
Use responsibly.
This project exists because privacy matters. Your data. Your keys. Your control. 🔏
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file vylt-0.1.0.tar.gz.
File metadata
- Download URL: vylt-0.1.0.tar.gz
- Upload date:
- Size: 18.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
31c986fa7a142f62812261831f5b2dfe37c0593972e4379db9646fcbc12d9d61
|
|
| MD5 |
132faa827cc424213998e39f812e7499
|
|
| BLAKE2b-256 |
79ff4bd1c3e12f18b54b952a3f742331612842fd061eee49e13199d2a9b5593e
|
Provenance
The following attestation bundles were made for vylt-0.1.0.tar.gz:
Publisher:
publish.yml on ankit-chaubey/vylt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
vylt-0.1.0.tar.gz -
Subject digest:
31c986fa7a142f62812261831f5b2dfe37c0593972e4379db9646fcbc12d9d61 - Sigstore transparency entry: 903111643
- Sigstore integration time:
-
Permalink:
ankit-chaubey/vylt@c1ae850acd0ce1c07a173e28fa7bc300a90588e6 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/ankit-chaubey
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@c1ae850acd0ce1c07a173e28fa7bc300a90588e6 -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file vylt-0.1.0-py3-none-any.whl.
File metadata
- Download URL: vylt-0.1.0-py3-none-any.whl
- Upload date:
- Size: 18.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3b838c2c9db518e7edc444b157c86a91e132366a925099f07a0d67f234f7c252
|
|
| MD5 |
cf725c9064574c24659e566ecd062dd2
|
|
| BLAKE2b-256 |
5857a49c0bebdeead9d6d279455502eec01c86280723486343920854e307d8e5
|
Provenance
The following attestation bundles were made for vylt-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on ankit-chaubey/vylt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
vylt-0.1.0-py3-none-any.whl -
Subject digest:
3b838c2c9db518e7edc444b157c86a91e132366a925099f07a0d67f234f7c252 - Sigstore transparency entry: 903111701
- Sigstore integration time:
-
Permalink:
ankit-chaubey/vylt@c1ae850acd0ce1c07a173e28fa7bc300a90588e6 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/ankit-chaubey
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@c1ae850acd0ce1c07a173e28fa7bc300a90588e6 -
Trigger Event:
workflow_dispatch
-
Statement type: