Skip to main content

An OCI plugin for the Pants build system

Project description

OCI backend for Pants

PyPI

Warning This plugin is in development. No stability is guaranteed! Contributions welcome.

This is a backend implementing support for building OCI images in pants; running them, and publishing them to container registries. To do this, this plugin uses three different tools:

  • umoci for manipulating OCI images
  • runc for exeuction
  • skopeo for pulling and pushing images

Planned and missing features

  • Currently there's no support for pulling tags, as that would break determinism
  • Multi-platform SHA/.sig is untested/unsupported
  • skopeo doesn't support MacOS, preventing pulling and pushing images.
  • No "in-container" build steps

Targets

There's six targets currently implemented, of which five are generic:

  • oci_pull_image
  • oci_pull_images
  • oci_image_build
  • oci_image_empty
  • oci_build_layer

And one with some special language semantics:

  • oci_python_image - this is the same as oci_image_build, but will prefer to set the entrypoint to .pex files.

oci_pull_image

Pull an image from a repository with a specific digest.

oci_pull_image(
    name="base-python",
    repository="docker.io/library/python",
    sha="b78b777208be08edd8f297035cdfbacddb45170ad778fd643c792ee045187e39"
)
Argument Meaning Default value
name The target name Same as any other target, which is the directory name
repository Fully qualified repository name Required
sha The digest of the image, minus the @sha: prefix. Required
anonymous Whether to pull the image anonymously. false
decsription A description of the target
tags List of tags []

oci_pull_images

Pull multiple shas for an image, generating a target for each. In the below example, we'd get the targets :python#slim and :python#buster.

oci_pull_image(
    name="python",
    repository="docker.io/library/python",
    variants={
       "slim": "f8fbb2370c6314c806b2ddbec8d94375987e16bc122379bef979c6fc5e962920",
       "buster": "97c123c899c8c9ca46248f4002ec4173322e0a1086b386efefac163c64967ba2"
    }
)
Argument Meaning Default value
name The target name Same as any other target, which is the directory name
repository Fully qualified repository name Required
variants Dictionary with local tags to the remote sha Required
anonymous Whether to pull the image anonymously false
decsription A description of the target
tags List of tags []

oci_build_image

Build an image with the provided packages embedded.

oci_image_build(
    name="my-server",
    base=":python#slim",
    repository="my-registry.example.com/a-namespace/an-image",
    tag="latest",
    packages=[":my_pex"]
)
Argument Meaning Default value
name The target name Same as any other target, which is the directory name
base The base image to use. Matches the FROM directive in a Dockerfile Required
packages Packaged targets to include. The first element will be used as the entrypoint. []
repository Fully qualified repository name Required when publishing
tag Remote tag to use Required when publishing
decsription A description of the target
tags List of tags []

oci_python_image

Build a Python image with the provided packages embedded.

oci_python_image(
    name="my-server",
    base=":python#slim",
    repository="my-registry.example.com/a-namespace/an-image",
	main="/app/server/start.py",
    tag="latest",
    packages=[":my_pex"]
)
Argument Meaning Default value
name The target name Same as any other target, which is the directory name
base The base image to use. Matches the FROM directive in a Dockerfile Required
packages Packaged targets to include. The first element will be used as the entrypoint. []
python_main The main file to run The last .pex in the dependency list
repository Fully qualified repository name Required when publishing
tag Remote tag to use Required when publishing
decsription A description of the target
tags List of tags []

oci_image_empty

An empty base image with no contents at all. This is declared as //:empty automatically, but you can use this to create new targets.

oci_image_empty(
    name="empty",
)
Argument Meaning Default value
name The target name Same as any other target, which is the directory name
decsription A description of the target
tags List of tags []

oci_extract

Extract one or more files from another container image.

oci_extract(
    name="my-app-binary"
	base=[":some-app"],
	outputs=['/usr/bin/local/the-app'],
)
Argument Meaning Default value
name The target name Same as any other target, which is the directory name
outputs Paths to capture into the built layer. []
exclude Globs to not include in the output. []
decsription A description of the target
output_path The output path during pants package A variant generated from the target name and directory
tags List of tags []

oci_build_layer

Run a command in an image, and capture the configured output into a layer artifact, that can be injected into other images. This matches the COPY --from workflows.

oci_build_layer(
    name="layer"
	base=[":rust-1-70"],
    packages=[":files"],
    env=['RUSTC_OPTS=...'],
	commands=['cd /my-package && cargo build --release'],
	outputs=['/my-package/target/release/my-package'],
)
Argument Meaning Default value
name The target name Same as any other target, which is the directory name
commands The commands to execute in the container []
packages Packaged targets to include. The first element will be used as the entrypoint. []
env Environment variables to set. Does not support interpolation. []
outputs Paths to capture into the built layer. []
exclude Globs to not include in the output. []
decsription A description of the target
output_path The output path during pants package A variant generated from the target name and directory
tags List of tags []

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

pants_backend_oci-0.8.1.tar.gz (30.4 kB view details)

Uploaded Source

Built Distribution

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

pants_backend_oci-0.8.1-py2.py3-none-any.whl (46.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pants_backend_oci-0.8.1.tar.gz.

File metadata

  • Download URL: pants_backend_oci-0.8.1.tar.gz
  • Upload date:
  • Size: 30.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for pants_backend_oci-0.8.1.tar.gz
Algorithm Hash digest
SHA256 843050f58d5a22aca190f29bc53c49db28a2566a83ccdfc2a74c420547e03ab3
MD5 ceee22293fdf36cc49af478c45a3d605
BLAKE2b-256 3676b410aaee2cc60b3c966488427a2001954f7004aadde793a81162cdaef708

See more details on using hashes here.

File details

Details for the file pants_backend_oci-0.8.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pants_backend_oci-0.8.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 6597cf1973b4a02779b6b0976ba23e851b14231c7d3b4880bccff0e18ac632dd
MD5 df96fa4e621eb39cf6a3d6b801f19a9e
BLAKE2b-256 9a306a0d701a70ae05cda105c0bd9e3721ade40d9a12341c5305c8d99c6fd4d4

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