Class MutatingWebhook.Builder

  • Enclosing class:
    MutatingWebhook

    public static class MutatingWebhook.Builder
    extends java.lang.Object
    • Method Detail

      • addToAdmissionReviewVersions

        public MutatingWebhook.Builder addToAdmissionReviewVersions​(java.lang.String addToAdmissionReviewVersions)
      • admissionReviewVersions

        public MutatingWebhook.Builder admissionReviewVersions​(java.util.Collection<? extends java.lang.String> admissionReviewVersions)
      • 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.
      • 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.
      • 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.
      • toString

        public java.lang.String toString()
        Overrides:
        toString in class java.lang.Object