Class MutatingWebhook.Builder
- java.lang.Object
-
- com.marcnuri.yakc.model.io.k8s.api.admissionregistration.v1.MutatingWebhook.Builder
-
- Enclosing class:
- MutatingWebhook
public static class MutatingWebhook.Builder extends java.lang.Object
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description MutatingWebhook.Builder
addToAdmissionReviewVersions(java.lang.String addToAdmissionReviewVersions)
MutatingWebhook.Builder
addToRules(RuleWithOperations addToRules)
MutatingWebhook.Builder
admissionReviewVersions(java.util.Collection<? extends java.lang.String> admissionReviewVersions)
MutatingWebhook
build()
MutatingWebhook.Builder
clearAdmissionReviewVersions()
MutatingWebhook.Builder
clearRules()
MutatingWebhook.Builder
clientConfig(@NonNull WebhookClientConfig clientConfig)
MutatingWebhook.Builder
failurePolicy(java.lang.String failurePolicy)
FailurePolicy defines how unrecognized errors from the admission endpoint are handled - allowed values are Ignore or Fail.MutatingWebhook.Builder
matchPolicy(java.lang.String matchPolicy)
matchPolicy defines how the "rules" list is used to match incoming requests.MutatingWebhook.Builder
name(@NonNull java.lang.String name)
The name of the admission webhook.MutatingWebhook.Builder
namespaceSelector(LabelSelector namespaceSelector)
MutatingWebhook.Builder
objectSelector(LabelSelector objectSelector)
MutatingWebhook.Builder
reinvocationPolicy(java.lang.String reinvocationPolicy)
reinvocationPolicy indicates whether this webhook should be called multiple times as part of a single admission evaluation.MutatingWebhook.Builder
rules(java.util.Collection<? extends RuleWithOperations> rules)
MutatingWebhook.Builder
sideEffects(@NonNull java.lang.String sideEffects)
SideEffects states whether this webhook has side effects.MutatingWebhook.Builder
timeoutSeconds(java.lang.Number timeoutSeconds)
TimeoutSeconds specifies the timeout for this webhook.java.lang.String
toString()
-
-
-
Method Detail
-
addToAdmissionReviewVersions
public MutatingWebhook.Builder addToAdmissionReviewVersions(java.lang.String addToAdmissionReviewVersions)
-
admissionReviewVersions
public MutatingWebhook.Builder admissionReviewVersions(java.util.Collection<? extends java.lang.String> admissionReviewVersions)
-
clearAdmissionReviewVersions
public MutatingWebhook.Builder clearAdmissionReviewVersions()
-
clientConfig
public MutatingWebhook.Builder clientConfig(@NonNull @NonNull WebhookClientConfig clientConfig)
-
failurePolicy
public MutatingWebhook.Builder failurePolicy(java.lang.String failurePolicy)
FailurePolicy defines how unrecognized errors from the admission endpoint are handled - allowed values are Ignore or Fail. Defaults to Fail.- Returns:
this
.
-
matchPolicy
public MutatingWebhook.Builder matchPolicy(java.lang.String matchPolicy)
matchPolicy defines how the "rules" list is used to match incoming requests. Allowed values are "Exact" or "Equivalent".- Exact: match a request only if it exactly matches a specified rule. For example, if deployments can be modified via apps/v1, apps/v1beta1, and extensions/v1beta1, but "rules" only included `apiGroups:["apps"], apiVersions:["v1"], resources: ["deployments"]`, a request to apps/v1beta1 or extensions/v1beta1 would not be sent to the webhook.
- Equivalent: match a request if modifies a resource listed in rules, even via another API group or version. For example, if deployments can be modified via apps/v1, apps/v1beta1, and extensions/v1beta1, and "rules" only included `apiGroups:["apps"], apiVersions:["v1"], resources: ["deployments"]`, a request to apps/v1beta1 or extensions/v1beta1 would be converted to apps/v1 and sent to the webhook.
Defaults to "Equivalent"
- Returns:
this
.
-
name
public MutatingWebhook.Builder name(@NonNull @NonNull java.lang.String name)
The name of the admission webhook. Name should be fully qualified, e.g., imagepolicy.kubernetes.io, where "imagepolicy" is the name of the webhook, and kubernetes.io is the name of the organization. Required.- Returns:
this
.
-
namespaceSelector
public MutatingWebhook.Builder namespaceSelector(LabelSelector namespaceSelector)
-
objectSelector
public MutatingWebhook.Builder objectSelector(LabelSelector objectSelector)
-
reinvocationPolicy
public MutatingWebhook.Builder reinvocationPolicy(java.lang.String reinvocationPolicy)
reinvocationPolicy indicates whether this webhook should be called multiple times as part of a single admission evaluation. Allowed values are "Never" and "IfNeeded".Never: the webhook will not be called more than once in a single admission evaluation.
IfNeeded: the webhook will be called at least one additional time as part of the admission evaluation if the object being admitted is modified by other admission plugins after the initial webhook call. Webhooks that specify this option *must* be idempotent, able to process objects they previously admitted. Note: * the number of additional invocations is not guaranteed to be exactly one. * if additional invocations result in further modifications to the object, webhooks are not guaranteed to be invoked again. * webhooks that use this option may be reordered to minimize the number of additional invocations. * to validate an object after all mutations are guaranteed complete, use a validating admission webhook instead.
Defaults to "Never".
- Returns:
this
.
-
addToRules
public MutatingWebhook.Builder addToRules(RuleWithOperations addToRules)
-
rules
public MutatingWebhook.Builder rules(java.util.Collection<? extends RuleWithOperations> rules)
-
clearRules
public MutatingWebhook.Builder clearRules()
-
sideEffects
public MutatingWebhook.Builder sideEffects(@NonNull @NonNull java.lang.String sideEffects)
SideEffects states whether this webhook has side effects. Acceptable values are: None, NoneOnDryRun (webhooks created via v1beta1 may also specify Some or Unknown). Webhooks with side effects MUST implement a reconciliation system, since a request may be rejected by a future step in the admission chain and the side effects therefore need to be undone. Requests with the dryRun attribute will be auto-rejected if they match a webhook with sideEffects == Unknown or Some.- Returns:
this
.
-
timeoutSeconds
public MutatingWebhook.Builder timeoutSeconds(java.lang.Number timeoutSeconds)
TimeoutSeconds specifies the timeout for this webhook. After the timeout passes, the webhook call will be ignored or the API call will fail based on the failure policy. The timeout value must be between 1 and 30 seconds. Default to 10 seconds.- Returns:
this
.
-
build
public MutatingWebhook build()
-
toString
public java.lang.String toString()
- Overrides:
toString
in classjava.lang.Object
-
-