From 2397f4cf67bbcd4781eb6e041aad47443222f7c2 Mon Sep 17 00:00:00 2001 From: wayne warren Date: Mon, 25 Sep 2023 17:27:01 -0600 Subject: [PATCH 1/4] manifest: support OCI Image Spec 1.1.0-rc5 Signed-off-by: wayne warren --- src/image/manifest.rs | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/src/image/manifest.rs b/src/image/manifest.rs index 6883473450..4cc0e24485 100644 --- a/src/image/manifest.rs +++ b/src/image/manifest.rs @@ -50,6 +50,15 @@ pub struct ImageManifest { #[getset(get = "pub", set = "pub")] #[builder(default)] media_type: Option, + /// This OPTIONAL property contains the type of an artifact when the manifest is used for an + /// artifact. This MUST be set when config.mediaType is set to the empty value. If defined, the + /// value MUST comply with RFC 6838, including the naming requirements in its section 4.2, and + /// MAY be registered with IANA. Implementations storing or copying image manifests MUST NOT + /// error on encountering an artifactType that is unknown to the implementation. + #[serde(skip_serializing_if = "Option::is_none")] + #[getset(get = "pub", set = "pub")] + #[builder(default)] + artifact_type: Option, /// This REQUIRED property references a configuration object for a /// container, by digest. Beyond the descriptor requirements, /// the value has the following additional restrictions: @@ -69,6 +78,12 @@ pub struct ImageManifest { /// attributes of the initial empty directory are unspecified. #[getset(get_mut = "pub", get = "pub", set = "pub")] layers: Vec, + /// This OPTIONAL property specifies a descriptor of another manifest. This value, used by the + /// referrers API, indicates a relationship to the specified manifest. + #[serde(skip_serializing_if = "Option::is_none")] + #[getset(get = "pub", set = "pub")] + #[builder(default)] + subject: Option, /// This OPTIONAL property contains arbitrary metadata for the image /// manifest. This OPTIONAL property MUST use the annotation /// rules. From b2d42de193ef030c1e39748892d789fc6d419b6e Mon Sep 17 00:00:00 2001 From: wayne warren Date: Mon, 25 Sep 2023 17:27:11 -0600 Subject: [PATCH 2/4] descriptor: support OCI Image Spec 1.1.0-rc5 Signed-off-by: wayne warren --- src/image/descriptor.rs | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/src/image/descriptor.rs b/src/image/descriptor.rs index 876b2ddfc3..20f177be08 100644 --- a/src/image/descriptor.rs +++ b/src/image/descriptor.rs @@ -60,6 +60,22 @@ pub struct Descriptor { #[getset(get = "pub", set = "pub")] #[builder(default)] platform: Option, + /// This OPTIONAL property contains the type of an artifact when the descriptor points to an + /// artifact. This is the value of the config descriptor mediaType when the descriptor + /// references an image manifest. If defined, the value MUST comply with RFC 6838, including + /// the naming requirements in its section 4.2, and MAY be registered with IANA. + #[serde(skip_serializing_if = "Option::is_none")] + #[getset(get = "pub", set = "pub")] + #[builder(default)] + artifact_type: Option, + /// This OPTIONAL property contains an embedded representation of the referenced content. + /// Values MUST conform to the Base 64 encoding, as defined in RFC 4648. The decoded data MUST + /// be identical to the referenced content and SHOULD be verified against the digest and size + /// fields by content consumers. See Embedded Content for when this is appropriate. + #[serde(skip_serializing_if = "Option::is_none")] + #[getset(get = "pub", set = "pub")] + #[builder(default)] + data: Option, } #[derive( @@ -109,6 +125,10 @@ pub struct Platform { #[serde(skip_serializing_if = "Option::is_none")] #[builder(default)] variant: Option, + /// This property is RESERVED for future versions of the specification. + #[serde(skip_serializing_if = "Option::is_none")] + #[builder(default)] + features: Option>, } impl Descriptor { @@ -121,6 +141,8 @@ impl Descriptor { urls: Default::default(), annotations: Default::default(), platform: Default::default(), + artifact_type: Default::default(), + data: Default::default(), } } } From 1607425ac5d8aa8dccc55376021bed0ccd96121b Mon Sep 17 00:00:00 2001 From: wayne warren Date: Mon, 25 Sep 2023 17:27:25 -0600 Subject: [PATCH 3/4] index: support OCI Image Spec 1.1.0-rc5 Signed-off-by: wayne warren --- src/image/index.rs | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/src/image/index.rs b/src/image/index.rs index 9758f784b7..e09adc345f 100644 --- a/src/image/index.rs +++ b/src/image/index.rs @@ -43,11 +43,24 @@ pub struct ImageIndex { #[getset(get = "pub", set = "pub")] #[builder(default)] media_type: Option, + /// This OPTIONAL property contains the type of an artifact when the manifest is used for an + /// 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. + #[serde(skip_serializing_if = "Option::is_none")] + #[getset(get = "pub", set = "pub")] + #[builder(default)] + artifact_type: Option, /// This REQUIRED property contains a list of manifests for specific /// platforms. While this property MUST be present, the size of /// the array MAY be zero. #[getset(get = "pub", set = "pub")] manifests: Vec, + /// This OPTIONAL property specifies a descriptor of another manifest. This value, used by the + /// referrers API, indicates a relationship to the specified manifest. + #[serde(skip_serializing_if = "Option::is_none")] + #[getset(get = "pub", set = "pub")] + #[builder(default)] + subject: Option, /// This OPTIONAL property contains arbitrary metadata for the image /// index. This OPTIONAL property MUST use the annotation rules. #[serde(skip_serializing_if = "Option::is_none")] @@ -191,6 +204,8 @@ impl Default for ImageIndex { media_type: Default::default(), manifests: Default::default(), annotations: Default::default(), + artifact_type: Default::default(), + subject: Default::default(), } } } From c40844960895a73931e08d89f7497fc504f33a2e Mon Sep 17 00:00:00 2001 From: wayne warren Date: Mon, 25 Sep 2023 18:05:08 -0600 Subject: [PATCH 4/4] image: support MediaType EmptyJSON Signed-off-by: wayne warren --- src/image/mod.rs | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/image/mod.rs b/src/image/mod.rs index 73a49fec10..2a5116eacd 100644 --- a/src/image/mod.rs +++ b/src/image/mod.rs @@ -60,6 +60,11 @@ pub enum MediaType { /// MediaType ArtifactManifest specifies the media type used for content addressable /// artifacts to store them along side container images in a registry. ArtifactManifest, + /// MediaType EmptyJSON specifies a descriptor that has no content for the implementation. The + /// blob payload is the most minimal content that is still a valid JSON object: {} (size of 2). + /// The blob digest of {} is + /// sha256:44136fa355b3678a1146ad16f7e8649e94fb4fc21fe77e8310c060f61caaff8a. + EmptyJSON, /// MediaType not specified by OCI image format. Other(String), } @@ -87,6 +92,7 @@ impl Display for MediaType { ), Self::ImageConfig => write!(f, "application/vnd.oci.image.config.v1+json"), Self::ArtifactManifest => write!(f, "application/vnd.oci.artifact.manifest.v1+json"), + Self::EmptyJSON => write!(f, "application/vnd.oci.empty.v1+json"), Self::Other(media_type) => write!(f, "{media_type}"), } } @@ -113,6 +119,7 @@ impl From<&str> for MediaType { } "application/vnd.oci.image.config.v1+json" => MediaType::ImageConfig, "application/vnd.oci.artifact.manifest.v1+json" => MediaType::ArtifactManifest, + "application/vnd.oci.empty.v1+json" => MediaType::EmptyJSON, media => MediaType::Other(media.to_owned()), } }