#container-image #oci #container #docker #podman #image-processing #opencontainers

ocidir

A Rust library for reading and writing OCI (opencontainers) layout directories

5 unstable releases

0.3.1 Sep 20, 2024
0.3.0 Sep 13, 2024
0.2.1 Aug 16, 2024
0.2.0 Jul 23, 2024
0.1.0 Jun 2, 2024

#236 in Unix APIs

Download history 383/week @ 2024-08-16 299/week @ 2024-08-23 400/week @ 2024-08-30 292/week @ 2024-09-06 637/week @ 2024-09-13 564/week @ 2024-09-20 508/week @ 2024-09-27 264/week @ 2024-10-04 335/week @ 2024-10-11 561/week @ 2024-10-18 324/week @ 2024-10-25 615/week @ 2024-11-01 444/week @ 2024-11-08 521/week @ 2024-11-15 385/week @ 2024-11-22 482/week @ 2024-11-29

1,976 downloads per month
Used in 5 crates (4 directly)

MIT/Apache

34KB
672 lines

ocidir

Crates.io

docs.rs

Read and write to OCI image layout directories

This library contains medium and low-level APIs for working with OCI images, which are basically a directory with blobs and JSON files for metadata.

Dependency on cap-std

This library makes use of cap-std to operate in a capability-oriented fashion. In practice, the code in this project is well tested and would not traverse outside its own path root. However, using capabilities is a generally good idea when operating in the container ecosystem, in particular when actively processing tar streams.

Examples

To access an existing OCI directory:

# use ocidir::cap_std;
# use anyhow::{anyhow, Result};
# fn main() -> anyhow::Result<()> {
let d = cap_std::fs::Dir::open_ambient_dir("/path/to/ocidir", cap_std::ambient_authority())?;
let d = ocidir::OciDir::open(&d)?;
println!("{:?}", d.read_index()?.ok_or_else(|| anyhow!("missing Image Index"))?);
# Ok(())
# }

Dependencies

~11–22MB
~361K SLoC