#[non_exhaustive]pub enum Patch<T>where
T: Serialize,{
Apply(T),
Json(Patch),
Merge(T),
Strategic(T),
}
Available on crate feature
client
only.Expand description
Describes changes that should be applied to a resource
Takes arbitrary serializable data for all strategies except Json
.
We recommend using (server-side) Apply
patches on new kubernetes releases.
See kubernetes patch docs for the older patch types.
Note that patches have different effects on different fields depending on their merge strategies.
These strategies are configurable when deriving your CustomResource
.
§Creating a patch via serde_json
use kube::api::Patch;
let patch = serde_json::json!({
"apiVersion": "v1",
"kind": "Pod",
"metadata": {
"name": "blog"
},
"spec": {
"activeDeadlineSeconds": 5
}
});
let patch = Patch::Apply(&patch);
§Creating a patch from a type
use kube::api::Patch;
use k8s_openapi::api::rbac::v1::Role;
use k8s_openapi::apimachinery::pkg::apis::meta::v1::ObjectMeta;
let r = Role {
metadata: ObjectMeta { name: Some("user".into()), ..ObjectMeta::default() },
rules: Some(vec![])
};
let patch = Patch::Apply(&r);
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
Apply(T)
Requires kubernetes >= 1.16
Json(Patch)
Using this variant will require you to explicitly provide a type for T
at the moment.
§Example
use kube::api::Patch;
let json_patch = json_patch::Patch(vec![]);
let patch = Patch::Json::<()>(json_patch);
Merge(T)
Strategic(T)
Trait Implementations§
impl<T> StructuralPartialEq for Patch<T>where
T: Serialize,
Auto Trait Implementations§
impl<T> Freeze for Patch<T>where
T: Freeze,
impl<T> RefUnwindSafe for Patch<T>where
T: RefUnwindSafe,
impl<T> Send for Patch<T>where
T: Send,
impl<T> Sync for Patch<T>where
T: Sync,
impl<T> Unpin for Patch<T>where
T: Unpin,
impl<T> UnwindSafe for Patch<T>where
T: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more