Skip to main content

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


PyPI Downloads Python CI License Release Platform Crypto

🧠 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: 1 thread (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

vylt-1.0.0.tar.gz (18.7 kB view details)

Uploaded Source

Built Distribution

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

vylt-1.0.0-py3-none-any.whl (18.4 kB view details)

Uploaded Python 3

File details

Details for the file vylt-1.0.0.tar.gz.

File metadata

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

File hashes

Hashes for vylt-1.0.0.tar.gz
Algorithm Hash digest
SHA256 b117a260a36dffefefba067c7d98bfbe3f0fc586e6a3e95aa3a229cab828c4b5
MD5 39dc6d5b1d794c788721e39bf75bf07f
BLAKE2b-256 3baef03ac850ca09f66381956101956e9e4445a4102cb9ec54b5a3758327dbec

See more details on using hashes here.

Provenance

The following attestation bundles were made for vylt-1.0.0.tar.gz:

Publisher: publish.yml on ankit-chaubey/vylt

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

File details

Details for the file vylt-1.0.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for vylt-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 638ccd7231730961522bc8dc0ee274a53538cda1902617da6e274314ffe87a7c
MD5 06c8c86c94873ac3a59961cf4edd827e
BLAKE2b-256 b658cd5f59efc3212decd8300d521b2db9bdc98e13b9fd6285b62bc432ed84a4

See more details on using hashes here.

Provenance

The following attestation bundles were made for vylt-1.0.0-py3-none-any.whl:

Publisher: publish.yml on ankit-chaubey/vylt

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