pub struct VolumeAttributesClass {
    pub driver_name: String,
    pub metadata: ObjectMeta,
    pub parameters: Option<BTreeMap<String, String>>,
}
Expand description

VolumeAttributesClass represents a specification of mutable volume attributes defined by the CSI driver. The class can be specified during dynamic provisioning of PersistentVolumeClaims, and changed in the PersistentVolumeClaim spec after provisioning.

Fields§

§driver_name: String

Name of the CSI driver This field is immutable.

§metadata: ObjectMeta

Standard object’s metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata

§parameters: Option<BTreeMap<String, String>>

parameters hold volume attributes defined by the CSI driver. These values are opaque to the Kubernetes and are passed directly to the CSI driver. The underlying storage provider supports changing these attributes on an existing volume, however the parameters field itself is immutable. To invoke a volume update, a new VolumeAttributesClass should be created with new parameters, and the PersistentVolumeClaim should be updated to reference the new VolumeAttributesClass.

This field is required and must contain at least one key/value pair. The keys cannot be empty, and the maximum number of parameters is 512, with a cumulative max size of 256K. If the CSI driver rejects invalid parameters, the target PersistentVolumeClaim will be set to an “Infeasible” state in the modifyVolumeStatus field.

Trait Implementations§

source§

impl Clone for VolumeAttributesClass

source§

fn clone(&self) -> VolumeAttributesClass

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 VolumeAttributesClass

source§

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

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

impl DeepMerge for VolumeAttributesClass

source§

fn merge_from(&mut self, other: Self)

Merge other into self.
source§

impl Default for VolumeAttributesClass

source§

fn default() -> VolumeAttributesClass

Returns the “default value” for a type. Read more
source§

impl<'de> Deserialize<'de> for VolumeAttributesClass

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 ListableResource for VolumeAttributesClass

source§

const LIST_KIND: &'static str = "VolumeAttributesClassList"

The kind of the list type of the resource. Read more
source§

impl Metadata for VolumeAttributesClass

§

type Ty = ObjectMeta

The type of the metadata object.
source§

fn metadata(&self) -> &<Self as Metadata>::Ty

Gets a reference to the metadata of this resource value.
source§

fn metadata_mut(&mut self) -> &mut <Self as Metadata>::Ty

Gets a mutable reference to the metadata of this resource value.
source§

impl PartialEq for VolumeAttributesClass

source§

fn eq(&self, other: &VolumeAttributesClass) -> 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 Resource for VolumeAttributesClass

source§

const API_VERSION: &'static str = "storage.k8s.io/v1alpha1"

The API version of the resource. This is a composite of Resource::GROUP and Resource::VERSION (eg "apiextensions.k8s.io/v1beta1") or just the version for resources without a group (eg "v1"). Read more
source§

const GROUP: &'static str = "storage.k8s.io"

The group of the resource, or the empty string if the resource doesn’t have a group.
source§

const KIND: &'static str = "VolumeAttributesClass"

The kind of the resource. Read more
source§

const VERSION: &'static str = "v1alpha1"

The version of the resource.
source§

const URL_PATH_SEGMENT: &'static str = "volumeattributesclasses"

The URL path segment used to construct URLs related to this resource. Read more
§

type Scope = ClusterResourceScope

Indicates whether the resource is namespace-scoped or cluster-scoped or a subresource. Read more
source§

impl Serialize for VolumeAttributesClass

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 StructuralPartialEq for VolumeAttributesClass

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> 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>,