Class CfnNetworkInterfaceProps.Builder

java.lang.Object
software.amazon.awscdk.services.ec2.CfnNetworkInterfaceProps.Builder
All Implemented Interfaces:
software.amazon.jsii.Builder<CfnNetworkInterfaceProps>
Enclosing interface:
CfnNetworkInterfaceProps

@Stability(Stable) public static final class CfnNetworkInterfaceProps.Builder extends Object implements software.amazon.jsii.Builder<CfnNetworkInterfaceProps>
  • Constructor Details

    • Builder

      public Builder()
  • Method Details

    • subnetId

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder subnetId(String subnetId)
      Parameters:
      subnetId - The ID of the subnet to associate with the network interface. This parameter is required.
      Returns:
      this
    • connectionTrackingSpecification

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder connectionTrackingSpecification(IResolvable connectionTrackingSpecification)
      Parameters:
      connectionTrackingSpecification - A connection tracking specification for the network interface.
      Returns:
      this
    • connectionTrackingSpecification

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder connectionTrackingSpecification(CfnNetworkInterface.ConnectionTrackingSpecificationProperty connectionTrackingSpecification)
      Parameters:
      connectionTrackingSpecification - A connection tracking specification for the network interface.
      Returns:
      this
    • description

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder description(String description)
      Parameters:
      description - A description for the network interface.
      Returns:
      this
    • enablePrimaryIpv6

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder enablePrimaryIpv6(Boolean enablePrimaryIpv6)
      Parameters:
      enablePrimaryIpv6 - If you’re modifying a network interface in a dual-stack or IPv6-only subnet, you have the option to assign a primary IPv6 IP address. A primary IPv6 address is an IPv6 GUA address associated with an ENI that you have enabled to use a primary IPv6 address. Use this option if the instance that this ENI will be attached to relies on its IPv6 address not changing. AWS will automatically assign an IPv6 address associated with the ENI attached to your instance to be the primary IPv6 address. Once you enable an IPv6 GUA address to be a primary IPv6, you cannot disable it. When you enable an IPv6 GUA address to be a primary IPv6, the first IPv6 GUA will be made the primary IPv6 address until the instance is terminated or the network interface is detached. If you have multiple IPv6 addresses associated with an ENI attached to your instance and you enable a primary IPv6 address, the first IPv6 GUA address associated with the ENI becomes the primary IPv6 address.
      Returns:
      this
    • enablePrimaryIpv6

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder enablePrimaryIpv6(IResolvable enablePrimaryIpv6)
      Parameters:
      enablePrimaryIpv6 - If you’re modifying a network interface in a dual-stack or IPv6-only subnet, you have the option to assign a primary IPv6 IP address. A primary IPv6 address is an IPv6 GUA address associated with an ENI that you have enabled to use a primary IPv6 address. Use this option if the instance that this ENI will be attached to relies on its IPv6 address not changing. AWS will automatically assign an IPv6 address associated with the ENI attached to your instance to be the primary IPv6 address. Once you enable an IPv6 GUA address to be a primary IPv6, you cannot disable it. When you enable an IPv6 GUA address to be a primary IPv6, the first IPv6 GUA will be made the primary IPv6 address until the instance is terminated or the network interface is detached. If you have multiple IPv6 addresses associated with an ENI attached to your instance and you enable a primary IPv6 address, the first IPv6 GUA address associated with the ENI becomes the primary IPv6 address.
      Returns:
      this
    • groupSet

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder groupSet(List<String> groupSet)
      Parameters:
      groupSet - The IDs of the security groups associated with this network interface.
      Returns:
      this
    • interfaceType

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder interfaceType(String interfaceType)
      Parameters:
      interfaceType - The type of network interface. The default is interface . The supported values are efa and trunk .
      Returns:
      this
    • ipv4PrefixCount

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder ipv4PrefixCount(Number ipv4PrefixCount)
      Parameters:
      ipv4PrefixCount - The number of IPv4 prefixes to be automatically assigned to the network interface. When creating a network interface, you can't specify a count of IPv4 prefixes if you've specified one of the following: specific IPv4 prefixes, specific private IPv4 addresses, or a count of private IPv4 addresses.
      Returns:
      this
    • ipv4Prefixes

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder ipv4Prefixes(IResolvable ipv4Prefixes)
      Parameters:
      ipv4Prefixes - The IPv4 delegated prefixes that are assigned to the network interface. When creating a network interface, you can't specify IPv4 prefixes if you've specified one of the following: a count of IPv4 prefixes, specific private IPv4 addresses, or a count of private IPv4 addresses.
      Returns:
      this
    • ipv4Prefixes

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder ipv4Prefixes(List<? extends Object> ipv4Prefixes)
      Parameters:
      ipv4Prefixes - The IPv4 delegated prefixes that are assigned to the network interface. When creating a network interface, you can't specify IPv4 prefixes if you've specified one of the following: a count of IPv4 prefixes, specific private IPv4 addresses, or a count of private IPv4 addresses.
      Returns:
      this
    • ipv6AddressCount

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder ipv6AddressCount(Number ipv6AddressCount)
      Parameters:
      ipv6AddressCount - The number of IPv6 addresses to assign to the network interface. Amazon EC2 automatically selects the IPv6 addresses from the subnet range. To specify specific IPv6 addresses, use the Ipv6Addresses property and don't specify this property.

      When creating a network interface, you can't specify a count of IPv6 addresses if you've specified one of the following: specific IPv6 addresses, specific IPv6 prefixes, or a count of IPv6 prefixes.

      Returns:
      this
    • ipv6Addresses

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder ipv6Addresses(IResolvable ipv6Addresses)
      Parameters:
      ipv6Addresses - The IPv6 addresses from the IPv6 CIDR block range of your subnet to assign to the network interface. If you're specifying a number of IPv6 addresses, use the Ipv6AddressCount property and don't specify this property.

      When creating a network interface, you can't specify IPv6 addresses if you've specified one of the following: a count of IPv6 addresses, specific IPv6 prefixes, or a count of IPv6 prefixes.

      Returns:
      this
    • ipv6Addresses

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder ipv6Addresses(List<? extends Object> ipv6Addresses)
      Parameters:
      ipv6Addresses - The IPv6 addresses from the IPv6 CIDR block range of your subnet to assign to the network interface. If you're specifying a number of IPv6 addresses, use the Ipv6AddressCount property and don't specify this property.

      When creating a network interface, you can't specify IPv6 addresses if you've specified one of the following: a count of IPv6 addresses, specific IPv6 prefixes, or a count of IPv6 prefixes.

      Returns:
      this
    • ipv6PrefixCount

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder ipv6PrefixCount(Number ipv6PrefixCount)
      Parameters:
      ipv6PrefixCount - The number of IPv6 prefixes to be automatically assigned to the network interface. When creating a network interface, you can't specify a count of IPv6 prefixes if you've specified one of the following: specific IPv6 prefixes, specific IPv6 addresses, or a count of IPv6 addresses.
      Returns:
      this
    • ipv6Prefixes

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder ipv6Prefixes(IResolvable ipv6Prefixes)
      Parameters:
      ipv6Prefixes - The IPv6 delegated prefixes that are assigned to the network interface. When creating a network interface, you can't specify IPv6 prefixes if you've specified one of the following: a count of IPv6 prefixes, specific IPv6 addresses, or a count of IPv6 addresses.
      Returns:
      this
    • ipv6Prefixes

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder ipv6Prefixes(List<? extends Object> ipv6Prefixes)
      Parameters:
      ipv6Prefixes - The IPv6 delegated prefixes that are assigned to the network interface. When creating a network interface, you can't specify IPv6 prefixes if you've specified one of the following: a count of IPv6 prefixes, specific IPv6 addresses, or a count of IPv6 addresses.
      Returns:
      this
    • privateIpAddress

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder privateIpAddress(String privateIpAddress)
      Parameters:
      privateIpAddress - The private IPv4 address to assign to the network interface as the primary private IP address. If you want to specify multiple private IP addresses, use the PrivateIpAddresses property.
      Returns:
      this
    • privateIpAddresses

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder privateIpAddresses(IResolvable privateIpAddresses)
      Parameters:
      privateIpAddresses - The private IPv4 addresses to assign to the network interface. You can specify a primary private IP address by setting the value of the Primary property to true in the PrivateIpAddressSpecification property. If you want EC2 to automatically assign private IP addresses, use the SecondaryPrivateIpAddressCount property and do not specify this property.

      When creating a network interface, you can't specify private IPv4 addresses if you've specified one of the following: a count of private IPv4 addresses, specific IPv4 prefixes, or a count of IPv4 prefixes.

      Returns:
      this
    • privateIpAddresses

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder privateIpAddresses(List<? extends Object> privateIpAddresses)
      Parameters:
      privateIpAddresses - The private IPv4 addresses to assign to the network interface. You can specify a primary private IP address by setting the value of the Primary property to true in the PrivateIpAddressSpecification property. If you want EC2 to automatically assign private IP addresses, use the SecondaryPrivateIpAddressCount property and do not specify this property.

      When creating a network interface, you can't specify private IPv4 addresses if you've specified one of the following: a count of private IPv4 addresses, specific IPv4 prefixes, or a count of IPv4 prefixes.

      Returns:
      this
    • secondaryPrivateIpAddressCount

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder secondaryPrivateIpAddressCount(Number secondaryPrivateIpAddressCount)
      Parameters:
      secondaryPrivateIpAddressCount - The number of secondary private IPv4 addresses to assign to a network interface. When you specify a number of secondary IPv4 addresses, Amazon EC2 selects these IP addresses within the subnet's IPv4 CIDR range. You can't specify this option and specify more than one private IP address using privateIpAddresses .

      When creating a Network Interface, you can't specify a count of private IPv4 addresses if you've specified one of the following: specific private IPv4 addresses, specific IPv4 prefixes, or a count of IPv4 prefixes.

      Returns:
      this
    • sourceDestCheck

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder sourceDestCheck(Boolean sourceDestCheck)
      Parameters:
      sourceDestCheck - Enable or disable source/destination checks, which ensure that the instance is either the source or the destination of any traffic that it receives. If the value is true , source/destination checks are enabled; otherwise, they are disabled. The default value is true . You must disable source/destination checks if the instance runs services such as network address translation, routing, or firewalls.
      Returns:
      this
    • sourceDestCheck

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder sourceDestCheck(IResolvable sourceDestCheck)
      Parameters:
      sourceDestCheck - Enable or disable source/destination checks, which ensure that the instance is either the source or the destination of any traffic that it receives. If the value is true , source/destination checks are enabled; otherwise, they are disabled. The default value is true . You must disable source/destination checks if the instance runs services such as network address translation, routing, or firewalls.
      Returns:
      this
    • tags

      @Stability(Stable) public CfnNetworkInterfaceProps.Builder tags(List<? extends CfnTag> tags)
      Parameters:
      tags - The tags to apply to the network interface.
      Returns:
      this
    • build

      @Stability(Stable) public CfnNetworkInterfaceProps build()
      Builds the configured instance.
      Specified by:
      build in interface software.amazon.jsii.Builder<CfnNetworkInterfaceProps>
      Returns:
      a new instance of CfnNetworkInterfaceProps
      Throws:
      NullPointerException - if any required attribute was not provided