Skip to main content

A CLI tool for generating OCI-compliant container images for Python and Node.js projects.

Project description

Verti-OSI CLI Tool Documentation

Overview

Verti-OSI is a command-line tool for generating OCI-compliant container images and Dockerfiles based on your application source code.
It supports flexible configurations via CLI parameters or a YAML file.

You can:

  • Generate a Dockerfile
  • Build a container image
  • Supply custom build-time and run-time base images
  • Use custom build commands, pre-build commands, and environment variables
  • Pull code from a remote repository
  • Support multiple platforms (e.g., linux/amd64, linux/arm64)

Supported Languages

  • Python (detects requirements.txt / pyproject.toml)
  • Node.js (detects package.json)

Prerequisites

Make sure you have:

  • Python 3.7+ installed:

    python --version
    
  • pipx installed:

    pipx --version
    

    If not installed:

    python -m pip install --user pipx
    pipx ensurepath
    
  • A container daemon running:

    • Docker:
      docker info
      
    • Podman:
      podman info
      

Installation

Install Verti-OSI globally with pipx:

pipx install verti-osi

Usage

After installing, invoke the CLI tool using:

verti-osi

Verti-OSI has two main commands:

Command Description
dockerfile Generate a Dockerfile only
image Build a container image (can also generate the Dockerfile internally)

Command Reference

Generate an Image

verti-osi image [OPTIONS]

Key CLI options:

Option Description
--file-dir Path to verti-osi.yaml config file
--root-directory Project's root directory (default: .)
--source-directory Source code directory (default: .)
--image-name Name of the generated image
--build-image Base image to use during build
--run-time-image Base image for runtime
--platforms Comma-separated build platforms
--repository-url Git repository URL
--repository-branch Git repository branch
--env-vars Environment variables for all stages
--env-vars-rt Runtime-specific environment variables
--env-vars-bt Build-time-specific environment variables
--pre-build-commands Commands before build
--build-commands Build commands
--output Image output: tar, registry, standard
--delete-generated-dockerfile Delete Dockerfile after build (True/False)
--run-generated-image Run image after build (True/False)
--port Port to expose (default: 8080)
--daemon Container daemon (docker or podman)

Generate a Dockerfile

verti-osi dockerfile [OPTIONS]

Key CLI options:

Same as image command, but without:

  • --platforms
  • --output
  • --run-generated-image

Configuration via YAML

You can define all parameters using a verti-osi.yaml config file.

Then invoke:

verti-osi <image | dockerfile> --file-dir <path-to-directory>

Example verti-osi.yaml

image-name: verti-node-app:v1
source-directory: ./src
root-directory: .
delete-generated-dockerfile: true
daemon: docker
output-type: tar
platform:
  - linux/amd64
  - linux/arm64
pre-build:
  - echo "Running pre-build steps"
build:
  - npm run build
env-vars:
  - name: API_KEY
    value: abc123
    type: both
  - name: DEBUG
    value: true
    type: runtime
port: 8080
remote-source-repository:
  git:
    url: https://github.com/example/project
    branch: main
images:
  build: node:20-slim
  run-time: node:20-alpine

Examples

1. Build and Push an Image to Registry

verti-osi image --root-directory . \
                --source-directory ./src \
                --image-name myorg/myapp:v1 \
                --output registry

2. Generate Dockerfile Only

verti-osi dockerfile --root-directory . \
                     --source-directory ./src \
                     --output-directory ./dockerfiles

3. Full Flow (YAML + Build + Push + Clean Dockerfile)

verti-osi image --file-dir ./configs \
                --output registry \
                --delete-generated-dockerfile True

Features Summary

✅ Automatic Language Detection
✅ Custom Build & Run-time Images
✅ Pre-Build and Build Commands
✅ Pull Source from Git Repositories
✅ Multi-Platform Build Support
✅ Dockerfile Only Generation
✅ Docker or Podman Support
✅ Configurable via CLI or YAML


License

Verti-OSI is licensed under the MIT License.


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

verti_osi-2.5.1.tar.gz (21.4 kB view details)

Uploaded Source

Built Distribution

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

verti_osi-2.5.1-py3-none-any.whl (30.3 kB view details)

Uploaded Python 3

File details

Details for the file verti_osi-2.5.1.tar.gz.

File metadata

  • Download URL: verti_osi-2.5.1.tar.gz
  • Upload date:
  • Size: 21.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for verti_osi-2.5.1.tar.gz
Algorithm Hash digest
SHA256 9caefe9eb9102555686e81f2e67a76cc4e7cbfdff4d65d2995a27e404c25b3eb
MD5 f765d183317d3698796fbb11060f5ebd
BLAKE2b-256 74ac76581c1749769362f6c90de187a7f0274d6581c69b8bfc170373163d665e

See more details on using hashes here.

File details

Details for the file verti_osi-2.5.1-py3-none-any.whl.

File metadata

  • Download URL: verti_osi-2.5.1-py3-none-any.whl
  • Upload date:
  • Size: 30.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for verti_osi-2.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 cc2eea5b90e47432878a247181f5907341ca8c5eb10aeb8a06312948df3ec8a0
MD5 dcfe2f2e6d8670fc331b014bb9d03836
BLAKE2b-256 9afb636e0981bdf474ec25068301c2e2bdade8cf006460296096a405213b4a41

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