Skip to main content

Workflow for reproducible asset packaging and publishing.

Project description

ovpackage

ovpackage is a command-line and Python API tool for reproducible asset packaging and publishing.

Use it when a project needs to snapshot a directory of assets, publish that snapshot as an immutable package version, install that version into another workspace, and later prove what was installed. It is designed for asset-heavy build pipelines, shared content libraries, CI/CD promotion, offline delivery, and agents that need deterministic package operations.

The first public source release intentionally keeps the documentation small. The most useful references in this repository are:

  • this README for the concepts and common workflows
  • ovpackage --help and ovpackage COMMAND --help for exact CLI syntax
  • .agents/skills/ovpackage-cli/ for agent-oriented command guidance
  • tests/ for runnable examples of the public behavior

Install from source

python -m pip install -e .[local]

Optional backends are available through extras: s3, azure, gcs, and storage-api.

python -m pip install -e .[local,s3,azure,gcs,storage-api]

Check the installed command:

ovpackage --help
ovpackage version

Core Concepts

  • Package: A named collection of files.
  • Version: An immutable snapshot of a package. Use a new version string for every changed snapshot.
  • Repository: A storage location that contains a .packages directory with package versions.
  • Install location: A workspace path where a package version is materialized for a project.
  • Package metadata file: A JSON file named .<package>.wrapp that records package metadata and dependencies. The .wrapp extension is part of the package format.
  • Ignore file: .wrappignore uses gitignore-style rules and is picked up by create, catalog, and freeze workflows.
  • Catalog: A JSON description of a directory tree, including paths, sizes, and hashes.

Local Quickstart

Create and install a package using only local files:

mkdir -p demo/source demo/repo demo/workspace
printf "hello assets\n" > demo/source/readme.txt

ovpackage create sample_assets 1.0.0 demo/source --repo demo/repo --progress-report off
ovpackage list-repo demo/repo
ovpackage install sample_assets 1.0.0 demo/workspace/sample_assets --repo demo/repo --progress-report off

Track installed package dependencies in a project-level metadata file:

mkdir -p demo/project
ovpackage new demo_project 1.0.0 demo/project
ovpackage install sample_assets 1.0.0 demo/project/assets \
    --repo demo/repo \
    --package demo/project/.demo_project.wrapp \
    --progress-report off
ovpackage status demo/project/.demo_project.wrapp --progress-report off

Common Workflows

Publish a new immutable version

ovpackage create textures 2026.05.11 ./textures --repo s3://asset-packages --progress-report off
ovpackage list-repo s3://asset-packages

Install a specific version

ovpackage install textures 2026.05.11 ./project/assets/textures \
    --repo s3://asset-packages \
    --progress-report off

Compare two directory snapshots

ovpackage catalog ./assets assets-before.json --progress-report off
ovpackage catalog ./assets assets-after.json --progress-report off
ovpackage diff assets-before.json assets-after.json --show

Mirror packages between repositories

ovpackage mirror textures 2026.05.11 \
    --source-repo s3://dev-packages \
    --destination-repo s3://release-packages \
    --recursive \
    --progress-report off

Export and import for offline delivery

ovpackage export textures 2026.05.11 --repo s3://release-packages --dedup --progress-report off
ovpackage import textures.2026.05.11.tar --repo ./offline-repo --progress-report off

Storage Backends

Install only the extras you need:

Backend URL examples Install extra
Local filesystem ./repo, /mnt/packages, file:///mnt/packages local
Amazon S3 and compatible endpoints s3://bucket/path s3
Azure Blob Storage https://account.blob.core.windows.net/container/path azure
Google Cloud Storage gs://bucket/path gcs
Storage API Service-specific URLs storage-api

omniverse:// Nucleus URLs are also supported when the required client libraries are available in the environment.

Authentication can be passed with --auth or environment variables. Prefer OVPACKAGE_* variables in new automation, for example OVPACKAGE_REPO, OVPACKAGE_AUTH, OVPACKAGE_LOG_FILE, and OVPACKAGE_PROGRESS_REPORT.

Python API

The public import namespace is ovpackage:

import ovpackage

print(ovpackage.__version__)

Most command implementations are asynchronous. A typical application initializes storage backends through ContextManager and then calls package operations with that scheduler. See tests such as tests/test_api.py and tests/test_ovpackage_aliases.py for executable API examples.

Agent Usage

This repository includes an agent skill at .agents/skills/ovpackage-cli/. Agents that support repository-local skills can use it directly. Otherwise, copy or symlink that directory into the agent's skill search path.

The skill contains a command reference, storage/auth notes, and multi-step recipes. It is meant to compensate for the intentionally minimal initial documentation set.

Package Format Notes

  • Published package versions are intended to be immutable. Publish a new version instead of changing files under an existing package version.
  • Package metadata filenames use .<package>.wrapp; keep that filename format.
  • Ignore rules use .wrappignore; keep that filename format.
  • Object stores do not preserve empty folders. Add placeholder files if empty folders are meaningful to your pipeline.
  • Use --progress-report off in automation and agent runs to avoid interactive progress output.

Tests

Install test dependencies:

python -m pip install -e .[local,test]

Run the default public test set:

make test

Run emulator-backed backend tests:

make start-test-services
make test-emulators
make stop-test-services

The GitHub workflow in .github/workflows/tests.yml runs both the default public tests and emulator-backed S3, Azure, and GCS tests.

Contributing

This project is currently not accepting contributions.

Generated version: 0.1.0.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

ovpackage-0.1.0-py3-none-any.whl (462.0 kB view details)

Uploaded Python 3

File details

Details for the file ovpackage-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: ovpackage-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 462.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for ovpackage-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 12afcd2a7743eaec94dcbe36c0000356c5831e4775bc8e97995bdb3d7c8d8559
MD5 37bc29b3a243f0649e97376d97e60170
BLAKE2b-256 b2ccf9d916834a5c433a38ecba588540aeb977105e5a85bfdb333a85423bf02d

See more details on using hashes here.

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