com.pulumi.kubernetes.flowcontrol.v1beta2.outputs.FlowSchemaSpecPatch Maven / Gradle / Ivy
// *** WARNING: this file was generated by pulumi-java-gen. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package com.pulumi.kubernetes.flowcontrol.v1beta2.outputs;
import com.pulumi.core.annotations.CustomType;
import com.pulumi.kubernetes.flowcontrol.v1beta2.outputs.FlowDistinguisherMethodPatch;
import com.pulumi.kubernetes.flowcontrol.v1beta2.outputs.PolicyRulesWithSubjectsPatch;
import com.pulumi.kubernetes.flowcontrol.v1beta2.outputs.PriorityLevelConfigurationReferencePatch;
import java.lang.Integer;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;
@CustomType
public final class FlowSchemaSpecPatch {
/**
* @return `distinguisherMethod` defines how to compute the flow distinguisher for requests that match this schema. `nil` specifies that the distinguisher is disabled and thus will always be the empty string.
*
*/
private @Nullable FlowDistinguisherMethodPatch distinguisherMethod;
/**
* @return `matchingPrecedence` is used to choose among the FlowSchemas that match a given request. The chosen FlowSchema is among those with the numerically lowest (which we take to be logically highest) MatchingPrecedence. Each MatchingPrecedence value must be ranged in [1,10000]. Note that if the precedence is not specified, it will be set to 1000 as default.
*
*/
private @Nullable Integer matchingPrecedence;
/**
* @return `priorityLevelConfiguration` should reference a PriorityLevelConfiguration in the cluster. If the reference cannot be resolved, the FlowSchema will be ignored and marked as invalid in its status. Required.
*
*/
private @Nullable PriorityLevelConfigurationReferencePatch priorityLevelConfiguration;
/**
* @return `rules` describes which requests will match this flow schema. This FlowSchema matches a request if and only if at least one member of rules matches the request. if it is an empty slice, there will be no requests matching the FlowSchema.
*
*/
private @Nullable List rules;
private FlowSchemaSpecPatch() {}
/**
* @return `distinguisherMethod` defines how to compute the flow distinguisher for requests that match this schema. `nil` specifies that the distinguisher is disabled and thus will always be the empty string.
*
*/
public Optional distinguisherMethod() {
return Optional.ofNullable(this.distinguisherMethod);
}
/**
* @return `matchingPrecedence` is used to choose among the FlowSchemas that match a given request. The chosen FlowSchema is among those with the numerically lowest (which we take to be logically highest) MatchingPrecedence. Each MatchingPrecedence value must be ranged in [1,10000]. Note that if the precedence is not specified, it will be set to 1000 as default.
*
*/
public Optional matchingPrecedence() {
return Optional.ofNullable(this.matchingPrecedence);
}
/**
* @return `priorityLevelConfiguration` should reference a PriorityLevelConfiguration in the cluster. If the reference cannot be resolved, the FlowSchema will be ignored and marked as invalid in its status. Required.
*
*/
public Optional priorityLevelConfiguration() {
return Optional.ofNullable(this.priorityLevelConfiguration);
}
/**
* @return `rules` describes which requests will match this flow schema. This FlowSchema matches a request if and only if at least one member of rules matches the request. if it is an empty slice, there will be no requests matching the FlowSchema.
*
*/
public List rules() {
return this.rules == null ? List.of() : this.rules;
}
public static Builder builder() {
return new Builder();
}
public static Builder builder(FlowSchemaSpecPatch defaults) {
return new Builder(defaults);
}
@CustomType.Builder
public static final class Builder {
private @Nullable FlowDistinguisherMethodPatch distinguisherMethod;
private @Nullable Integer matchingPrecedence;
private @Nullable PriorityLevelConfigurationReferencePatch priorityLevelConfiguration;
private @Nullable List rules;
public Builder() {}
public Builder(FlowSchemaSpecPatch defaults) {
Objects.requireNonNull(defaults);
this.distinguisherMethod = defaults.distinguisherMethod;
this.matchingPrecedence = defaults.matchingPrecedence;
this.priorityLevelConfiguration = defaults.priorityLevelConfiguration;
this.rules = defaults.rules;
}
@CustomType.Setter
public Builder distinguisherMethod(@Nullable FlowDistinguisherMethodPatch distinguisherMethod) {
this.distinguisherMethod = distinguisherMethod;
return this;
}
@CustomType.Setter
public Builder matchingPrecedence(@Nullable Integer matchingPrecedence) {
this.matchingPrecedence = matchingPrecedence;
return this;
}
@CustomType.Setter
public Builder priorityLevelConfiguration(@Nullable PriorityLevelConfigurationReferencePatch priorityLevelConfiguration) {
this.priorityLevelConfiguration = priorityLevelConfiguration;
return this;
}
@CustomType.Setter
public Builder rules(@Nullable List rules) {
this.rules = rules;
return this;
}
public Builder rules(PolicyRulesWithSubjectsPatch... rules) {
return rules(List.of(rules));
}
public FlowSchemaSpecPatch build() {
final var _resultValue = new FlowSchemaSpecPatch();
_resultValue.distinguisherMethod = distinguisherMethod;
_resultValue.matchingPrecedence = matchingPrecedence;
_resultValue.priorityLevelConfiguration = priorityLevelConfiguration;
_resultValue.rules = rules;
return _resultValue;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy