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

software.amazon.awssdk.services.fms.model.EC2ReplaceRouteAction 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.29.15
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.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
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.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * 

* Information about the ReplaceRoute action in Amazon EC2. *

*/ @Generated("software.amazon.awssdk:codegen") public final class EC2ReplaceRouteAction implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField DESCRIPTION_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("Description").getter(getter(EC2ReplaceRouteAction::description)).setter(setter(Builder::description)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Description").build()).build(); private static final SdkField DESTINATION_CIDR_BLOCK_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("DestinationCidrBlock").getter(getter(EC2ReplaceRouteAction::destinationCidrBlock)) .setter(setter(Builder::destinationCidrBlock)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("DestinationCidrBlock").build()) .build(); private static final SdkField DESTINATION_PREFIX_LIST_ID_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("DestinationPrefixListId").getter(getter(EC2ReplaceRouteAction::destinationPrefixListId)) .setter(setter(Builder::destinationPrefixListId)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("DestinationPrefixListId").build()) .build(); private static final SdkField DESTINATION_IPV6_CIDR_BLOCK_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("DestinationIpv6CidrBlock").getter(getter(EC2ReplaceRouteAction::destinationIpv6CidrBlock)) .setter(setter(Builder::destinationIpv6CidrBlock)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("DestinationIpv6CidrBlock").build()) .build(); private static final SdkField GATEWAY_ID_FIELD = SdkField. builder(MarshallingType.SDK_POJO) .memberName("GatewayId").getter(getter(EC2ReplaceRouteAction::gatewayId)).setter(setter(Builder::gatewayId)) .constructor(ActionTarget::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("GatewayId").build()).build(); private static final SdkField ROUTE_TABLE_ID_FIELD = SdkField. builder(MarshallingType.SDK_POJO) .memberName("RouteTableId").getter(getter(EC2ReplaceRouteAction::routeTableId)).setter(setter(Builder::routeTableId)) .constructor(ActionTarget::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("RouteTableId").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(DESCRIPTION_FIELD, DESTINATION_CIDR_BLOCK_FIELD, DESTINATION_PREFIX_LIST_ID_FIELD, DESTINATION_IPV6_CIDR_BLOCK_FIELD, GATEWAY_ID_FIELD, ROUTE_TABLE_ID_FIELD)); private static final long serialVersionUID = 1L; private final String description; private final String destinationCidrBlock; private final String destinationPrefixListId; private final String destinationIpv6CidrBlock; private final ActionTarget gatewayId; private final ActionTarget routeTableId; private EC2ReplaceRouteAction(BuilderImpl builder) { this.description = builder.description; this.destinationCidrBlock = builder.destinationCidrBlock; this.destinationPrefixListId = builder.destinationPrefixListId; this.destinationIpv6CidrBlock = builder.destinationIpv6CidrBlock; this.gatewayId = builder.gatewayId; this.routeTableId = builder.routeTableId; } /** *

* A description of the ReplaceRoute action in Amazon EC2. *

* * @return A description of the ReplaceRoute action in Amazon EC2. */ public final String description() { return description; } /** *

* Information about the IPv4 CIDR address block used for the destination match. The value that you provide must * match the CIDR of an existing route in the table. *

* * @return Information about the IPv4 CIDR address block used for the destination match. The value that you provide * must match the CIDR of an existing route in the table. */ public final String destinationCidrBlock() { return destinationCidrBlock; } /** *

* Information about the ID of the prefix list for the route. *

* * @return Information about the ID of the prefix list for the route. */ public final String destinationPrefixListId() { return destinationPrefixListId; } /** *

* Information about the IPv6 CIDR address block used for the destination match. The value that you provide must * match the CIDR of an existing route in the table. *

* * @return Information about the IPv6 CIDR address block used for the destination match. The value that you provide * must match the CIDR of an existing route in the table. */ public final String destinationIpv6CidrBlock() { return destinationIpv6CidrBlock; } /** *

* Information about the ID of an internet gateway or virtual private gateway. *

* * @return Information about the ID of an internet gateway or virtual private gateway. */ public final ActionTarget gatewayId() { return gatewayId; } /** *

* Information about the ID of the route table. *

* * @return Information about the ID of the route table. */ public final ActionTarget routeTableId() { return routeTableId; } @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(description()); hashCode = 31 * hashCode + Objects.hashCode(destinationCidrBlock()); hashCode = 31 * hashCode + Objects.hashCode(destinationPrefixListId()); hashCode = 31 * hashCode + Objects.hashCode(destinationIpv6CidrBlock()); hashCode = 31 * hashCode + Objects.hashCode(gatewayId()); hashCode = 31 * hashCode + Objects.hashCode(routeTableId()); 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 EC2ReplaceRouteAction)) { return false; } EC2ReplaceRouteAction other = (EC2ReplaceRouteAction) obj; return Objects.equals(description(), other.description()) && Objects.equals(destinationCidrBlock(), other.destinationCidrBlock()) && Objects.equals(destinationPrefixListId(), other.destinationPrefixListId()) && Objects.equals(destinationIpv6CidrBlock(), other.destinationIpv6CidrBlock()) && Objects.equals(gatewayId(), other.gatewayId()) && Objects.equals(routeTableId(), other.routeTableId()); } /** * 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("EC2ReplaceRouteAction").add("Description", description()) .add("DestinationCidrBlock", destinationCidrBlock()).add("DestinationPrefixListId", destinationPrefixListId()) .add("DestinationIpv6CidrBlock", destinationIpv6CidrBlock()).add("GatewayId", gatewayId()) .add("RouteTableId", routeTableId()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "Description": return Optional.ofNullable(clazz.cast(description())); case "DestinationCidrBlock": return Optional.ofNullable(clazz.cast(destinationCidrBlock())); case "DestinationPrefixListId": return Optional.ofNullable(clazz.cast(destinationPrefixListId())); case "DestinationIpv6CidrBlock": return Optional.ofNullable(clazz.cast(destinationIpv6CidrBlock())); case "GatewayId": return Optional.ofNullable(clazz.cast(gatewayId())); case "RouteTableId": return Optional.ofNullable(clazz.cast(routeTableId())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((EC2ReplaceRouteAction) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* A description of the ReplaceRoute action in Amazon EC2. *

* * @param description * A description of the ReplaceRoute action in Amazon EC2. * @return Returns a reference to this object so that method calls can be chained together. */ Builder description(String description); /** *

* Information about the IPv4 CIDR address block used for the destination match. The value that you provide must * match the CIDR of an existing route in the table. *

* * @param destinationCidrBlock * Information about the IPv4 CIDR address block used for the destination match. The value that you * provide must match the CIDR of an existing route in the table. * @return Returns a reference to this object so that method calls can be chained together. */ Builder destinationCidrBlock(String destinationCidrBlock); /** *

* Information about the ID of the prefix list for the route. *

* * @param destinationPrefixListId * Information about the ID of the prefix list for the route. * @return Returns a reference to this object so that method calls can be chained together. */ Builder destinationPrefixListId(String destinationPrefixListId); /** *

* Information about the IPv6 CIDR address block used for the destination match. The value that you provide must * match the CIDR of an existing route in the table. *

* * @param destinationIpv6CidrBlock * Information about the IPv6 CIDR address block used for the destination match. The value that you * provide must match the CIDR of an existing route in the table. * @return Returns a reference to this object so that method calls can be chained together. */ Builder destinationIpv6CidrBlock(String destinationIpv6CidrBlock); /** *

* Information about the ID of an internet gateway or virtual private gateway. *

* * @param gatewayId * Information about the ID of an internet gateway or virtual private gateway. * @return Returns a reference to this object so that method calls can be chained together. */ Builder gatewayId(ActionTarget gatewayId); /** *

* Information about the ID of an internet gateway or virtual private gateway. *

* This is a convenience method that creates an instance of the {@link ActionTarget.Builder} avoiding the need * to create one manually via {@link ActionTarget#builder()}. * *

* When the {@link Consumer} completes, {@link ActionTarget.Builder#build()} is called immediately and its * result is passed to {@link #gatewayId(ActionTarget)}. * * @param gatewayId * a consumer that will call methods on {@link ActionTarget.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #gatewayId(ActionTarget) */ default Builder gatewayId(Consumer gatewayId) { return gatewayId(ActionTarget.builder().applyMutation(gatewayId).build()); } /** *

* Information about the ID of the route table. *

* * @param routeTableId * Information about the ID of the route table. * @return Returns a reference to this object so that method calls can be chained together. */ Builder routeTableId(ActionTarget routeTableId); /** *

* Information about the ID of the route table. *

* This is a convenience method that creates an instance of the {@link ActionTarget.Builder} avoiding the need * to create one manually via {@link ActionTarget#builder()}. * *

* When the {@link Consumer} completes, {@link ActionTarget.Builder#build()} is called immediately and its * result is passed to {@link #routeTableId(ActionTarget)}. * * @param routeTableId * a consumer that will call methods on {@link ActionTarget.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #routeTableId(ActionTarget) */ default Builder routeTableId(Consumer routeTableId) { return routeTableId(ActionTarget.builder().applyMutation(routeTableId).build()); } } static final class BuilderImpl implements Builder { private String description; private String destinationCidrBlock; private String destinationPrefixListId; private String destinationIpv6CidrBlock; private ActionTarget gatewayId; private ActionTarget routeTableId; private BuilderImpl() { } private BuilderImpl(EC2ReplaceRouteAction model) { description(model.description); destinationCidrBlock(model.destinationCidrBlock); destinationPrefixListId(model.destinationPrefixListId); destinationIpv6CidrBlock(model.destinationIpv6CidrBlock); gatewayId(model.gatewayId); routeTableId(model.routeTableId); } public final String getDescription() { return description; } public final void setDescription(String description) { this.description = description; } @Override public final Builder description(String description) { this.description = description; return this; } public final String getDestinationCidrBlock() { return destinationCidrBlock; } public final void setDestinationCidrBlock(String destinationCidrBlock) { this.destinationCidrBlock = destinationCidrBlock; } @Override public final Builder destinationCidrBlock(String destinationCidrBlock) { this.destinationCidrBlock = destinationCidrBlock; return this; } public final String getDestinationPrefixListId() { return destinationPrefixListId; } public final void setDestinationPrefixListId(String destinationPrefixListId) { this.destinationPrefixListId = destinationPrefixListId; } @Override public final Builder destinationPrefixListId(String destinationPrefixListId) { this.destinationPrefixListId = destinationPrefixListId; return this; } public final String getDestinationIpv6CidrBlock() { return destinationIpv6CidrBlock; } public final void setDestinationIpv6CidrBlock(String destinationIpv6CidrBlock) { this.destinationIpv6CidrBlock = destinationIpv6CidrBlock; } @Override public final Builder destinationIpv6CidrBlock(String destinationIpv6CidrBlock) { this.destinationIpv6CidrBlock = destinationIpv6CidrBlock; return this; } public final ActionTarget.Builder getGatewayId() { return gatewayId != null ? gatewayId.toBuilder() : null; } public final void setGatewayId(ActionTarget.BuilderImpl gatewayId) { this.gatewayId = gatewayId != null ? gatewayId.build() : null; } @Override public final Builder gatewayId(ActionTarget gatewayId) { this.gatewayId = gatewayId; return this; } public final ActionTarget.Builder getRouteTableId() { return routeTableId != null ? routeTableId.toBuilder() : null; } public final void setRouteTableId(ActionTarget.BuilderImpl routeTableId) { this.routeTableId = routeTableId != null ? routeTableId.build() : null; } @Override public final Builder routeTableId(ActionTarget routeTableId) { this.routeTableId = routeTableId; return this; } @Override public EC2ReplaceRouteAction build() { return new EC2ReplaceRouteAction(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy