#[derive(Clone, Debug, Default, PartialEq)]
pub struct ListMeta {
pub continue_: Option<String>,
pub remaining_item_count: Option<i64>,
pub resource_version: Option<String>,
pub self_link: Option<String>,
}
impl crate::DeepMerge for ListMeta {
fn merge_from(&mut self, other: Self) {
crate::DeepMerge::merge_from(&mut self.continue_, other.continue_);
crate::DeepMerge::merge_from(&mut self.remaining_item_count, other.remaining_item_count);
crate::DeepMerge::merge_from(&mut self.resource_version, other.resource_version);
crate::DeepMerge::merge_from(&mut self.self_link, other.self_link);
}
}
impl<'de> crate::serde::Deserialize<'de> for ListMeta {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
#[allow(non_camel_case_types)]
enum Field {
Key_continue_,
Key_remaining_item_count,
Key_resource_version,
Key_self_link,
Other,
}
impl<'de> crate::serde::Deserialize<'de> for Field {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: crate::serde::Deserializer<'de> {
struct Visitor;
impl<'de> crate::serde::de::Visitor<'de> for Visitor {
type Value = Field;
fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_str("field identifier")
}
fn visit_str<E>(self, v: &str) -> Result<Self::Value, E> where E: crate::serde::de::Error {
Ok(match v {
"continue" => Field::Key_continue_,
"remainingItemCount" => Field::Key_remaining_item_count,
"resourceVersion" => Field::Key_resource_version,
"selfLink" => Field::Key_self_link,
_ => Field::Other,
})
}
}
deserializer.deserialize_identifier(Visitor)
}
}
struct Visitor;
impl<'de> crate::serde::de::Visitor<'de> for Visitor {
type Value = ListMeta;
fn expecting(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_str("ListMeta")
}
fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> where A: crate::serde::de::MapAccess<'de> {
let mut value_continue_: Option<String> = None;
let mut value_remaining_item_count: Option<i64> = None;
let mut value_resource_version: Option<String> = None;
let mut value_self_link: Option<String> = None;
while let Some(key) = crate::serde::de::MapAccess::next_key::<Field>(&mut map)? {
match key {
Field::Key_continue_ => value_continue_ = crate::serde::de::MapAccess::next_value(&mut map)?,
Field::Key_remaining_item_count => value_remaining_item_count = crate::serde::de::MapAccess::next_value(&mut map)?,
Field::Key_resource_version => value_resource_version = crate::serde::de::MapAccess::next_value(&mut map)?,
Field::Key_self_link => value_self_link = crate::serde::de::MapAccess::next_value(&mut map)?,
Field::Other => { let _: crate::serde::de::IgnoredAny = crate::serde::de::MapAccess::next_value(&mut map)?; },
}
}
Ok(ListMeta {
continue_: value_continue_,
remaining_item_count: value_remaining_item_count,
resource_version: value_resource_version,
self_link: value_self_link,
})
}
}
deserializer.deserialize_struct(
"ListMeta",
&[
"continue",
"remainingItemCount",
"resourceVersion",
"selfLink",
],
Visitor,
)
}
}
impl crate::serde::Serialize for ListMeta {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: crate::serde::Serializer {
let mut state = serializer.serialize_struct(
"ListMeta",
self.continue_.as_ref().map_or(0, |_| 1) +
self.remaining_item_count.as_ref().map_or(0, |_| 1) +
self.resource_version.as_ref().map_or(0, |_| 1) +
self.self_link.as_ref().map_or(0, |_| 1),
)?;
if let Some(value) = &self.continue_ {
crate::serde::ser::SerializeStruct::serialize_field(&mut state, "continue", value)?;
}
if let Some(value) = &self.remaining_item_count {
crate::serde::ser::SerializeStruct::serialize_field(&mut state, "remainingItemCount", value)?;
}
if let Some(value) = &self.resource_version {
crate::serde::ser::SerializeStruct::serialize_field(&mut state, "resourceVersion", value)?;
}
if let Some(value) = &self.self_link {
crate::serde::ser::SerializeStruct::serialize_field(&mut state, "selfLink", value)?;
}
crate::serde::ser::SerializeStruct::end(state)
}
}
#[cfg(feature = "schemars")]
impl crate::schemars::JsonSchema for ListMeta {
fn schema_name() -> String {
"io.k8s.apimachinery.pkg.apis.meta.v1.ListMeta".to_owned()
}
fn json_schema(__gen: &mut crate::schemars::gen::SchemaGenerator) -> crate::schemars::schema::Schema {
crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
metadata: Some(Box::new(crate::schemars::schema::Metadata {
description: Some("ListMeta describes metadata that synthetic resources must have, including lists and various status objects. A resource may have only one of {ObjectMeta, ListMeta}.".to_owned()),
..Default::default()
})),
instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::Object))),
object: Some(Box::new(crate::schemars::schema::ObjectValidation {
properties: [
(
"continue".to_owned(),
crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
metadata: Some(Box::new(crate::schemars::schema::Metadata {
description: Some("continue may be set if the user set a limit on the number of items returned, and indicates that the server has more data available. The value is opaque and may be used to issue another request to the endpoint that served this list to retrieve the next set of available objects. Continuing a consistent list may not be possible if the server configuration has changed or more than a few minutes have passed. The resourceVersion field returned when using this continue value will be identical to the value in the first response, unless you have received this token from an error message.".to_owned()),
..Default::default()
})),
instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::String))),
..Default::default()
}),
),
(
"remainingItemCount".to_owned(),
crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
metadata: Some(Box::new(crate::schemars::schema::Metadata {
description: Some("remainingItemCount is the number of subsequent items in the list which are not included in this list response. If the list request contained label or field selectors, then the number of remaining items is unknown and the field will be left unset and omitted during serialization. If the list is complete (either because it is not chunking or because this is the last chunk), then there are no more remaining items and this field will be left unset and omitted during serialization. Servers older than v1.15 do not set this field. The intended use of the remainingItemCount is *estimating* the size of a collection. Clients should not rely on the remainingItemCount to be set or to be exact.".to_owned()),
..Default::default()
})),
instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::Integer))),
format: Some("int64".to_owned()),
..Default::default()
}),
),
(
"resourceVersion".to_owned(),
crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
metadata: Some(Box::new(crate::schemars::schema::Metadata {
description: Some("String that identifies the server's internal version of this object that can be used by clients to determine when objects have changed. Value must be treated as opaque by clients and passed unmodified back to the server. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency".to_owned()),
..Default::default()
})),
instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::String))),
..Default::default()
}),
),
(
"selfLink".to_owned(),
crate::schemars::schema::Schema::Object(crate::schemars::schema::SchemaObject {
metadata: Some(Box::new(crate::schemars::schema::Metadata {
description: Some("Deprecated: selfLink is a legacy read-only field that is no longer populated by the system.".to_owned()),
..Default::default()
})),
instance_type: Some(crate::schemars::schema::SingleOrVec::Single(Box::new(crate::schemars::schema::InstanceType::String))),
..Default::default()
}),
),
].into(),
..Default::default()
})),
..Default::default()
})
}
}