io.k8s.api.admissionregistration.v1alpha1.NamedRuleWithOperations Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bl-k8s130 Show documentation
Show all versions of bl-k8s130 Show documentation
Programmatic resource management for Kubernetes
package io.k8s.api.admissionregistration.v1alpha1;
import java.lang.String;
import java.util.List;
/**
* NamedRuleWithOperations is a tuple of Operations and Resources with ResourceNames.
*/
public class NamedRuleWithOperations {
public List apiGroups;
public List apiVersions;
public List operations;
public List resourceNames;
public List resources;
public String scope;
/**
* APIGroups is the API groups the resources belong to. '*
' is all groups. If '*
' is present, the length of the slice must be one. Required.
*/
public NamedRuleWithOperations apiGroups(List apiGroups) {
this.apiGroups = apiGroups;
return this;
}
/**
* APIVersions is the API versions the resources belong to. '*
' is all versions. If '*
' is present, the length of the slice must be one. Required.
*/
public NamedRuleWithOperations apiVersions(List apiVersions) {
this.apiVersions = apiVersions;
return this;
}
/**
* Operations is the operations the admission hook cares about - CREATE, UPDATE, DELETE, CONNECT or *
for all of those operations and any future admission operations that are added. If '*
' is present, the length of the slice must be one. Required.
*/
public NamedRuleWithOperations operations(List operations) {
this.operations = operations;
return this;
}
/**
* ResourceNames is an optional white list of names that the rule applies to. An empty set means that everything is allowed.
*/
public NamedRuleWithOperations resourceNames(List resourceNames) {
this.resourceNames = resourceNames;
return this;
}
/**
* Resources is a list of resources this rule applies to.
*
* For example: 'pods' means pods. 'pods/log' means the log subresource of pods. '*
' means all resources, but not subresources. 'pods/*
' means all subresources of pods. '*
/scale' means all scale subresources. '*
/*
' means all resources and their subresources.
*
* If wildcard is present, the validation rule will ensure resources do not overlap with each other.
*
* Depending on the enclosing object, subresources might not be allowed. Required.
*/
public NamedRuleWithOperations resources(List resources) {
this.resources = resources;
return this;
}
/**
* scope specifies the scope of this rule. Valid values are "Cluster", "Namespaced", and "*
" "Cluster" means that only cluster-scoped resources will match this rule. Namespace API objects are cluster-scoped. "Namespaced" means that only namespaced resources will match this rule. "*
" means that there are no scope restrictions. Subresources match the scope of their parent resource. Default is "*
".
*/
public NamedRuleWithOperations scope(String scope) {
this.scope = scope;
return this;
}
public static NamedRuleWithOperations namedRuleWithOperations() {
return new NamedRuleWithOperations();
}
}