CreatePublicVirtualInterface
Creates a public virtual interface. A virtual interface is the VLAN that transports AWS Direct Connect traffic. A public virtual interface supports sending traffic to public services of AWS such as Amazon S3.
When creating an IPv6 public virtual interface (addressFamily is ipv6), leave the customer
      and amazon address fields blank to use auto-assigned IPv6 space. Custom IPv6 addresses are not supported.
Request Syntax
{
   "connectionId": "string",
   "newPublicVirtualInterface": { 
      "addressFamily": "string",
      "amazonAddress": "string",
      "asn": number,
      "asnLong": number,
      "authKey": "string",
      "customerAddress": "string",
      "routeFilterPrefixes": [ 
         { 
            "cidr": "string"
         }
      ],
      "tags": [ 
         { 
            "key": "string",
            "value": "string"
         }
      ],
      "virtualInterfaceName": "string",
      "vlan": number
   }
}Request Parameters
For information about the parameters that are common to all actions, see Common Parameters.
The request accepts the following data in JSON format.
- connectionId
- 
               The ID of the connection. Type: String Required: Yes 
- newPublicVirtualInterface
- 
               Information about the public virtual interface. Type: NewPublicVirtualInterface object Required: Yes 
Response Syntax
{
   "addressFamily": "string",
   "amazonAddress": "string",
   "amazonSideAsn": number,
   "asn": number,
   "asnLong": number,
   "authKey": "string",
   "awsDeviceV2": "string",
   "awsLogicalDeviceId": "string",
   "bgpPeers": [ 
      { 
         "addressFamily": "string",
         "amazonAddress": "string",
         "asn": number,
         "asnLong": number,
         "authKey": "string",
         "awsDeviceV2": "string",
         "awsLogicalDeviceId": "string",
         "bgpPeerId": "string",
         "bgpPeerState": "string",
         "bgpStatus": "string",
         "customerAddress": "string"
      }
   ],
   "connectionId": "string",
   "customerAddress": "string",
   "customerRouterConfig": "string",
   "directConnectGatewayId": "string",
   "jumboFrameCapable": boolean,
   "location": "string",
   "mtu": number,
   "ownerAccount": "string",
   "region": "string",
   "routeFilterPrefixes": [ 
      { 
         "cidr": "string"
      }
   ],
   "siteLinkEnabled": boolean,
   "tags": [ 
      { 
         "key": "string",
         "value": "string"
      }
   ],
   "virtualGatewayId": "string",
   "virtualInterfaceId": "string",
   "virtualInterfaceName": "string",
   "virtualInterfaceState": "string",
   "virtualInterfaceType": "string",
   "vlan": number
}Response Elements
If the action is successful, the service sends back an HTTP 200 response.
The following data is returned in JSON format by the service.
- addressFamily
- 
               The address family for the BGP peer. Type: String Valid Values: ipv4 | ipv6
- amazonAddress
- 
               The IP address assigned to the Amazon interface. Type: String 
- amazonSideAsn
- 
               The autonomous system number (AS) for the Amazon side of the connection. Type: Long 
- asn
- 
               The autonomous system number (ASN). The valid range is from 1 to 2147483646 for Border Gateway Protocol (BGP) configuration. If you provide a number greater than the maximum, an error is returned. Use asnLonginstead.- 
                     You can use asnLongorasn, but not both. We recommend usingasnLongas it supports a greater pool of numbers.
- 
                     If you provide a value in the same API call for both asnandasnLong, the API will only accept the value forasnLong.
- 
                     If you enter a 4-byte ASN for the asnparameter, the API returns an error.
- 
                     If you are using a 2-byte ASN, the API response will include the 2-byte value for both the asnandasnLongfields.
 Type: Integer 
- 
                     
- asnLong
- 
               The long ASN for the virtual interface. The valid range is from 1 to 4294967294 for BGP configuration. Note the following limitations when using asnLong:- 
                     You can use asnLongorasn, but not both. We recommend usingasnLongas it supports a greater pool of numbers.
- 
                     asnLongaccepts any valid ASN value, regardless if it's 2-byte or 4-byte.
- 
                     When using a 4-byte asnLong, the API response returns0for the legacyasnattribute since 4-byte ASN values exceed the maximum supported value of 2,147,483,647.
- 
                     If you are using a 2-byte ASN, the API response will include the 2-byte value for both the asnandasnLongfields.
- 
                     If you provide a value in the same API call for both asnandasnLong, the API will only accept the value forasnLong.
 Type: Long 
- 
                     
- authKey
- 
               The authentication key for BGP configuration. This string has a minimum length of 6 characters and and a maximun lenth of 80 characters. Type: String 
- awsDeviceV2
- 
               The Direct Connect endpoint that terminates the physical connection. Type: String 
- awsLogicalDeviceId
- 
               The Direct Connect endpoint that terminates the logical connection. This device might be different than the device that terminates the physical connection. Type: String 
- bgpPeers
- 
               The BGP peers configured on this virtual interface. Type: Array of BGPPeer objects 
- connectionId
- 
               The ID of the connection. Type: String 
- customerAddress
- 
               The IP address assigned to the customer interface. Type: String 
- customerRouterConfig
- 
               The customer router configuration. Type: String 
- directConnectGatewayId
- 
               The ID of the Direct Connect gateway. Type: String 
- jumboFrameCapable
- 
               Indicates whether jumbo frames are supported. Type: Boolean 
- location
- 
               The location of the connection. Type: String 
- mtu
- 
               The maximum transmission unit (MTU), in bytes. The supported values are 1500 and 8500. The default value is 1500 Type: Integer 
- ownerAccount
- 
               The ID of the AWS account that owns the virtual interface. Type: String 
- region
- 
               The AWS Region where the virtual interface is located. Type: String 
- routeFilterPrefixes
- 
               The routes to be advertised to the AWS network in this Region. Applies to public virtual interfaces. Type: Array of RouteFilterPrefix objects 
- siteLinkEnabled
- 
               Indicates whether SiteLink is enabled. Type: Boolean 
- 
               The tags associated with the virtual interface. Type: Array of Tag objects Array Members: Minimum number of 1 item. 
- virtualGatewayId
- 
               The ID of the virtual private gateway. Applies only to private virtual interfaces. Type: String 
- virtualInterfaceId
- 
               The ID of the virtual interface. Type: String 
- virtualInterfaceName
- 
               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 (-). Type: String 
- 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.
- 
                     testing: A virtual interface is in this state immediately after calling StartBgpFailoverTest and remains in this state during the duration of the test.
- 
                     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 theConfirmingstate is deleted by the virtual interface owner, the virtual interface enters theRejectedstate.
- 
                     unknown: The state of the virtual interface is not available.
 Type: String Valid Values: confirming | verifying | pending | available | down | testing | deleting | deleted | rejected | unknown
- 
                     
- virtualInterfaceType
- 
               The type of virtual interface. The possible values are private,publicandtransit.Type: String 
- vlan
- 
               The ID of the VLAN. Type: Integer 
Errors
For information about the errors that are common to all actions, see Common Errors.
- DirectConnectClientException
- 
               One or more parameters are not valid. HTTP Status Code: 400 
- DirectConnectServerException
- 
               A server-side error occurred. HTTP Status Code: 400 
- DuplicateTagKeysException
- 
               A tag key was specified more than once. HTTP Status Code: 400 
- TooManyTagsException
- 
               You have reached the limit on the number of tags that can be assigned. HTTP Status Code: 400 
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: