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-0.1.0.tar.gz (18.6 kB view details)

Uploaded Source

Built Distribution

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

vylt-0.1.0-py3-none-any.whl (18.2 kB view details)

Uploaded Python 3

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

Hashes for vylt-0.1.0.tar.gz
Algorithm Hash digest
SHA256 31c986fa7a142f62812261831f5b2dfe37c0593972e4379db9646fcbc12d9d61
MD5 132faa827cc424213998e39f812e7499
BLAKE2b-256 79ff4bd1c3e12f18b54b952a3f742331612842fd061eee49e13199d2a9b5593e

See more details on using hashes here.

Provenance

The following attestation bundles were made for vylt-0.1.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-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

Hashes for vylt-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3b838c2c9db518e7edc444b157c86a91e132366a925099f07a0d67f234f7c252
MD5 cf725c9064574c24659e566ecd062dd2
BLAKE2b-256 5857a49c0bebdeead9d6d279455502eec01c86280723486343920854e307d8e5

See more details on using hashes here.

Provenance

The following attestation bundles were made for vylt-0.1.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