pub struct CustomResourceDefinitionSpec {
pub conversion: Option<CustomResourceConversion>,
pub group: String,
pub names: CustomResourceDefinitionNames,
pub preserve_unknown_fields: Option<bool>,
pub scope: String,
pub versions: Vec<CustomResourceDefinitionVersion>,
}
Expand description
CustomResourceDefinitionSpec describes how a user wants their resource to appear
Fields§
§conversion: Option<CustomResourceConversion>
conversion defines conversion settings for the CRD.
group: String
group is the API group of the defined custom resource. The custom resources are served under /apis/\<group\>/...
. Must match the name of the CustomResourceDefinition (in the form \<names.plural\>.\<group\>
).
names: CustomResourceDefinitionNames
names specify the resource and kind names for the custom resource.
preserve_unknown_fields: Option<bool>
preserveUnknownFields indicates that object fields which are not specified in the OpenAPI schema should be preserved when persisting to storage. apiVersion, kind, metadata and known fields inside metadata are always preserved. This field is deprecated in favor of setting x-preserve-unknown-fields
to true in spec.versions\[*\].schema.openAPIV3Schema
. See https://kubernetes.io/docs/tasks/extend-kubernetes/custom-resources/custom-resource-definitions/#field-pruning for details.
scope: String
scope indicates whether the defined custom resource is cluster- or namespace-scoped. Allowed values are Cluster
and Namespaced
.
versions: Vec<CustomResourceDefinitionVersion>
versions is the list of all API versions of the defined custom resource. Version names are used to compute the order in which served versions are listed in API discovery. If the version string is “kube-like”, it will sort above non “kube-like” version strings, which are ordered lexicographically. “Kube-like” versions start with a “v”, then are followed by a number (the major version), then optionally the string “alpha” or “beta” and another number (the minor version). These are sorted first by GA > beta > alpha (where GA is a version with no suffix such as beta or alpha), and then by comparing major version, then minor version. An example sorted list of versions: v10, v2, v1, v11beta2, v10beta3, v3beta1, v12alpha1, v11alpha2, foo1, foo10.
Trait Implementations§
Source§impl Clone for CustomResourceDefinitionSpec
impl Clone for CustomResourceDefinitionSpec
Source§fn clone(&self) -> CustomResourceDefinitionSpec
fn clone(&self) -> CustomResourceDefinitionSpec
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for CustomResourceDefinitionSpec
impl Debug for CustomResourceDefinitionSpec
Source§impl DeepMerge for CustomResourceDefinitionSpec
impl DeepMerge for CustomResourceDefinitionSpec
Source§fn merge_from(&mut self, other: Self)
fn merge_from(&mut self, other: Self)
other
into self
.Source§impl Default for CustomResourceDefinitionSpec
impl Default for CustomResourceDefinitionSpec
Source§fn default() -> CustomResourceDefinitionSpec
fn default() -> CustomResourceDefinitionSpec
Source§impl<'de> Deserialize<'de> for CustomResourceDefinitionSpec
impl<'de> Deserialize<'de> for CustomResourceDefinitionSpec
Source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
Source§impl PartialEq for CustomResourceDefinitionSpec
impl PartialEq for CustomResourceDefinitionSpec
Source§fn eq(&self, other: &CustomResourceDefinitionSpec) -> bool
fn eq(&self, other: &CustomResourceDefinitionSpec) -> bool
self
and other
values to be equal, and is used by ==
.