Skip to main content

The Unified Project Lifecycle Manager: Backup, Restore, and Teleport Projects Anywhere.

Project description

Project Vault (pv) 🏦

The Unified Project Lifecycle Manager: Backup, Restore, and Teleport Projects Anywhere.

Project Vault Logo

Build Status License: MIT Python Version Code Style: Black Ruff Maintenance

Project Vault (pv) is your command-line companion for managing project state. It combines the power of atomic backups, cloud synchronization, and time-travel restoration into a single, unified tool. Think of it as Time Machine for your dev projects — portable, reproducible, and cloud-ready.


⚡ Quick Start (The "5-Minute Rule")

Prerequisites

  • Python 3.10+
  • Pip (Python Package Installer)
  • Docker (Optional, for database backups)

Installation

# Clone the repository
git clone https://github.com/dhruv13x/project-vault.git
cd project-vault

# Install in editable mode with development tools
pip install -e .[dev]

Run

Verify the installation:

pv --version

Demo

Create a snapshot of your current project and list it:

# 1. Initialize (optional, for auto-ignore)
pv init --smart

# 2. Create a local snapshot
pv vault . --name "initial-commit"

# 3. List snapshots
pv list

✨ Features

🛡️ Core Reliability

  • Atomic Snapshots: Never lose data due to a partial backup. Snapshots are verified and immutable.
  • Content Addressable Storage (CAS): Deduplication at the file level. Save space by storing unique files only once.
  • Symlink Support: Preserves symlinks (or optionally follows them), ensuring complex project structures remain intact.

🚀 Performance

  • ZStandard Compression: High-speed, high-ratio compression for efficient storage and transfer.
  • Incremental Backups: Only changed files are processed, making subsequent backups lightning fast.

☁️ Cloud & Security

  • Cloud Sync (S3/B2): Push and pull your vaults to any S3-compatible storage.
  • Encrypted Configuration: Securely handle credentials (optional integration).
  • Integrity Checks: Verify the health of your local vault and cloud storage.

🧩 Developer Experience

  • TUI (Textual UI): Browse snapshots and restore files using an interactive terminal interface (pv browse).
  • Smart Ignorance: Auto-generates .pvignore based on project type (Python, Node, Rust, etc.).
  • Rich Output: Beautiful, color-coded terminal output using rich.

🛠️ Configuration

Project Vault can be configured via environment variables, a local pv.toml, or pyproject.toml.

Environment Variables

Variable Description Default Required
PV_BUCKET The default cloud bucket name. None No (unless pushing)
PV_ENDPOINT The S3-compatible endpoint URL. None No (unless pushing)
PV_VAULT_PATH Default local path to store the vault. ~/.project-vault No
PV_RESTORE_PATH Default path to restore projects. ./restored No
PV_TELEGRAM_BOT_TOKEN Telegram Bot Token for notifications. None No
PV_TELEGRAM_CHAT_ID Telegram Chat ID for notifications. None No
PV_DB_PASSWORD Database password for backups. None No

CLI Arguments

Common arguments for pv vault (create snapshot):

Flag Description
--name Tag the snapshot with a custom name.
--cloud Push to cloud immediately after creating.
--symlinks Preserve symlinks instead of copying targets.
--bucket Override configured bucket.
--endpoint Override configured endpoint.
--include-db Include database snapshot in the backup.

Common arguments for pv list:

Flag Description
--cloud List snapshots from the cloud instead of local.
--limit Number of snapshots to show (default: 10).

🏗️ Architecture

Project Vault is a self-contained monorepo orchestrating specialized internal engines for backup and restore.

Directory Tree

project-vault/
├── src/                        # Source Code
│   ├── cli.py                  # Entry Point (pv)
│   ├── cli_dispatch.py         # Command Routing
│   ├── common/                 # Shared Utilities (Config, Crypto, S3/B2)
│   ├── projectclone/           # Backup Engine (Snapshot Creation)
│   ├── projectrestore/         # Restore Engine (Snapshot Application)
│   ├── projectvault/           # Database & Driver Logic
│   └── tui.py                  # Textual User Interface
└── tests/                      # Orchestration & Integration Tests

Data Flow

  1. Input: User runs pv vault in a project directory.
  2. Filter: Rules from .pvignore are applied.
  3. Capture: The internal Clone Engine scans files, computes hashes, and stores unique objects in the CAS (Content Addressable Storage).
  4. Manifest: A JSON manifest is created, linking file paths to CAS objects.
  5. Sync (Optional): pv push uploads new CAS objects and the manifest to Cloud Storage (S3/B2).
  6. Restore: pv vault-restore uses the Restore Engine to read the manifest, fetch objects from CAS, and reconstruct the directory state.

🐞 Troubleshooting

Common Issues

Error Message Possible Cause Solution
B2ConnectionError / 403 Invalid credentials or endpoint. Check pv.toml or PV_ENDPOINT. Ensure keys are correct.
Snapshot not found Local vault is empty or path is wrong. Run pv list to see available snapshots. Check PV_VAULT_PATH.
Permission denied Lack of write access to vault/restore path. Ensure you have permissions for the directory.
Docker not found Docker daemon not running. Start Docker if using pv db or --include-db.

Debug Mode

To enable verbose logging and see stack traces, you can run the CLI module directly:

# Run with python directly for detailed tracebacks
python3 src/cli.py [command]

🤝 Contributing

We welcome contributions! Please see CONTRIBUTING.md for details on how to get started, report bugs, or suggest features.

Dev Setup

  1. Clone & Install:

    git clone https://github.com/dhruv13x/project-vault
    cd project-vault
    # Install package in editable mode with dev dependencies
    pip install -e .[dev]
    
  2. Run Tests:

    python3 -m pytest
    

🗺️ Roadmap

  • Encryption: Client-side encryption for zero-knowledge cloud backups.
  • Daemon Mode: Background watcher for auto-backups on file change.
  • Web UI: A lightweight web interface for browsing vaults remotely.
  • Plugin System: Hooks for custom pre/post backup actions (e.g., database dumps).

Built with ❤️ by Dhruv13x

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

project_vault-11.0.0.tar.gz (160.7 kB view details)

Uploaded Source

Built Distribution

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

project_vault-11.0.0-py3-none-any.whl (181.0 kB view details)

Uploaded Python 3

File details

Details for the file project_vault-11.0.0.tar.gz.

File metadata

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

File hashes

Hashes for project_vault-11.0.0.tar.gz
Algorithm Hash digest
SHA256 92196f8b3d12e94c3d744cdc172392b042aaa9b04c53ccf3b7a8b3fd4c53137b
MD5 a74679f023573e4371f456fbbe2da6a2
BLAKE2b-256 f5770935f956854d8519156ded1ee3bcc4c316f21b3730dff1f8828e3753fd6a

See more details on using hashes here.

Provenance

The following attestation bundles were made for project_vault-11.0.0.tar.gz:

Publisher: publish.yml on dhruv13x/project-vault

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

File details

Details for the file project_vault-11.0.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for project_vault-11.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 364be4dc036c842c99f0e2f3f6513a5a5b5c9700c3da5b00bb7d22f4b46c3480
MD5 22158c5be0ddf1c34d9a60989c62efd0
BLAKE2b-256 987ca040e1b0bed3c822b3708e81e97beba7b76e676a400e0c93d53b5baf0a93

See more details on using hashes here.

Provenance

The following attestation bundles were made for project_vault-11.0.0-py3-none-any.whl:

Publisher: publish.yml on dhruv13x/project-vault

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