All Downloads are FREE. Search and download functionalities are using the official Maven repository.

software.amazon.awssdk.services.fms.model.DnsRuleGroupPriorityConflictViolation Maven / Gradle / Ivy

Go to download

The AWS Java SDK for FMS module holds the client classes that are used for communicating with FMS.

There is a newer version: 2.30.1
Show newest version
/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */

package software.amazon.awssdk.services.fms.model;

import java.io.Serializable;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * 

* A rule group that Firewall Manager tried to associate with a VPC has the same priority as a rule group that's already * associated. *

*/ @Generated("software.amazon.awssdk:codegen") public final class DnsRuleGroupPriorityConflictViolation implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField VIOLATION_TARGET_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("ViolationTarget").getter(getter(DnsRuleGroupPriorityConflictViolation::violationTarget)) .setter(setter(Builder::violationTarget)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ViolationTarget").build()).build(); private static final SdkField VIOLATION_TARGET_DESCRIPTION_FIELD = SdkField . builder(MarshallingType.STRING) .memberName("ViolationTargetDescription") .getter(getter(DnsRuleGroupPriorityConflictViolation::violationTargetDescription)) .setter(setter(Builder::violationTargetDescription)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ViolationTargetDescription").build()) .build(); private static final SdkField CONFLICTING_PRIORITY_FIELD = SdkField. builder(MarshallingType.INTEGER) .memberName("ConflictingPriority").getter(getter(DnsRuleGroupPriorityConflictViolation::conflictingPriority)) .setter(setter(Builder::conflictingPriority)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ConflictingPriority").build()) .build(); private static final SdkField CONFLICTING_POLICY_ID_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("ConflictingPolicyId").getter(getter(DnsRuleGroupPriorityConflictViolation::conflictingPolicyId)) .setter(setter(Builder::conflictingPolicyId)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ConflictingPolicyId").build()) .build(); private static final SdkField> UNAVAILABLE_PRIORITIES_FIELD = SdkField .> builder(MarshallingType.LIST) .memberName("UnavailablePriorities") .getter(getter(DnsRuleGroupPriorityConflictViolation::unavailablePriorities)) .setter(setter(Builder::unavailablePriorities)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("UnavailablePriorities").build(), ListTrait .builder() .memberLocationName(null) .memberFieldInfo( SdkField. builder(MarshallingType.INTEGER) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD) .locationName("member").build()).build()).build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(VIOLATION_TARGET_FIELD, VIOLATION_TARGET_DESCRIPTION_FIELD, CONFLICTING_PRIORITY_FIELD, CONFLICTING_POLICY_ID_FIELD, UNAVAILABLE_PRIORITIES_FIELD)); private static final long serialVersionUID = 1L; private final String violationTarget; private final String violationTargetDescription; private final Integer conflictingPriority; private final String conflictingPolicyId; private final List unavailablePriorities; private DnsRuleGroupPriorityConflictViolation(BuilderImpl builder) { this.violationTarget = builder.violationTarget; this.violationTargetDescription = builder.violationTargetDescription; this.conflictingPriority = builder.conflictingPriority; this.conflictingPolicyId = builder.conflictingPolicyId; this.unavailablePriorities = builder.unavailablePriorities; } /** *

* The ID of the VPC. *

* * @return The ID of the VPC. */ public final String violationTarget() { return violationTarget; } /** *

* A description of the violation that specifies the VPC and the rule group that's already associated with it. *

* * @return A description of the violation that specifies the VPC and the rule group that's already associated with * it. */ public final String violationTargetDescription() { return violationTargetDescription; } /** *

* The priority setting of the two conflicting rule groups. *

* * @return The priority setting of the two conflicting rule groups. */ public final Integer conflictingPriority() { return conflictingPriority; } /** *

* The ID of the Firewall Manager DNS Firewall policy that was already applied to the VPC. This policy contains the * rule group that's already associated with the VPC. *

* * @return The ID of the Firewall Manager DNS Firewall policy that was already applied to the VPC. This policy * contains the rule group that's already associated with the VPC. */ public final String conflictingPolicyId() { return conflictingPolicyId; } /** * Returns true if the UnavailablePriorities property was specified by the sender (it may be empty), or false if the * sender did not specify the value (it will be empty). For responses returned by the SDK, the sender is the AWS * service. */ public final boolean hasUnavailablePriorities() { return unavailablePriorities != null && !(unavailablePriorities instanceof SdkAutoConstructList); } /** *

* The priorities of rule groups that are already associated with the VPC. To retry your operation, choose priority * settings that aren't in this list for the rule groups in your new DNS Firewall policy. *

*

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

*

* You can use {@link #hasUnavailablePriorities()} to see if a value was sent in this field. *

* * @return The priorities of rule groups that are already associated with the VPC. To retry your operation, choose * priority settings that aren't in this list for the rule groups in your new DNS Firewall policy. */ public final List unavailablePriorities() { return unavailablePriorities; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(violationTarget()); hashCode = 31 * hashCode + Objects.hashCode(violationTargetDescription()); hashCode = 31 * hashCode + Objects.hashCode(conflictingPriority()); hashCode = 31 * hashCode + Objects.hashCode(conflictingPolicyId()); hashCode = 31 * hashCode + Objects.hashCode(hasUnavailablePriorities() ? unavailablePriorities() : null); return hashCode; } @Override public final boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof DnsRuleGroupPriorityConflictViolation)) { return false; } DnsRuleGroupPriorityConflictViolation other = (DnsRuleGroupPriorityConflictViolation) obj; return Objects.equals(violationTarget(), other.violationTarget()) && Objects.equals(violationTargetDescription(), other.violationTargetDescription()) && Objects.equals(conflictingPriority(), other.conflictingPriority()) && Objects.equals(conflictingPolicyId(), other.conflictingPolicyId()) && hasUnavailablePriorities() == other.hasUnavailablePriorities() && Objects.equals(unavailablePriorities(), other.unavailablePriorities()); } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. */ @Override public final String toString() { return ToString.builder("DnsRuleGroupPriorityConflictViolation").add("ViolationTarget", violationTarget()) .add("ViolationTargetDescription", violationTargetDescription()) .add("ConflictingPriority", conflictingPriority()).add("ConflictingPolicyId", conflictingPolicyId()) .add("UnavailablePriorities", hasUnavailablePriorities() ? unavailablePriorities() : null).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "ViolationTarget": return Optional.ofNullable(clazz.cast(violationTarget())); case "ViolationTargetDescription": return Optional.ofNullable(clazz.cast(violationTargetDescription())); case "ConflictingPriority": return Optional.ofNullable(clazz.cast(conflictingPriority())); case "ConflictingPolicyId": return Optional.ofNullable(clazz.cast(conflictingPolicyId())); case "UnavailablePriorities": return Optional.ofNullable(clazz.cast(unavailablePriorities())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((DnsRuleGroupPriorityConflictViolation) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* The ID of the VPC. *

* * @param violationTarget * The ID of the VPC. * @return Returns a reference to this object so that method calls can be chained together. */ Builder violationTarget(String violationTarget); /** *

* A description of the violation that specifies the VPC and the rule group that's already associated with it. *

* * @param violationTargetDescription * A description of the violation that specifies the VPC and the rule group that's already associated * with it. * @return Returns a reference to this object so that method calls can be chained together. */ Builder violationTargetDescription(String violationTargetDescription); /** *

* The priority setting of the two conflicting rule groups. *

* * @param conflictingPriority * The priority setting of the two conflicting rule groups. * @return Returns a reference to this object so that method calls can be chained together. */ Builder conflictingPriority(Integer conflictingPriority); /** *

* The ID of the Firewall Manager DNS Firewall policy that was already applied to the VPC. This policy contains * the rule group that's already associated with the VPC. *

* * @param conflictingPolicyId * The ID of the Firewall Manager DNS Firewall policy that was already applied to the VPC. This policy * contains the rule group that's already associated with the VPC. * @return Returns a reference to this object so that method calls can be chained together. */ Builder conflictingPolicyId(String conflictingPolicyId); /** *

* The priorities of rule groups that are already associated with the VPC. To retry your operation, choose * priority settings that aren't in this list for the rule groups in your new DNS Firewall policy. *

* * @param unavailablePriorities * The priorities of rule groups that are already associated with the VPC. To retry your operation, * choose priority settings that aren't in this list for the rule groups in your new DNS Firewall policy. * @return Returns a reference to this object so that method calls can be chained together. */ Builder unavailablePriorities(Collection unavailablePriorities); /** *

* The priorities of rule groups that are already associated with the VPC. To retry your operation, choose * priority settings that aren't in this list for the rule groups in your new DNS Firewall policy. *

* * @param unavailablePriorities * The priorities of rule groups that are already associated with the VPC. To retry your operation, * choose priority settings that aren't in this list for the rule groups in your new DNS Firewall policy. * @return Returns a reference to this object so that method calls can be chained together. */ Builder unavailablePriorities(Integer... unavailablePriorities); } static final class BuilderImpl implements Builder { private String violationTarget; private String violationTargetDescription; private Integer conflictingPriority; private String conflictingPolicyId; private List unavailablePriorities = DefaultSdkAutoConstructList.getInstance(); private BuilderImpl() { } private BuilderImpl(DnsRuleGroupPriorityConflictViolation model) { violationTarget(model.violationTarget); violationTargetDescription(model.violationTargetDescription); conflictingPriority(model.conflictingPriority); conflictingPolicyId(model.conflictingPolicyId); unavailablePriorities(model.unavailablePriorities); } public final String getViolationTarget() { return violationTarget; } @Override public final Builder violationTarget(String violationTarget) { this.violationTarget = violationTarget; return this; } public final void setViolationTarget(String violationTarget) { this.violationTarget = violationTarget; } public final String getViolationTargetDescription() { return violationTargetDescription; } @Override public final Builder violationTargetDescription(String violationTargetDescription) { this.violationTargetDescription = violationTargetDescription; return this; } public final void setViolationTargetDescription(String violationTargetDescription) { this.violationTargetDescription = violationTargetDescription; } public final Integer getConflictingPriority() { return conflictingPriority; } @Override public final Builder conflictingPriority(Integer conflictingPriority) { this.conflictingPriority = conflictingPriority; return this; } public final void setConflictingPriority(Integer conflictingPriority) { this.conflictingPriority = conflictingPriority; } public final String getConflictingPolicyId() { return conflictingPolicyId; } @Override public final Builder conflictingPolicyId(String conflictingPolicyId) { this.conflictingPolicyId = conflictingPolicyId; return this; } public final void setConflictingPolicyId(String conflictingPolicyId) { this.conflictingPolicyId = conflictingPolicyId; } public final Collection getUnavailablePriorities() { if (unavailablePriorities instanceof SdkAutoConstructList) { return null; } return unavailablePriorities; } @Override public final Builder unavailablePriorities(Collection unavailablePriorities) { this.unavailablePriorities = DnsRuleGroupPrioritiesCopier.copy(unavailablePriorities); return this; } @Override @SafeVarargs public final Builder unavailablePriorities(Integer... unavailablePriorities) { unavailablePriorities(Arrays.asList(unavailablePriorities)); return this; } public final void setUnavailablePriorities(Collection unavailablePriorities) { this.unavailablePriorities = DnsRuleGroupPrioritiesCopier.copy(unavailablePriorities); } @Override public DnsRuleGroupPriorityConflictViolation build() { return new DnsRuleGroupPriorityConflictViolation(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy