software.amazon.awssdk.services.directconnect.model.VirtualInterface Maven / Gradle / Ivy
/*
* 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.directconnect.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.Consumer;
import java.util.function.Function;
import java.util.stream.Collectors;
import java.util.stream.Stream;
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;
/**
*
* Information about a virtual interface.
*
*/
@Generated("software.amazon.awssdk:codegen")
public final class VirtualInterface implements SdkPojo, Serializable,
ToCopyableBuilder {
private static final SdkField OWNER_ACCOUNT_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ownerAccount").getter(getter(VirtualInterface::ownerAccount)).setter(setter(Builder::ownerAccount))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ownerAccount").build()).build();
private static final SdkField VIRTUAL_INTERFACE_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("virtualInterfaceId").getter(getter(VirtualInterface::virtualInterfaceId))
.setter(setter(Builder::virtualInterfaceId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("virtualInterfaceId").build())
.build();
private static final SdkField LOCATION_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("location").getter(getter(VirtualInterface::location)).setter(setter(Builder::location))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("location").build()).build();
private static final SdkField CONNECTION_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("connectionId").getter(getter(VirtualInterface::connectionId)).setter(setter(Builder::connectionId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("connectionId").build()).build();
private static final SdkField VIRTUAL_INTERFACE_TYPE_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("virtualInterfaceType").getter(getter(VirtualInterface::virtualInterfaceType))
.setter(setter(Builder::virtualInterfaceType))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("virtualInterfaceType").build())
.build();
private static final SdkField VIRTUAL_INTERFACE_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("virtualInterfaceName").getter(getter(VirtualInterface::virtualInterfaceName))
.setter(setter(Builder::virtualInterfaceName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("virtualInterfaceName").build())
.build();
private static final SdkField VLAN_FIELD = SdkField. builder(MarshallingType.INTEGER).memberName("vlan")
.getter(getter(VirtualInterface::vlan)).setter(setter(Builder::vlan))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("vlan").build()).build();
private static final SdkField ASN_FIELD = SdkField. builder(MarshallingType.INTEGER).memberName("asn")
.getter(getter(VirtualInterface::asn)).setter(setter(Builder::asn))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("asn").build()).build();
private static final SdkField AMAZON_SIDE_ASN_FIELD = SdkField. builder(MarshallingType.LONG)
.memberName("amazonSideAsn").getter(getter(VirtualInterface::amazonSideAsn)).setter(setter(Builder::amazonSideAsn))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("amazonSideAsn").build()).build();
private static final SdkField AUTH_KEY_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("authKey").getter(getter(VirtualInterface::authKey)).setter(setter(Builder::authKey))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("authKey").build()).build();
private static final SdkField AMAZON_ADDRESS_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("amazonAddress").getter(getter(VirtualInterface::amazonAddress)).setter(setter(Builder::amazonAddress))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("amazonAddress").build()).build();
private static final SdkField CUSTOMER_ADDRESS_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("customerAddress").getter(getter(VirtualInterface::customerAddress))
.setter(setter(Builder::customerAddress))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("customerAddress").build()).build();
private static final SdkField ADDRESS_FAMILY_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("addressFamily").getter(getter(VirtualInterface::addressFamilyAsString))
.setter(setter(Builder::addressFamily))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("addressFamily").build()).build();
private static final SdkField VIRTUAL_INTERFACE_STATE_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("virtualInterfaceState").getter(getter(VirtualInterface::virtualInterfaceStateAsString))
.setter(setter(Builder::virtualInterfaceState))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("virtualInterfaceState").build())
.build();
private static final SdkField CUSTOMER_ROUTER_CONFIG_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("customerRouterConfig").getter(getter(VirtualInterface::customerRouterConfig))
.setter(setter(Builder::customerRouterConfig))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("customerRouterConfig").build())
.build();
private static final SdkField MTU_FIELD = SdkField. builder(MarshallingType.INTEGER).memberName("mtu")
.getter(getter(VirtualInterface::mtu)).setter(setter(Builder::mtu))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("mtu").build()).build();
private static final SdkField JUMBO_FRAME_CAPABLE_FIELD = SdkField. builder(MarshallingType.BOOLEAN)
.memberName("jumboFrameCapable").getter(getter(VirtualInterface::jumboFrameCapable))
.setter(setter(Builder::jumboFrameCapable))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("jumboFrameCapable").build()).build();
private static final SdkField VIRTUAL_GATEWAY_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("virtualGatewayId").getter(getter(VirtualInterface::virtualGatewayId))
.setter(setter(Builder::virtualGatewayId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("virtualGatewayId").build()).build();
private static final SdkField DIRECT_CONNECT_GATEWAY_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("directConnectGatewayId").getter(getter(VirtualInterface::directConnectGatewayId))
.setter(setter(Builder::directConnectGatewayId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("directConnectGatewayId").build())
.build();
private static final SdkField> ROUTE_FILTER_PREFIXES_FIELD = SdkField
.> builder(MarshallingType.LIST)
.memberName("routeFilterPrefixes")
.getter(getter(VirtualInterface::routeFilterPrefixes))
.setter(setter(Builder::routeFilterPrefixes))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("routeFilterPrefixes").build(),
ListTrait
.builder()
.memberLocationName(null)
.memberFieldInfo(
SdkField. builder(MarshallingType.SDK_POJO)
.constructor(RouteFilterPrefix::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
.locationName("member").build()).build()).build()).build();
private static final SdkField> BGP_PEERS_FIELD = SdkField
.> builder(MarshallingType.LIST)
.memberName("bgpPeers")
.getter(getter(VirtualInterface::bgpPeers))
.setter(setter(Builder::bgpPeers))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("bgpPeers").build(),
ListTrait
.builder()
.memberLocationName(null)
.memberFieldInfo(
SdkField. builder(MarshallingType.SDK_POJO)
.constructor(BGPPeer::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
.locationName("member").build()).build()).build()).build();
private static final SdkField REGION_FIELD = SdkField. builder(MarshallingType.STRING).memberName("region")
.getter(getter(VirtualInterface::region)).setter(setter(Builder::region))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("region").build()).build();
private static final SdkField AWS_DEVICE_V2_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("awsDeviceV2").getter(getter(VirtualInterface::awsDeviceV2)).setter(setter(Builder::awsDeviceV2))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("awsDeviceV2").build()).build();
private static final SdkField AWS_LOGICAL_DEVICE_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("awsLogicalDeviceId").getter(getter(VirtualInterface::awsLogicalDeviceId))
.setter(setter(Builder::awsLogicalDeviceId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("awsLogicalDeviceId").build())
.build();
private static final SdkField> TAGS_FIELD = SdkField
.> builder(MarshallingType.LIST)
.memberName("tags")
.getter(getter(VirtualInterface::tags))
.setter(setter(Builder::tags))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("tags").build(),
ListTrait
.builder()
.memberLocationName(null)
.memberFieldInfo(
SdkField. builder(MarshallingType.SDK_POJO)
.constructor(Tag::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
.locationName("member").build()).build()).build()).build();
private static final SdkField SITE_LINK_ENABLED_FIELD = SdkField. builder(MarshallingType.BOOLEAN)
.memberName("siteLinkEnabled").getter(getter(VirtualInterface::siteLinkEnabled))
.setter(setter(Builder::siteLinkEnabled))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("siteLinkEnabled").build()).build();
private static final List> SDK_FIELDS = Collections
.unmodifiableList(Arrays.asList(OWNER_ACCOUNT_FIELD, VIRTUAL_INTERFACE_ID_FIELD, LOCATION_FIELD, CONNECTION_ID_FIELD,
VIRTUAL_INTERFACE_TYPE_FIELD, VIRTUAL_INTERFACE_NAME_FIELD, VLAN_FIELD, ASN_FIELD, AMAZON_SIDE_ASN_FIELD,
AUTH_KEY_FIELD, AMAZON_ADDRESS_FIELD, CUSTOMER_ADDRESS_FIELD, ADDRESS_FAMILY_FIELD,
VIRTUAL_INTERFACE_STATE_FIELD, CUSTOMER_ROUTER_CONFIG_FIELD, MTU_FIELD, JUMBO_FRAME_CAPABLE_FIELD,
VIRTUAL_GATEWAY_ID_FIELD, DIRECT_CONNECT_GATEWAY_ID_FIELD, ROUTE_FILTER_PREFIXES_FIELD, BGP_PEERS_FIELD,
REGION_FIELD, AWS_DEVICE_V2_FIELD, AWS_LOGICAL_DEVICE_ID_FIELD, TAGS_FIELD, SITE_LINK_ENABLED_FIELD));
private static final long serialVersionUID = 1L;
private final String ownerAccount;
private final String virtualInterfaceId;
private final String location;
private final String connectionId;
private final String virtualInterfaceType;
private final String virtualInterfaceName;
private final Integer vlan;
private final Integer asn;
private final Long amazonSideAsn;
private final String authKey;
private final String amazonAddress;
private final String customerAddress;
private final String addressFamily;
private final String virtualInterfaceState;
private final String customerRouterConfig;
private final Integer mtu;
private final Boolean jumboFrameCapable;
private final String virtualGatewayId;
private final String directConnectGatewayId;
private final List routeFilterPrefixes;
private final List bgpPeers;
private final String region;
private final String awsDeviceV2;
private final String awsLogicalDeviceId;
private final List tags;
private final Boolean siteLinkEnabled;
private VirtualInterface(BuilderImpl builder) {
this.ownerAccount = builder.ownerAccount;
this.virtualInterfaceId = builder.virtualInterfaceId;
this.location = builder.location;
this.connectionId = builder.connectionId;
this.virtualInterfaceType = builder.virtualInterfaceType;
this.virtualInterfaceName = builder.virtualInterfaceName;
this.vlan = builder.vlan;
this.asn = builder.asn;
this.amazonSideAsn = builder.amazonSideAsn;
this.authKey = builder.authKey;
this.amazonAddress = builder.amazonAddress;
this.customerAddress = builder.customerAddress;
this.addressFamily = builder.addressFamily;
this.virtualInterfaceState = builder.virtualInterfaceState;
this.customerRouterConfig = builder.customerRouterConfig;
this.mtu = builder.mtu;
this.jumboFrameCapable = builder.jumboFrameCapable;
this.virtualGatewayId = builder.virtualGatewayId;
this.directConnectGatewayId = builder.directConnectGatewayId;
this.routeFilterPrefixes = builder.routeFilterPrefixes;
this.bgpPeers = builder.bgpPeers;
this.region = builder.region;
this.awsDeviceV2 = builder.awsDeviceV2;
this.awsLogicalDeviceId = builder.awsLogicalDeviceId;
this.tags = builder.tags;
this.siteLinkEnabled = builder.siteLinkEnabled;
}
/**
*
* The ID of the Amazon Web Services account that owns the virtual interface.
*
*
* @return The ID of the Amazon Web Services account that owns the virtual interface.
*/
public final String ownerAccount() {
return ownerAccount;
}
/**
*
* The ID of the virtual interface.
*
*
* @return The ID of the virtual interface.
*/
public final String virtualInterfaceId() {
return virtualInterfaceId;
}
/**
*
* The location of the connection.
*
*
* @return The location of the connection.
*/
public final String location() {
return location;
}
/**
*
* The ID of the connection.
*
*
* @return The ID of the connection.
*/
public final String connectionId() {
return connectionId;
}
/**
*
* The type of virtual interface. The possible values are private
and public
.
*
*
* @return The type of virtual interface. The possible values are private
and public
.
*/
public final String virtualInterfaceType() {
return virtualInterfaceType;
}
/**
*
* The name of the virtual interface assigned by the customer network. The name has a maximum of 100 characters. The
* following are valid characters: a-z, 0-9 and a hyphen (-).
*
*
* @return The name of the virtual interface assigned by the customer network. The name has a maximum of 100
* characters. The following are valid characters: a-z, 0-9 and a hyphen (-).
*/
public final String virtualInterfaceName() {
return virtualInterfaceName;
}
/**
*
* The ID of the VLAN.
*
*
* @return The ID of the VLAN.
*/
public final Integer vlan() {
return vlan;
}
/**
*
* The autonomous system (AS) number for Border Gateway Protocol (BGP) configuration.
*
*
* The valid values are 1-2147483647.
*
*
* @return The autonomous system (AS) number for Border Gateway Protocol (BGP) configuration.
*
* The valid values are 1-2147483647.
*/
public final Integer asn() {
return asn;
}
/**
*
* The autonomous system number (ASN) for the Amazon side of the connection.
*
*
* @return The autonomous system number (ASN) for the Amazon side of the connection.
*/
public final Long amazonSideAsn() {
return amazonSideAsn;
}
/**
*
* The authentication key for BGP configuration. This string has a minimum length of 6 characters and and a maximun
* lenth of 80 characters.
*
*
* @return The authentication key for BGP configuration. This string has a minimum length of 6 characters and and a
* maximun lenth of 80 characters.
*/
public final String authKey() {
return authKey;
}
/**
*
* The IP address assigned to the Amazon interface.
*
*
* @return The IP address assigned to the Amazon interface.
*/
public final String amazonAddress() {
return amazonAddress;
}
/**
*
* The IP address assigned to the customer interface.
*
*
* @return The IP address assigned to the customer interface.
*/
public final String customerAddress() {
return customerAddress;
}
/**
*
* The address family for the BGP peer.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #addressFamily}
* will return {@link AddressFamily#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #addressFamilyAsString}.
*
*
* @return The address family for the BGP peer.
* @see AddressFamily
*/
public final AddressFamily addressFamily() {
return AddressFamily.fromValue(addressFamily);
}
/**
*
* The address family for the BGP peer.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #addressFamily}
* will return {@link AddressFamily#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #addressFamilyAsString}.
*
*
* @return The address family for the BGP peer.
* @see AddressFamily
*/
public final String addressFamilyAsString() {
return addressFamily;
}
/**
*
* The state of the virtual interface. The following are the possible values:
*
*
* -
*
* confirming
: The creation of the virtual interface is pending confirmation from the virtual interface
* owner. If the owner of the virtual interface is different from the owner of the connection on which it is
* provisioned, then the virtual interface will remain in this state until it is confirmed by the virtual interface
* owner.
*
*
* -
*
* verifying
: This state only applies to public virtual interfaces. Each public virtual interface needs
* validation before the virtual interface can be created.
*
*
* -
*
* pending
: A virtual interface is in this state from the time that it is created until the virtual
* interface is ready to forward traffic.
*
*
* -
*
* available
: A virtual interface that is able to forward traffic.
*
*
* -
*
* down
: A virtual interface that is BGP down.
*
*
* -
*
* deleting
: A virtual interface is in this state immediately after calling
* DeleteVirtualInterface until it can no longer forward traffic.
*
*
* -
*
* deleted
: A virtual interface that cannot forward traffic.
*
*
* -
*
* rejected
: The virtual interface owner has declined creation of the virtual interface. If a virtual
* interface in the Confirming
state is deleted by the virtual interface owner, the virtual interface
* enters the Rejected
state.
*
*
* -
*
* unknown
: The state of the virtual interface is not available.
*
*
*
*
* If the service returns an enum value that is not available in the current SDK version,
* {@link #virtualInterfaceState} will return {@link VirtualInterfaceState#UNKNOWN_TO_SDK_VERSION}. The raw value
* returned by the service is available from {@link #virtualInterfaceStateAsString}.
*
*
* @return The state of the virtual interface. The following are the possible values:
*
* -
*
* confirming
: The creation of the virtual interface is pending confirmation from the virtual
* interface owner. If the owner of the virtual interface is different from the owner of the connection on
* which it is provisioned, then the virtual interface will remain in this state until it is confirmed by
* the virtual interface owner.
*
*
* -
*
* verifying
: This state only applies to public virtual interfaces. Each public virtual
* interface needs validation before the virtual interface can be created.
*
*
* -
*
* pending
: A virtual interface is in this state from the time that it is created until the
* virtual interface is ready to forward traffic.
*
*
* -
*
* available
: A virtual interface that is able to forward traffic.
*
*
* -
*
* down
: A virtual interface that is BGP down.
*
*
* -
*
* deleting
: A virtual interface is in this state immediately after calling
* DeleteVirtualInterface until it can no longer forward traffic.
*
*
* -
*
* deleted
: A virtual interface that cannot forward traffic.
*
*
* -
*
* rejected
: The virtual interface owner has declined creation of the virtual interface. If a
* virtual interface in the Confirming
state is deleted by the virtual interface owner, the
* virtual interface enters the Rejected
state.
*
*
* -
*
* unknown
: The state of the virtual interface is not available.
*
*
* @see VirtualInterfaceState
*/
public final VirtualInterfaceState virtualInterfaceState() {
return VirtualInterfaceState.fromValue(virtualInterfaceState);
}
/**
*
* The state of the virtual interface. The following are the possible values:
*
*
* -
*
* confirming
: The creation of the virtual interface is pending confirmation from the virtual interface
* owner. If the owner of the virtual interface is different from the owner of the connection on which it is
* provisioned, then the virtual interface will remain in this state until it is confirmed by the virtual interface
* owner.
*
*
* -
*
* verifying
: This state only applies to public virtual interfaces. Each public virtual interface needs
* validation before the virtual interface can be created.
*
*
* -
*
* pending
: A virtual interface is in this state from the time that it is created until the virtual
* interface is ready to forward traffic.
*
*
* -
*
* available
: A virtual interface that is able to forward traffic.
*
*
* -
*
* down
: A virtual interface that is BGP down.
*
*
* -
*
* deleting
: A virtual interface is in this state immediately after calling
* DeleteVirtualInterface until it can no longer forward traffic.
*
*
* -
*
* deleted
: A virtual interface that cannot forward traffic.
*
*
* -
*
* rejected
: The virtual interface owner has declined creation of the virtual interface. If a virtual
* interface in the Confirming
state is deleted by the virtual interface owner, the virtual interface
* enters the Rejected
state.
*
*
* -
*
* unknown
: The state of the virtual interface is not available.
*
*
*
*
* If the service returns an enum value that is not available in the current SDK version,
* {@link #virtualInterfaceState} will return {@link VirtualInterfaceState#UNKNOWN_TO_SDK_VERSION}. The raw value
* returned by the service is available from {@link #virtualInterfaceStateAsString}.
*
*
* @return The state of the virtual interface. The following are the possible values:
*
* -
*
* confirming
: The creation of the virtual interface is pending confirmation from the virtual
* interface owner. If the owner of the virtual interface is different from the owner of the connection on
* which it is provisioned, then the virtual interface will remain in this state until it is confirmed by
* the virtual interface owner.
*
*
* -
*
* verifying
: This state only applies to public virtual interfaces. Each public virtual
* interface needs validation before the virtual interface can be created.
*
*
* -
*
* pending
: A virtual interface is in this state from the time that it is created until the
* virtual interface is ready to forward traffic.
*
*
* -
*
* available
: A virtual interface that is able to forward traffic.
*
*
* -
*
* down
: A virtual interface that is BGP down.
*
*
* -
*
* deleting
: A virtual interface is in this state immediately after calling
* DeleteVirtualInterface until it can no longer forward traffic.
*
*
* -
*
* deleted
: A virtual interface that cannot forward traffic.
*
*
* -
*
* rejected
: The virtual interface owner has declined creation of the virtual interface. If a
* virtual interface in the Confirming
state is deleted by the virtual interface owner, the
* virtual interface enters the Rejected
state.
*
*
* -
*
* unknown
: The state of the virtual interface is not available.
*
*
* @see VirtualInterfaceState
*/
public final String virtualInterfaceStateAsString() {
return virtualInterfaceState;
}
/**
*
* The customer router configuration.
*
*
* @return The customer router configuration.
*/
public final String customerRouterConfig() {
return customerRouterConfig;
}
/**
*
* The maximum transmission unit (MTU), in bytes. The supported values are 1500 and 9001. The default value is 1500.
*
*
* @return The maximum transmission unit (MTU), in bytes. The supported values are 1500 and 9001. The default value
* is 1500.
*/
public final Integer mtu() {
return mtu;
}
/**
*
* Indicates whether jumbo frames (9001 MTU) are supported.
*
*
* @return Indicates whether jumbo frames (9001 MTU) are supported.
*/
public final Boolean jumboFrameCapable() {
return jumboFrameCapable;
}
/**
*
* The ID of the virtual private gateway. Applies only to private virtual interfaces.
*
*
* @return The ID of the virtual private gateway. Applies only to private virtual interfaces.
*/
public final String virtualGatewayId() {
return virtualGatewayId;
}
/**
*
* The ID of the Direct Connect gateway.
*
*
* @return The ID of the Direct Connect gateway.
*/
public final String directConnectGatewayId() {
return directConnectGatewayId;
}
/**
* For responses, this returns true if the service returned a value for the RouteFilterPrefixes property. This DOES
* NOT check that the value is non-empty (for which, you should check the {@code isEmpty()} method on the property).
* This is useful because the SDK will never return a null collection or map, but you may need to differentiate
* between the service returning nothing (or null) and the service returning an empty collection or map. For
* requests, this returns true if a value for the property was specified in the request builder, and false if a
* value was not specified.
*/
public final boolean hasRouteFilterPrefixes() {
return routeFilterPrefixes != null && !(routeFilterPrefixes instanceof SdkAutoConstructList);
}
/**
*
* The routes to be advertised to the Amazon Web Services network in this Region. Applies to public virtual
* interfaces.
*
*
* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
*
*
* This method will never return null. If you would like to know whether the service returned this field (so that
* you can differentiate between null and empty), you can use the {@link #hasRouteFilterPrefixes} method.
*
*
* @return The routes to be advertised to the Amazon Web Services network in this Region. Applies to public virtual
* interfaces.
*/
public final List routeFilterPrefixes() {
return routeFilterPrefixes;
}
/**
* For responses, this returns true if the service returned a value for the BgpPeers property. This DOES NOT check
* that the value is non-empty (for which, you should check the {@code isEmpty()} method on the property). This is
* useful because the SDK will never return a null collection or map, but you may need to differentiate between the
* service returning nothing (or null) and the service returning an empty collection or map. For requests, this
* returns true if a value for the property was specified in the request builder, and false if a value was not
* specified.
*/
public final boolean hasBgpPeers() {
return bgpPeers != null && !(bgpPeers instanceof SdkAutoConstructList);
}
/**
*
* The BGP peers configured on this virtual interface.
*
*
* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
*
*
* This method will never return null. If you would like to know whether the service returned this field (so that
* you can differentiate between null and empty), you can use the {@link #hasBgpPeers} method.
*
*
* @return The BGP peers configured on this virtual interface.
*/
public final List bgpPeers() {
return bgpPeers;
}
/**
*
* The Amazon Web Services Region where the virtual interface is located.
*
*
* @return The Amazon Web Services Region where the virtual interface is located.
*/
public final String region() {
return region;
}
/**
*
* The Direct Connect endpoint that terminates the physical connection.
*
*
* @return The Direct Connect endpoint that terminates the physical connection.
*/
public final String awsDeviceV2() {
return awsDeviceV2;
}
/**
*
* The Direct Connect endpoint that terminates the logical connection. This device might be different than the
* device that terminates the physical connection.
*
*
* @return The Direct Connect endpoint that terminates the logical connection. This device might be different than
* the device that terminates the physical connection.
*/
public final String awsLogicalDeviceId() {
return awsLogicalDeviceId;
}
/**
* For responses, this returns true if the service returned a value for the Tags property. This DOES NOT check that
* the value is non-empty (for which, you should check the {@code isEmpty()} method on the property). This is useful
* because the SDK will never return a null collection or map, but you may need to differentiate between the service
* returning nothing (or null) and the service returning an empty collection or map. For requests, this returns true
* if a value for the property was specified in the request builder, and false if a value was not specified.
*/
public final boolean hasTags() {
return tags != null && !(tags instanceof SdkAutoConstructList);
}
/**
*
* The tags associated with the virtual interface.
*
*
* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
*
*
* This method will never return null. If you would like to know whether the service returned this field (so that
* you can differentiate between null and empty), you can use the {@link #hasTags} method.
*
*
* @return The tags associated with the virtual interface.
*/
public final List tags() {
return tags;
}
/**
*
* Indicates whether SiteLink is enabled.
*
*
* @return Indicates whether SiteLink is enabled.
*/
public final Boolean siteLinkEnabled() {
return siteLinkEnabled;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class extends Builder> serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public final int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + Objects.hashCode(ownerAccount());
hashCode = 31 * hashCode + Objects.hashCode(virtualInterfaceId());
hashCode = 31 * hashCode + Objects.hashCode(location());
hashCode = 31 * hashCode + Objects.hashCode(connectionId());
hashCode = 31 * hashCode + Objects.hashCode(virtualInterfaceType());
hashCode = 31 * hashCode + Objects.hashCode(virtualInterfaceName());
hashCode = 31 * hashCode + Objects.hashCode(vlan());
hashCode = 31 * hashCode + Objects.hashCode(asn());
hashCode = 31 * hashCode + Objects.hashCode(amazonSideAsn());
hashCode = 31 * hashCode + Objects.hashCode(authKey());
hashCode = 31 * hashCode + Objects.hashCode(amazonAddress());
hashCode = 31 * hashCode + Objects.hashCode(customerAddress());
hashCode = 31 * hashCode + Objects.hashCode(addressFamilyAsString());
hashCode = 31 * hashCode + Objects.hashCode(virtualInterfaceStateAsString());
hashCode = 31 * hashCode + Objects.hashCode(customerRouterConfig());
hashCode = 31 * hashCode + Objects.hashCode(mtu());
hashCode = 31 * hashCode + Objects.hashCode(jumboFrameCapable());
hashCode = 31 * hashCode + Objects.hashCode(virtualGatewayId());
hashCode = 31 * hashCode + Objects.hashCode(directConnectGatewayId());
hashCode = 31 * hashCode + Objects.hashCode(hasRouteFilterPrefixes() ? routeFilterPrefixes() : null);
hashCode = 31 * hashCode + Objects.hashCode(hasBgpPeers() ? bgpPeers() : null);
hashCode = 31 * hashCode + Objects.hashCode(region());
hashCode = 31 * hashCode + Objects.hashCode(awsDeviceV2());
hashCode = 31 * hashCode + Objects.hashCode(awsLogicalDeviceId());
hashCode = 31 * hashCode + Objects.hashCode(hasTags() ? tags() : null);
hashCode = 31 * hashCode + Objects.hashCode(siteLinkEnabled());
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 VirtualInterface)) {
return false;
}
VirtualInterface other = (VirtualInterface) obj;
return Objects.equals(ownerAccount(), other.ownerAccount())
&& Objects.equals(virtualInterfaceId(), other.virtualInterfaceId())
&& Objects.equals(location(), other.location()) && Objects.equals(connectionId(), other.connectionId())
&& Objects.equals(virtualInterfaceType(), other.virtualInterfaceType())
&& Objects.equals(virtualInterfaceName(), other.virtualInterfaceName()) && Objects.equals(vlan(), other.vlan())
&& Objects.equals(asn(), other.asn()) && Objects.equals(amazonSideAsn(), other.amazonSideAsn())
&& Objects.equals(authKey(), other.authKey()) && Objects.equals(amazonAddress(), other.amazonAddress())
&& Objects.equals(customerAddress(), other.customerAddress())
&& Objects.equals(addressFamilyAsString(), other.addressFamilyAsString())
&& Objects.equals(virtualInterfaceStateAsString(), other.virtualInterfaceStateAsString())
&& Objects.equals(customerRouterConfig(), other.customerRouterConfig()) && Objects.equals(mtu(), other.mtu())
&& Objects.equals(jumboFrameCapable(), other.jumboFrameCapable())
&& Objects.equals(virtualGatewayId(), other.virtualGatewayId())
&& Objects.equals(directConnectGatewayId(), other.directConnectGatewayId())
&& hasRouteFilterPrefixes() == other.hasRouteFilterPrefixes()
&& Objects.equals(routeFilterPrefixes(), other.routeFilterPrefixes()) && hasBgpPeers() == other.hasBgpPeers()
&& Objects.equals(bgpPeers(), other.bgpPeers()) && Objects.equals(region(), other.region())
&& Objects.equals(awsDeviceV2(), other.awsDeviceV2())
&& Objects.equals(awsLogicalDeviceId(), other.awsLogicalDeviceId()) && hasTags() == other.hasTags()
&& Objects.equals(tags(), other.tags()) && Objects.equals(siteLinkEnabled(), other.siteLinkEnabled());
}
/**
* 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("VirtualInterface").add("OwnerAccount", ownerAccount())
.add("VirtualInterfaceId", virtualInterfaceId()).add("Location", location()).add("ConnectionId", connectionId())
.add("VirtualInterfaceType", virtualInterfaceType()).add("VirtualInterfaceName", virtualInterfaceName())
.add("Vlan", vlan()).add("Asn", asn()).add("AmazonSideAsn", amazonSideAsn()).add("AuthKey", authKey())
.add("AmazonAddress", amazonAddress()).add("CustomerAddress", customerAddress())
.add("AddressFamily", addressFamilyAsString()).add("VirtualInterfaceState", virtualInterfaceStateAsString())
.add("CustomerRouterConfig", customerRouterConfig()).add("Mtu", mtu())
.add("JumboFrameCapable", jumboFrameCapable()).add("VirtualGatewayId", virtualGatewayId())
.add("DirectConnectGatewayId", directConnectGatewayId())
.add("RouteFilterPrefixes", hasRouteFilterPrefixes() ? routeFilterPrefixes() : null)
.add("BgpPeers", hasBgpPeers() ? bgpPeers() : null).add("Region", region()).add("AwsDeviceV2", awsDeviceV2())
.add("AwsLogicalDeviceId", awsLogicalDeviceId()).add("Tags", hasTags() ? tags() : null)
.add("SiteLinkEnabled", siteLinkEnabled()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "ownerAccount":
return Optional.ofNullable(clazz.cast(ownerAccount()));
case "virtualInterfaceId":
return Optional.ofNullable(clazz.cast(virtualInterfaceId()));
case "location":
return Optional.ofNullable(clazz.cast(location()));
case "connectionId":
return Optional.ofNullable(clazz.cast(connectionId()));
case "virtualInterfaceType":
return Optional.ofNullable(clazz.cast(virtualInterfaceType()));
case "virtualInterfaceName":
return Optional.ofNullable(clazz.cast(virtualInterfaceName()));
case "vlan":
return Optional.ofNullable(clazz.cast(vlan()));
case "asn":
return Optional.ofNullable(clazz.cast(asn()));
case "amazonSideAsn":
return Optional.ofNullable(clazz.cast(amazonSideAsn()));
case "authKey":
return Optional.ofNullable(clazz.cast(authKey()));
case "amazonAddress":
return Optional.ofNullable(clazz.cast(amazonAddress()));
case "customerAddress":
return Optional.ofNullable(clazz.cast(customerAddress()));
case "addressFamily":
return Optional.ofNullable(clazz.cast(addressFamilyAsString()));
case "virtualInterfaceState":
return Optional.ofNullable(clazz.cast(virtualInterfaceStateAsString()));
case "customerRouterConfig":
return Optional.ofNullable(clazz.cast(customerRouterConfig()));
case "mtu":
return Optional.ofNullable(clazz.cast(mtu()));
case "jumboFrameCapable":
return Optional.ofNullable(clazz.cast(jumboFrameCapable()));
case "virtualGatewayId":
return Optional.ofNullable(clazz.cast(virtualGatewayId()));
case "directConnectGatewayId":
return Optional.ofNullable(clazz.cast(directConnectGatewayId()));
case "routeFilterPrefixes":
return Optional.ofNullable(clazz.cast(routeFilterPrefixes()));
case "bgpPeers":
return Optional.ofNullable(clazz.cast(bgpPeers()));
case "region":
return Optional.ofNullable(clazz.cast(region()));
case "awsDeviceV2":
return Optional.ofNullable(clazz.cast(awsDeviceV2()));
case "awsLogicalDeviceId":
return Optional.ofNullable(clazz.cast(awsLogicalDeviceId()));
case "tags":
return Optional.ofNullable(clazz.cast(tags()));
case "siteLinkEnabled":
return Optional.ofNullable(clazz.cast(siteLinkEnabled()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function