Struct oci_spec::image::ArtifactManifest

source ·
pub struct ArtifactManifest { /* private fields */ }
Expand description

The OCI Artifact manifest describes content addressable artifacts in order to store them along side container images in a registry.

Implementations§

source§

impl ArtifactManifest

source

pub fn media_type(&self) -> &MediaType

This property MUST be used and contain the media type application/vnd.oci.artifact.manifest.v1+json.

source

pub fn artifact_type(&self) -> &MediaType

This property SHOULD be used and contain the mediaType of the referenced artifact. If defined, the value MUST comply with RFC 6838, including the naming requirements in its section 4.2, and MAY be registered with IANA.

source

pub fn blobs(&self) -> &Vec<Descriptor>

This OPTIONAL property is an array of objects and each item in the array MUST be a descriptor. Each descriptor represents an artifact of any IANA mediaType. The list MAY be ordered for certain artifact types like scan results.

source

pub fn subject(&self) -> &Option<Descriptor>

This OPTIONAL property specifies a descriptor of another manifest. This value, used by the referrers API, indicates a relationship to the specified manifest.

source

pub fn annotations(&self) -> &Option<HashMap<String, String>>

This OPTIONAL property contains additional metadata for the artifact manifest. This OPTIONAL property MUST use the annotation rules. See Pre-Defined Annotation Keys. Annotations MAY be used to filter the response from the referrers API.

source§

impl ArtifactManifest

source

pub fn blobs_mut(&mut self) -> &mut Vec<Descriptor>

This OPTIONAL property is an array of objects and each item in the array MUST be a descriptor. Each descriptor represents an artifact of any IANA mediaType. The list MAY be ordered for certain artifact types like scan results.

source

pub fn annotations_mut(&mut self) -> &mut Option<HashMap<String, String>>

This OPTIONAL property contains additional metadata for the artifact manifest. This OPTIONAL property MUST use the annotation rules. See Pre-Defined Annotation Keys. Annotations MAY be used to filter the response from the referrers API.

source§

impl ArtifactManifest

source

pub fn set_artifact_type(&mut self, val: MediaType) -> &mut Self

This property SHOULD be used and contain the mediaType of the referenced artifact. If defined, the value MUST comply with RFC 6838, including the naming requirements in its section 4.2, and MAY be registered with IANA.

source

pub fn set_blobs(&mut self, val: Vec<Descriptor>) -> &mut Self

This OPTIONAL property is an array of objects and each item in the array MUST be a descriptor. Each descriptor represents an artifact of any IANA mediaType. The list MAY be ordered for certain artifact types like scan results.

source

pub fn set_subject(&mut self, val: Option<Descriptor>) -> &mut Self

This OPTIONAL property specifies a descriptor of another manifest. This value, used by the referrers API, indicates a relationship to the specified manifest.

source

pub fn set_annotations( &mut self, val: Option<HashMap<String, String>>, ) -> &mut Self

This OPTIONAL property contains additional metadata for the artifact manifest. This OPTIONAL property MUST use the annotation rules. See Pre-Defined Annotation Keys. Annotations MAY be used to filter the response from the referrers API.

source§

impl ArtifactManifest

source

pub fn from_file(path: impl AsRef<Path>) -> Result<Self>

Attempts to load an image manifest from a file.

§Errors
§Example
use oci_spec::image::ArtifactManifest;

let artifact_manifest = ArtifactManifest::from_file("manifest.json").unwrap();
source

pub fn from_reader<R: Read>(reader: R) -> Result<Self>

Attempts to load an image manifest from a stream.

§Errors
§Example
use oci_spec::image::ArtifactManifest;
use std::fs::File;

let reader = File::open("manifest.json").unwrap();
let artifact_manifest = ArtifactManifest::from_reader(reader).unwrap();
source

pub fn to_file<P: AsRef<Path>>(&self, path: P) -> Result<()>

Attempts to write an image manifest to a file as JSON. If the file already exists, it will be overwritten.

§Errors
§Example
use oci_spec::image::ArtifactManifest;

let artifact_manifest = ArtifactManifest::from_file("manifest.json").unwrap();
artifact_manifest.to_file("my-manifest.json").unwrap();
source

pub fn to_file_pretty<P: AsRef<Path>>(&self, path: P) -> Result<()>

Attempts to write an image manifest to a file as pretty printed JSON. If the file already exists, it will be overwritten.

§Errors
§Example
use oci_spec::image::ArtifactManifest;

let artifact_manifest = ArtifactManifest::from_file("manifest.json").unwrap();
artifact_manifest.to_file_pretty("my-manifest.json").unwrap();
source

pub fn to_writer<W: Write>(&self, writer: &mut W) -> Result<()>

Attempts to write an image manifest to a stream as JSON.

§Errors
§Example
use oci_spec::image::ArtifactManifest;

let artifact_manifest = ArtifactManifest::from_file("manifest.json").unwrap();
let mut writer = Vec::new();
artifact_manifest.to_writer(&mut writer);
source

pub fn to_writer_pretty<W: Write>(&self, writer: &mut W) -> Result<()>

Attempts to write an image manifest to a stream as pretty printed JSON.

§Errors
§Example
use oci_spec::image::ArtifactManifest;

let artifact_manifest = ArtifactManifest::from_file("manifest.json").unwrap();
let mut writer = Vec::new();
artifact_manifest.to_writer_pretty(&mut writer);
source

pub fn to_string(&self) -> Result<String>

Attempts to write an image manifest to a string as JSON.

§Errors
§Example
use oci_spec::image::ArtifactManifest;

let artifact_manifest = ArtifactManifest::from_file("manifest.json").unwrap();
let json_str = artifact_manifest.to_string().unwrap();
source

pub fn to_string_pretty(&self) -> Result<String>

Attempts to write an image manifest to a string as pretty printed JSON.

§Errors
§Example
use oci_spec::image::ArtifactManifest;

let artifact_manifest = ArtifactManifest::from_file("manifest.json").unwrap();
let json_str = artifact_manifest.to_string_pretty().unwrap();

Trait Implementations§

source§

impl Clone for ArtifactManifest

source§

fn clone(&self) -> ArtifactManifest

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for ArtifactManifest

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'de> Deserialize<'de> for ArtifactManifest

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl PartialEq for ArtifactManifest

source§

fn eq(&self, other: &ArtifactManifest) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Serialize for ArtifactManifest

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Eq for ArtifactManifest

source§

impl StructuralPartialEq for ArtifactManifest

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,