Skip to content
dbpm

Project Overview

See Convention-Driven SQL Generation for generating standalone install and versioned upgrade scripts from Git changes.

dbpm is a package manager for Oracle database applications and reusable PL/SQL components.

The goal is to bring modern dependency management, versioning, packaging, and deployment workflows to Oracle database development.

dbpm aims to make Oracle database development feel more like modern software engineering ecosystems such as:

  • Maven
  • npm
  • Cargo
  • pip

while remaining Oracle-native and deployment-friendly.

Maven-compatible repositories may be useful for publishing immutable package artifacts, but dbpm should not require ordinary package consumers to understand Maven or install a JDK. Consumer installs should use dbpm’s own CLI and plain HTTP(S) artifact retrieval where possible.

  • Package reusable PL/SQL libraries
  • Deploy end-user Oracle database applications through the same package workflow
  • Resolve dependencies automatically
  • Support semantic versioning
  • Enable repeatable deployments
  • Use Core as the in-database install registry and deployment substrate
  • Support schema evolution
  • Inject deployment provenance from package artifacts
  • Lock deployments to immutable artifact identities
  • Simplify CI/CD integration
  • Reduce fragile hand-managed deployment scripts

Example

Terminal window
uv run dbpm check-core --minimum-version 3.2.0
uv run dbpm plan gh-maven:rsantmyer/simple_scheduler:com.512itconsulting.database:simple_scheduler:1.1.0 --mode install --dependency-source gh-maven:512itconsulting/utl_interval:com.512itconsulting.database:utl_interval:1.0.0
uv run dbpm lock gh-maven:rsantmyer/simple_scheduler:com.512itconsulting.database:simple_scheduler:1.1.0 --dependency-source gh-maven:512itconsulting/utl_interval:com.512itconsulting.database:utl_interval:1.0.0
uv run dbpm install --lockfile dbpm-lock.json --env development

For a guided setup, see Getting Started.

  • Package manifests through dbpm.yaml, dbpm.yml, dbpm.json, or package.dbpm.yaml
  • Workspace manifests through dbpm-workspace.yaml for repositories with multiple package roots
  • Local package directory sources
  • Local ZIP package sources
  • GitHub Maven ZIP package sources with gh-maven:owner/repo:group:artifact:version[:extension]
  • Generic Maven ZIP package sources with maven:repository-url::group:artifact:version[:extension]
  • dbpm registry sources with registry:package@constraint
  • HTTPS ZIP artifact sources for lockfile installs
  • Maven snapshot ZIP resolution through maven-metadata.xml
  • SHA-256 checksum capture for ZIP artifacts and deterministic TREE-SHA-256 capture for local directories
  • Content-addressed artifact cache keyed by SHA-256 for lockfile-verified downloads
  • Exact and caret-compatible dependency constraints
  • Ordered multi-package install, conservative upgrade, and validate for dependency sources
  • Dependency lockfile generation and verification through dbpm lock
  • Lockfile-driven install without restating package sources
  • Core-backed installed-state lookup
  • Core-backed reverse-dependency lookup
  • Core provenance staging through pkg_application.stage_deployment_provenance_p
  • Environment-aware deployment plans
  • Install, upgrade, reinstall, resume, and validate workflows
  • ZIP artifact publishing to GitHub Packages and generic Maven repositories
  • GPG artifact signing and lockfile-driven signature verification
  • dbpm registry source resolution and artifact metadata indexing
  • Multi-package dependency execution does not support reinstall.
  • Lockfile database provenance reconciliation requires Core 3.3.0 or newer.
  • Non-lockfile installs use the coordinate-based cache without checksum verification; the lockfile path has full SHA-256 verification.
  • APEX integration
  • Registry search/info commands and compatibility-aware registry resolution

Live-tested against GitHub Packages artifacts for:

  • core
  • utl_interval
  • simple_scheduler

simple_scheduler depends on utl_interval; dbpm can install both from GitHub Packages in dependency order and record Core provenance with artifact URLs and SHA-256 checksums.

Database and GitHub Packages access is configured through local, uncommitted environment files such as dbpm-env.ps1 or dbpm-env.sh. Start from the committed templates dbpm-env.ps1.example or dbpm-env.sh.example.

Common variables:

  • DBPM_SQL_RUNNER: SQLcl or SQLPlus executable, such as sql.exe
  • DBPM_CONNECT: Oracle connect string
  • DBPM_GITHUB_TOKEN: GitHub token with package read access
  • DBPM_GITHUB_USER: optional GitHub username for package authentication
  • DBPM_SIGNING_KEY: optional default GPG key ID, fingerprint, or email for dbpm publish
  • DBPM_MAVEN_TOKEN: token for generic Maven publishing targets
  • DBPM_MAVEN_USER: optional username for generic Maven publishing targets
  • DBPM_REGISTRY_URL: optional default registry URL, default: https://registry.dbpm.io
  • DBPM_REGISTRY_TOKEN: bearer token for registry indexing
  • DBPM_REGISTRY_PUBLISHER: optional registry publisher override
  • DBPM_REGISTRY_DESCRIPTION: optional registry description override
  • DBPM_CACHE_DIR: optional local artifact cache directory, default: ~/.dbpm/cache
  • DBPM_LOG_DIR: optional execution log directory, default: .dbpm-logs in the current working directory
  • DBPM_RUN_DB_TESTS: optional 1 to enable live database pytest tests
CommandDescription
dbpm initScaffold a new package or workspace directory
dbpm check-coreVerify Core is installed and meets a minimum version
dbpm planGenerate and print a deployment plan without executing
dbpm lockWrite or verify a dependency lockfile
dbpm bootstrap-coreInstall Core into an empty schema
dbpm installInstall a package not yet registered in Core
dbpm upgradeUpgrade an installed package to a higher version
dbpm reinstallDestructively reinstall a package
dbpm resumeResume a running or failed deployment
dbpm validateRun a package’s validation script
dbpm generate-scriptsGenerate standalone Oracle install and upgrade scripts from Git changes
dbpm publishBuild and publish a package to a Maven repository with GPG signing
dbpm registry indexIndex a published immutable artifact in a dbpm registry
dbpm workspace listList packages declared by a workspace manifest

Run dbpm <command> --help for a quick flag reference. See docs/commands/source-types.md for the full source and version constraint syntax.

During development, examples use uv run dbpm ... so uv runs the project console script in the project environment. If the project has already been installed into a virtual environment, the generated console script can also be called directly: .venv/bin/dbpm on Linux/macOS or .\.venv\Scripts\dbpm.exe on Windows.


Source: README.md