You are viewing documentation for version 2 of the AWS SDK for Ruby. Version 3 documentation can be found here.
Class: Aws::DirectConnect::Client
- Inherits:
-
Seahorse::Client::Base
- Object
- Seahorse::Client::Base
- Aws::DirectConnect::Client
- Defined in:
- (unknown)
Overview
An API client for AWS Direct Connect. To construct a client, you need to configure a :region
and :credentials
.
directconnect = Aws::DirectConnect::Client.new(
region: region_name,
credentials: credentials,
# ...
)
See #initialize for a full list of supported configuration options.
Region
You can configure a default region in the following locations:
ENV['AWS_REGION']
Aws.config[:region]
Go here for a list of supported regions.
Credentials
Default credentials are loaded automatically from the following locations:
ENV['AWS_ACCESS_KEY_ID']
andENV['AWS_SECRET_ACCESS_KEY']
Aws.config[:credentials]
- The shared credentials ini file at
~/.aws/credentials
(more information) - From an instance profile when running on EC2
You can also construct a credentials object from one of the following classes:
Alternatively, you configure credentials with :access_key_id
and
:secret_access_key
:
# load credentials from disk
creds = YAML.load(File.read('/path/to/secrets'))
Aws::DirectConnect::Client.new(
access_key_id: creds['access_key_id'],
secret_access_key: creds['secret_access_key']
)
Always load your credentials from outside your application. Avoid configuring credentials statically and never commit them to source control.
Instance Attribute Summary
Attributes inherited from Seahorse::Client::Base
Constructor collapse
-
#initialize(options = {}) ⇒ Aws::DirectConnect::Client
constructor
Constructs an API client.
API Operations collapse
-
#accept_direct_connect_gateway_association_proposal(options = {}) ⇒ Types::AcceptDirectConnectGatewayAssociationProposalResult
Accepts a proposal request to attach a virtual private gateway or transit gateway to a Direct Connect gateway.
.
-
#allocate_connection_on_interconnect(options = {}) ⇒ Types::Connection
Deprecated.
-
#allocate_hosted_connection(options = {}) ⇒ Types::Connection
Creates a hosted connection on the specified interconnect or a link aggregation group (LAG) of interconnects.
Allocates a VLAN number and a specified amount of capacity (bandwidth) for use by a hosted connection on the specified interconnect or LAG of interconnects.
-
#allocate_private_virtual_interface(options = {}) ⇒ Types::VirtualInterface
Provisions a private virtual interface to be owned by the specified AWS account.
Virtual interfaces created using this action must be confirmed by the owner using ConfirmPrivateVirtualInterface.
-
#allocate_public_virtual_interface(options = {}) ⇒ Types::VirtualInterface
Provisions a public virtual interface to be owned by the specified AWS account.
The owner of a connection calls this function to provision a public virtual interface to be owned by the specified AWS account.
Virtual interfaces created using this function must be confirmed by the owner using ConfirmPublicVirtualInterface.
-
#allocate_transit_virtual_interface(options = {}) ⇒ Types::AllocateTransitVirtualInterfaceResult
Provisions a transit virtual interface to be owned by the specified AWS account.
-
#associate_connection_with_lag(options = {}) ⇒ Types::Connection
Associates an existing connection with a link aggregation group (LAG).
-
#associate_hosted_connection(options = {}) ⇒ Types::Connection
Associates a hosted connection and its virtual interfaces with a link aggregation group (LAG) or interconnect.
-
#associate_virtual_interface(options = {}) ⇒ Types::VirtualInterface
Associates a virtual interface with a specified link aggregation group (LAG) or connection.
-
#confirm_connection(options = {}) ⇒ Types::ConfirmConnectionResponse
Confirms the creation of the specified hosted connection on an interconnect.
Upon creation, the hosted connection is initially in the
.Ordering
state, and remains in this state until the owner confirms creation of the hosted connection. -
#confirm_private_virtual_interface(options = {}) ⇒ Types::ConfirmPrivateVirtualInterfaceResponse
Accepts ownership of a private virtual interface created by another AWS account.
After the virtual interface owner makes this call, the virtual interface is created and attached to the specified virtual private gateway or Direct Connect gateway, and is made available to handle traffic.
. -
#confirm_public_virtual_interface(options = {}) ⇒ Types::ConfirmPublicVirtualInterfaceResponse
Accepts ownership of a public virtual interface created by another AWS account.
After the virtual interface owner makes this call, the specified virtual interface is created and made available to handle traffic.
. -
#confirm_transit_virtual_interface(options = {}) ⇒ Types::ConfirmTransitVirtualInterfaceResponse
Accepts ownership of a transit virtual interface created by another AWS account.
After the owner of the transit virtual interface makes this call, the specified transit virtual interface is created and made available to handle traffic.
. -
#create_bgp_peer(options = {}) ⇒ Types::CreateBGPPeerResponse
Creates a BGP peer on the specified virtual interface.
You must create a BGP peer for the corresponding address family (IPv4/IPv6) in order to access AWS resources that also use that address family.
If logical redundancy is not supported by the connection, interconnect, or LAG, the BGP peer cannot be in the same address family as an existing BGP peer on the virtual interface.
When creating a IPv6 BGP peer, omit the Amazon address and customer address.
-
#create_connection(options = {}) ⇒ Types::Connection
Creates a connection between a customer network and a specific AWS Direct Connect location.
A connection links your internal network to an AWS Direct Connect location over a standard Ethernet fiber-optic cable.
-
#create_direct_connect_gateway(options = {}) ⇒ Types::CreateDirectConnectGatewayResult
Creates a Direct Connect gateway, which is an intermediate object that enables you to connect a set of virtual interfaces and virtual private gateways.
-
#create_direct_connect_gateway_association(options = {}) ⇒ Types::CreateDirectConnectGatewayAssociationResult
Creates an association between a Direct Connect gateway and a virtual private gateway.
-
#create_direct_connect_gateway_association_proposal(options = {}) ⇒ Types::CreateDirectConnectGatewayAssociationProposalResult
Creates a proposal to associate the specified virtual private gateway or transit gateway with the specified Direct Connect gateway.
You can associate a Direct Connect gateway and virtual private gateway or transit gateway that is owned by any AWS account.
-
#create_interconnect(options = {}) ⇒ Types::Interconnect
Creates an interconnect between an AWS Direct Connect Partner's network and a specific AWS Direct Connect location.
An interconnect is a connection that is capable of hosting other connections.
-
#create_lag(options = {}) ⇒ Types::Lag
Creates a link aggregation group (LAG) with the specified number of bundled physical dedicated connections between the customer network and a specific AWS Direct Connect location.
-
#create_private_virtual_interface(options = {}) ⇒ Types::VirtualInterface
Creates a private virtual interface.
-
#create_public_virtual_interface(options = {}) ⇒ Types::VirtualInterface
Creates a public virtual interface.
-
#create_transit_virtual_interface(options = {}) ⇒ Types::CreateTransitVirtualInterfaceResult
Creates a transit virtual interface.
-
#delete_bgp_peer(options = {}) ⇒ Types::DeleteBGPPeerResponse
Deletes the specified BGP peer on the specified virtual interface with the specified customer address and ASN.
You cannot delete the last BGP peer from a virtual interface.
. -
#delete_connection(options = {}) ⇒ Types::Connection
Deletes the specified connection.
Deleting a connection only stops the AWS Direct Connect port hour and data transfer charges.
-
#delete_direct_connect_gateway(options = {}) ⇒ Types::DeleteDirectConnectGatewayResult
Deletes the specified Direct Connect gateway.
-
#delete_direct_connect_gateway_association(options = {}) ⇒ Types::DeleteDirectConnectGatewayAssociationResult
Deletes the association between the specified Direct Connect gateway and virtual private gateway.
We recommend that you specify the
associationID
to delete the association. -
#delete_direct_connect_gateway_association_proposal(options = {}) ⇒ Types::DeleteDirectConnectGatewayAssociationProposalResult
Deletes the association proposal request between the specified Direct Connect gateway and virtual private gateway or transit gateway.
.
-
#delete_interconnect(options = {}) ⇒ Types::DeleteInterconnectResponse
Deletes the specified interconnect.
Intended for use by AWS Direct Connect Partners only.
-
#delete_lag(options = {}) ⇒ Types::Lag
Deletes the specified link aggregation group (LAG).
-
#delete_virtual_interface(options = {}) ⇒ Types::DeleteVirtualInterfaceResponse
Deletes a virtual interface.
.
-
#describe_connection_loa(options = {}) ⇒ Types::DescribeConnectionLoaResponse
Deprecated.
-
#describe_connections(options = {}) ⇒ Types::Connections
Displays the specified connection or all connections in this Region.
.
-
#describe_connections_on_interconnect(options = {}) ⇒ Types::Connections
Deprecated.
-
#describe_direct_connect_gateway_association_proposals(options = {}) ⇒ Types::DescribeDirectConnectGatewayAssociationProposalsResult
Describes one or more association proposals for connection between a virtual private gateway or transit gateway and a Direct Connect gateway.
-
#describe_direct_connect_gateway_associations(options = {}) ⇒ Types::DescribeDirectConnectGatewayAssociationsResult
Lists the associations between your Direct Connect gateways and virtual private gateways.
-
#describe_direct_connect_gateway_attachments(options = {}) ⇒ Types::DescribeDirectConnectGatewayAttachmentsResult
Lists the attachments between your Direct Connect gateways and virtual interfaces.
-
#describe_direct_connect_gateways(options = {}) ⇒ Types::DescribeDirectConnectGatewaysResult
Lists all your Direct Connect gateways or only the specified Direct Connect gateway.
-
#describe_hosted_connections(options = {}) ⇒ Types::Connections
Lists the hosted connections that have been provisioned on the specified interconnect or link aggregation group (LAG).
Intended for use by AWS Direct Connect Partners only.
-
#describe_interconnect_loa(options = {}) ⇒ Types::DescribeInterconnectLoaResponse
Deprecated.
-
#describe_interconnects(options = {}) ⇒ Types::Interconnects
Lists the interconnects owned by the AWS account or only the specified interconnect.
.
-
#describe_lags(options = {}) ⇒ Types::Lags
Describes all your link aggregation groups (LAG) or the specified LAG.
.
-
#describe_loa(options = {}) ⇒ Types::Loa
Gets the LOA-CFA for a connection, interconnect, or link aggregation group (LAG).
The Letter of Authorization - Connecting Facility Assignment (LOA-CFA) is a document that is used when establishing your cross connect to AWS at the colocation facility.
-
#describe_locations(options = {}) ⇒ Types::Locations
Lists the AWS Direct Connect locations in the current AWS Region.
-
#describe_tags(options = {}) ⇒ Types::DescribeTagsResponse
Describes the tags associated with the specified AWS Direct Connect resources.
.
-
#describe_virtual_gateways(options = {}) ⇒ Types::VirtualGateways
Lists the virtual private gateways owned by the AWS account.
You can create one or more AWS Direct Connect private virtual interfaces linked to a virtual private gateway.
. -
#describe_virtual_interfaces(options = {}) ⇒ Types::VirtualInterfaces
Displays all virtual interfaces for an AWS account.
-
#disassociate_connection_from_lag(options = {}) ⇒ Types::Connection
Disassociates a connection from a link aggregation group (LAG).
-
#list_virtual_interface_test_history(options = {}) ⇒ Types::ListVirtualInterfaceTestHistoryResponse
Lists the virtual interface failover test history.
.
-
#start_bgp_failover_test(options = {}) ⇒ Types::StartBgpFailoverTestResponse
Starts the virtual interface failover test that verifies your configuration meets your resiliency requirements by placing the BGP peering session in the DOWN state.
-
#stop_bgp_failover_test(options = {}) ⇒ Types::StopBgpFailoverTestResponse
Stops the virtual interface failover test.
.
-
#tag_resource(options = {}) ⇒ Struct
Adds the specified tags to the specified AWS Direct Connect resource.
-
#untag_resource(options = {}) ⇒ Struct
Removes one or more tags from the specified AWS Direct Connect resource.
.
-
#update_direct_connect_gateway_association(options = {}) ⇒ Types::UpdateDirectConnectGatewayAssociationResult
Updates the specified attributes of the Direct Connect gateway association.
Add or remove prefixes from the association.
. -
#update_lag(options = {}) ⇒ Types::Lag
Updates the attributes of the specified link aggregation group (LAG).
You can update the following attributes:
-
The name of the LAG.
-
The value for the minimum number of connections that must be operational for the LAG itself to be operational.
-
-
#update_virtual_interface_attributes(options = {}) ⇒ Types::VirtualInterface
Updates the specified attributes of the specified virtual private interface.
Setting the MTU of a virtual interface to 9001 (jumbo frames) can cause an update to the underlying physical connection if it wasn't updated to support jumbo frames.
Instance Method Summary collapse
-
#wait_until(waiter_name, params = {}) {|waiter| ... } ⇒ Boolean
Waiters polls an API operation until a resource enters a desired state.
-
#waiter_names ⇒ Array<Symbol>
Returns the list of supported waiters.
Methods inherited from Seahorse::Client::Base
add_plugin, api, #build_request, clear_plugins, define, new, #operation, #operation_names, plugins, remove_plugin, set_api, set_plugins
Methods included from Seahorse::Client::HandlerBuilder
#handle, #handle_request, #handle_response
Constructor Details
#initialize(options = {}) ⇒ Aws::DirectConnect::Client
Constructs an API client.
Instance Method Details
#accept_direct_connect_gateway_association_proposal(options = {}) ⇒ Types::AcceptDirectConnectGatewayAssociationProposalResult
Accepts a proposal request to attach a virtual private gateway or transit gateway to a Direct Connect gateway.
#allocate_connection_on_interconnect(options = {}) ⇒ Types::Connection
Deprecated. Use AllocateHostedConnection instead.
Creates a hosted connection on an interconnect.
Allocates a VLAN number and a specified amount of bandwidth for use by a hosted connection on the specified interconnect.
Intended for use by AWS Direct Connect Partners only.
#allocate_hosted_connection(options = {}) ⇒ Types::Connection
Creates a hosted connection on the specified interconnect or a link aggregation group (LAG) of interconnects.
Allocates a VLAN number and a specified amount of capacity (bandwidth) for use by a hosted connection on the specified interconnect or LAG of interconnects. AWS polices the hosted connection for the specified capacity and the AWS Direct Connect Partner must also police the hosted connection for the specified capacity.
Intended for use by AWS Direct Connect Partners only.
#allocate_private_virtual_interface(options = {}) ⇒ Types::VirtualInterface
Provisions a private virtual interface to be owned by the specified AWS account.
Virtual interfaces created using this action must be confirmed by the owner using ConfirmPrivateVirtualInterface. Until then, the virtual interface is in the Confirming
state and is not available to handle traffic.
#allocate_public_virtual_interface(options = {}) ⇒ Types::VirtualInterface
Provisions a public virtual interface to be owned by the specified AWS account.
The owner of a connection calls this function to provision a public virtual interface to be owned by the specified AWS account.
Virtual interfaces created using this function must be confirmed by the owner using ConfirmPublicVirtualInterface. Until this step has been completed, the virtual interface is in the confirming
state and is not available to handle traffic.
When creating an IPv6 public virtual interface, omit the Amazon address and customer address. IPv6 addresses are automatically assigned from the Amazon pool of IPv6 addresses; you cannot specify custom IPv6 addresses.
#allocate_transit_virtual_interface(options = {}) ⇒ Types::AllocateTransitVirtualInterfaceResult
Provisions a transit virtual interface to be owned by the specified AWS account. Use this type of interface to connect a transit gateway to your Direct Connect gateway.
The owner of a connection provisions a transit virtual interface to be owned by the specified AWS account.
After you create a transit virtual interface, it must be confirmed by the owner using ConfirmTransitVirtualInterface. Until this step has been completed, the transit virtual interface is in the requested
state and is not available to handle traffic.
#associate_connection_with_lag(options = {}) ⇒ Types::Connection
Associates an existing connection with a link aggregation group (LAG). The connection is interrupted and re-established as a member of the LAG (connectivity to AWS is interrupted). The connection must be hosted on the same AWS Direct Connect endpoint as the LAG, and its bandwidth must match the bandwidth for the LAG. You can re-associate a connection that's currently associated with a different LAG; however, if removing the connection would cause the original LAG to fall below its setting for minimum number of operational connections, the request fails.
Any virtual interfaces that are directly associated with the connection are automatically re-associated with the LAG. If the connection was originally associated with a different LAG, the virtual interfaces remain associated with the original LAG.
For interconnects, any hosted connections are automatically re-associated with the LAG. If the interconnect was originally associated with a different LAG, the hosted connections remain associated with the original LAG.
#associate_hosted_connection(options = {}) ⇒ Types::Connection
Associates a hosted connection and its virtual interfaces with a link aggregation group (LAG) or interconnect. If the target interconnect or LAG has an existing hosted connection with a conflicting VLAN number or IP address, the operation fails. This action temporarily interrupts the hosted connection's connectivity to AWS as it is being migrated.
Intended for use by AWS Direct Connect Partners only.
#associate_virtual_interface(options = {}) ⇒ Types::VirtualInterface
Associates a virtual interface with a specified link aggregation group (LAG) or connection. Connectivity to AWS is temporarily interrupted as the virtual interface is being migrated. If the target connection or LAG has an associated virtual interface with a conflicting VLAN number or a conflicting IP address, the operation fails.
Virtual interfaces associated with a hosted connection cannot be associated with a LAG; hosted connections must be migrated along with their virtual interfaces using AssociateHostedConnection.
To reassociate a virtual interface to a new connection or LAG, the requester must own either the virtual interface itself or the connection to which the virtual interface is currently associated. Additionally, the requester must own the connection or LAG for the association.
#confirm_connection(options = {}) ⇒ Types::ConfirmConnectionResponse
Confirms the creation of the specified hosted connection on an interconnect.
Upon creation, the hosted connection is initially in the Ordering
state, and remains in this state until the owner confirms creation of the hosted connection.
#confirm_private_virtual_interface(options = {}) ⇒ Types::ConfirmPrivateVirtualInterfaceResponse
Accepts ownership of a private virtual interface created by another AWS account.
After the virtual interface owner makes this call, the virtual interface is created and attached to the specified virtual private gateway or Direct Connect gateway, and is made available to handle traffic.
#confirm_public_virtual_interface(options = {}) ⇒ Types::ConfirmPublicVirtualInterfaceResponse
Accepts ownership of a public virtual interface created by another AWS account.
After the virtual interface owner makes this call, the specified virtual interface is created and made available to handle traffic.
#confirm_transit_virtual_interface(options = {}) ⇒ Types::ConfirmTransitVirtualInterfaceResponse
Accepts ownership of a transit virtual interface created by another AWS account.
After the owner of the transit virtual interface makes this call, the specified transit virtual interface is created and made available to handle traffic.
#create_bgp_peer(options = {}) ⇒ Types::CreateBGPPeerResponse
Creates a BGP peer on the specified virtual interface.
You must create a BGP peer for the corresponding address family (IPv4/IPv6) in order to access AWS resources that also use that address family.
If logical redundancy is not supported by the connection, interconnect, or LAG, the BGP peer cannot be in the same address family as an existing BGP peer on the virtual interface.
When creating a IPv6 BGP peer, omit the Amazon address and customer address. IPv6 addresses are automatically assigned from the Amazon pool of IPv6 addresses; you cannot specify custom IPv6 addresses.
For a public virtual interface, the Autonomous System Number (ASN) must be private or already whitelisted for the virtual interface.
#create_connection(options = {}) ⇒ Types::Connection
Creates a connection between a customer network and a specific AWS Direct Connect location.
A connection links your internal network to an AWS Direct Connect location over a standard Ethernet fiber-optic cable. One end of the cable is connected to your router, the other to an AWS Direct Connect router.
To find the locations for your Region, use DescribeLocations.
You can automatically add the new connection to a link aggregation group (LAG) by specifying a LAG ID in the request. This ensures that the new connection is allocated on the same AWS Direct Connect endpoint that hosts the specified LAG. If there are no available ports on the endpoint, the request fails and no connection is created.
#create_direct_connect_gateway(options = {}) ⇒ Types::CreateDirectConnectGatewayResult
Creates a Direct Connect gateway, which is an intermediate object that enables you to connect a set of virtual interfaces and virtual private gateways. A Direct Connect gateway is global and visible in any AWS Region after it is created. The virtual interfaces and virtual private gateways that are connected through a Direct Connect gateway can be in different AWS Regions. This enables you to connect to a VPC in any Region, regardless of the Region in which the virtual interfaces are located, and pass traffic between them.
#create_direct_connect_gateway_association(options = {}) ⇒ Types::CreateDirectConnectGatewayAssociationResult
Creates an association between a Direct Connect gateway and a virtual private gateway. The virtual private gateway must be attached to a VPC and must not be associated with another Direct Connect gateway.
#create_direct_connect_gateway_association_proposal(options = {}) ⇒ Types::CreateDirectConnectGatewayAssociationProposalResult
Creates a proposal to associate the specified virtual private gateway or transit gateway with the specified Direct Connect gateway.
You can associate a Direct Connect gateway and virtual private gateway or transit gateway that is owned by any AWS account.
#create_interconnect(options = {}) ⇒ Types::Interconnect
Creates an interconnect between an AWS Direct Connect Partner's network and a specific AWS Direct Connect location.
An interconnect is a connection that is capable of hosting other connections. The AWS Direct Connect partner can use an interconnect to provide AWS Direct Connect hosted connections to customers through their own network services. Like a standard connection, an interconnect links the partner's network to an AWS Direct Connect location over a standard Ethernet fiber-optic cable. One end is connected to the partner's router, the other to an AWS Direct Connect router.
You can automatically add the new interconnect to a link aggregation group (LAG) by specifying a LAG ID in the request. This ensures that the new interconnect is allocated on the same AWS Direct Connect endpoint that hosts the specified LAG. If there are no available ports on the endpoint, the request fails and no interconnect is created.
For each end customer, the AWS Direct Connect Partner provisions a connection on their interconnect by calling AllocateHostedConnection. The end customer can then connect to AWS resources by creating a virtual interface on their connection, using the VLAN assigned to them by the AWS Direct Connect Partner.
Intended for use by AWS Direct Connect Partners only.
#create_lag(options = {}) ⇒ Types::Lag
Creates a link aggregation group (LAG) with the specified number of bundled physical dedicated connections between the customer network and a specific AWS Direct Connect location. A LAG is a logical interface that uses the Link Aggregation Control Protocol (LACP) to aggregate multiple interfaces, enabling you to treat them as a single interface.
All connections in a LAG must use the same bandwidth (either 1Gbps or 10Gbps) and must terminate at the same AWS Direct Connect endpoint.
You can have up to 10 dedicated connections per LAG. Regardless of this limit, if you request more connections for the LAG than AWS Direct Connect can allocate on a single endpoint, no LAG is created.
You can specify an existing physical dedicated connection or interconnect to include in the LAG (which counts towards the total number of connections). Doing so interrupts the current physical dedicated connection, and re-establishes them as a member of the LAG. The LAG will be created on the same AWS Direct Connect endpoint to which the dedicated connection terminates. Any virtual interfaces associated with the dedicated connection are automatically disassociated and re-associated with the LAG. The connection ID does not change.
If the AWS account used to create a LAG is a registered AWS Direct Connect Partner, the LAG is automatically enabled to host sub-connections. For a LAG owned by a partner, any associated virtual interfaces cannot be directly configured.
#create_private_virtual_interface(options = {}) ⇒ Types::VirtualInterface
Creates a private virtual interface. A virtual interface is the VLAN that transports AWS Direct Connect traffic. A private virtual interface can be connected to either a Direct Connect gateway or a Virtual Private Gateway (VGW). Connecting the private virtual interface to a Direct Connect gateway enables the possibility for connecting to multiple VPCs, including VPCs in different AWS Regions. Connecting the private virtual interface to a VGW only provides access to a single VPC within the same Region.
Setting the MTU of a virtual interface to 9001 (jumbo frames) can cause an update to the underlying physical connection if it wasn't updated to support jumbo frames. Updating the connection disrupts network connectivity for all virtual interfaces associated with the connection for up to 30 seconds. To check whether your connection supports jumbo frames, call DescribeConnections. To check whether your virtual interface supports jumbo frames, call DescribeVirtualInterfaces.
#create_public_virtual_interface(options = {}) ⇒ Types::VirtualInterface
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.
#create_transit_virtual_interface(options = {}) ⇒ Types::CreateTransitVirtualInterfaceResult
Creates a transit virtual interface. A transit virtual interface should be used to access one or more transit gateways associated with Direct Connect gateways. A transit virtual interface enables the connection of multiple VPCs attached to a transit gateway to a Direct Connect gateway.
If you associate your transit gateway with one or more Direct Connect gateways, the Autonomous System Number (ASN) used by the transit gateway and the Direct Connect gateway must be different. For example, if you use the default ASN 64512 for both your the transit gateway and Direct Connect gateway, the association request fails.
Setting the MTU of a virtual interface to 8500 (jumbo frames) can cause an update to the underlying physical connection if it wasn't updated to support jumbo frames. Updating the connection disrupts network connectivity for all virtual interfaces associated with the connection for up to 30 seconds. To check whether your connection supports jumbo frames, call DescribeConnections. To check whether your virtual interface supports jumbo frames, call DescribeVirtualInterfaces.
#delete_bgp_peer(options = {}) ⇒ Types::DeleteBGPPeerResponse
Deletes the specified BGP peer on the specified virtual interface with the specified customer address and ASN.
You cannot delete the last BGP peer from a virtual interface.
#delete_connection(options = {}) ⇒ Types::Connection
Deletes the specified connection.
Deleting a connection only stops the AWS Direct Connect port hour and data transfer charges. If you are partnering with any third parties to connect with the AWS Direct Connect location, you must cancel your service with them separately.
#delete_direct_connect_gateway(options = {}) ⇒ Types::DeleteDirectConnectGatewayResult
Deletes the specified Direct Connect gateway. You must first delete all virtual interfaces that are attached to the Direct Connect gateway and disassociate all virtual private gateways associated with the Direct Connect gateway.
#delete_direct_connect_gateway_association(options = {}) ⇒ Types::DeleteDirectConnectGatewayAssociationResult
Deletes the association between the specified Direct Connect gateway and virtual private gateway.
We recommend that you specify the associationID
to delete the association. Alternatively, if you own virtual gateway and a Direct Connect gateway association, you can specify the virtualGatewayId
and directConnectGatewayId
to delete an association.
#delete_direct_connect_gateway_association_proposal(options = {}) ⇒ Types::DeleteDirectConnectGatewayAssociationProposalResult
Deletes the association proposal request between the specified Direct Connect gateway and virtual private gateway or transit gateway.
#delete_interconnect(options = {}) ⇒ Types::DeleteInterconnectResponse
Deletes the specified interconnect.
Intended for use by AWS Direct Connect Partners only.
#delete_lag(options = {}) ⇒ Types::Lag
Deletes the specified link aggregation group (LAG). You cannot delete a LAG if it has active virtual interfaces or hosted connections.
#delete_virtual_interface(options = {}) ⇒ Types::DeleteVirtualInterfaceResponse
Deletes a virtual interface.
#describe_connection_loa(options = {}) ⇒ Types::DescribeConnectionLoaResponse
Deprecated. Use DescribeLoa instead.
Gets the LOA-CFA for a connection.
The Letter of Authorization - Connecting Facility Assignment (LOA-CFA) is a document that your APN partner or service provider uses when establishing your cross connect to AWS at the colocation facility. For more information, see Requesting Cross Connects at AWS Direct Connect Locations in the AWS Direct Connect User Guide.
#describe_connections(options = {}) ⇒ Types::Connections
Displays the specified connection or all connections in this Region.
#describe_connections_on_interconnect(options = {}) ⇒ Types::Connections
Deprecated. Use DescribeHostedConnections instead.
Lists the connections that have been provisioned on the specified interconnect.
Intended for use by AWS Direct Connect Partners only.
#describe_direct_connect_gateway_association_proposals(options = {}) ⇒ Types::DescribeDirectConnectGatewayAssociationProposalsResult
Describes one or more association proposals for connection between a virtual private gateway or transit gateway and a Direct Connect gateway.
#describe_direct_connect_gateway_associations(options = {}) ⇒ Types::DescribeDirectConnectGatewayAssociationsResult
Lists the associations between your Direct Connect gateways and virtual private gateways. You must specify a Direct Connect gateway, a virtual private gateway, or both. If you specify a Direct Connect gateway, the response contains all virtual private gateways associated with the Direct Connect gateway. If you specify a virtual private gateway, the response contains all Direct Connect gateways associated with the virtual private gateway. If you specify both, the response contains the association between the Direct Connect gateway and the virtual private gateway.
#describe_direct_connect_gateway_attachments(options = {}) ⇒ Types::DescribeDirectConnectGatewayAttachmentsResult
Lists the attachments between your Direct Connect gateways and virtual interfaces. You must specify a Direct Connect gateway, a virtual interface, or both. If you specify a Direct Connect gateway, the response contains all virtual interfaces attached to the Direct Connect gateway. If you specify a virtual interface, the response contains all Direct Connect gateways attached to the virtual interface. If you specify both, the response contains the attachment between the Direct Connect gateway and the virtual interface.
#describe_direct_connect_gateways(options = {}) ⇒ Types::DescribeDirectConnectGatewaysResult
Lists all your Direct Connect gateways or only the specified Direct Connect gateway. Deleted Direct Connect gateways are not returned.
#describe_hosted_connections(options = {}) ⇒ Types::Connections
Lists the hosted connections that have been provisioned on the specified interconnect or link aggregation group (LAG).
Intended for use by AWS Direct Connect Partners only.
#describe_interconnect_loa(options = {}) ⇒ Types::DescribeInterconnectLoaResponse
Deprecated. Use DescribeLoa instead.
Gets the LOA-CFA for the specified interconnect.
The Letter of Authorization - Connecting Facility Assignment (LOA-CFA) is a document that is used when establishing your cross connect to AWS at the colocation facility. For more information, see Requesting Cross Connects at AWS Direct Connect Locations in the AWS Direct Connect User Guide.
#describe_interconnects(options = {}) ⇒ Types::Interconnects
Lists the interconnects owned by the AWS account or only the specified interconnect.
#describe_lags(options = {}) ⇒ Types::Lags
Describes all your link aggregation groups (LAG) or the specified LAG.
#describe_loa(options = {}) ⇒ Types::Loa
Gets the LOA-CFA for a connection, interconnect, or link aggregation group (LAG).
The Letter of Authorization - Connecting Facility Assignment (LOA-CFA) is a document that is used when establishing your cross connect to AWS at the colocation facility. For more information, see Requesting Cross Connects at AWS Direct Connect Locations in the AWS Direct Connect User Guide.
#describe_locations(options = {}) ⇒ Types::Locations
Lists the AWS Direct Connect locations in the current AWS Region. These are the locations that can be selected when calling CreateConnection or CreateInterconnect.
#describe_tags(options = {}) ⇒ Types::DescribeTagsResponse
Describes the tags associated with the specified AWS Direct Connect resources.
#describe_virtual_gateways(options = {}) ⇒ Types::VirtualGateways
Lists the virtual private gateways owned by the AWS account.
You can create one or more AWS Direct Connect private virtual interfaces linked to a virtual private gateway.
#describe_virtual_interfaces(options = {}) ⇒ Types::VirtualInterfaces
Displays all virtual interfaces for an AWS account. Virtual interfaces deleted fewer than 15 minutes before you make the request are also returned. If you specify a connection ID, only the virtual interfaces associated with the connection are returned. If you specify a virtual interface ID, then only a single virtual interface is returned.
A virtual interface (VLAN) transmits the traffic between the AWS Direct Connect location and the customer network.
#disassociate_connection_from_lag(options = {}) ⇒ Types::Connection
Disassociates a connection from a link aggregation group (LAG). The connection is interrupted and re-established as a standalone connection (the connection is not deleted; to delete the connection, use the DeleteConnection request). If the LAG has associated virtual interfaces or hosted connections, they remain associated with the LAG. A disassociated connection owned by an AWS Direct Connect Partner is automatically converted to an interconnect.
If disassociating the connection would cause the LAG to fall below its setting for minimum number of operational connections, the request fails, except when it's the last member of the LAG. If all connections are disassociated, the LAG continues to exist as an empty LAG with no physical connections.
#list_virtual_interface_test_history(options = {}) ⇒ Types::ListVirtualInterfaceTestHistoryResponse
Lists the virtual interface failover test history.
#start_bgp_failover_test(options = {}) ⇒ Types::StartBgpFailoverTestResponse
Starts the virtual interface failover test that verifies your configuration meets your resiliency requirements by placing the BGP peering session in the DOWN state. You can then send traffic to verify that there are no outages.
You can run the test on public, private, transit, and hosted virtual interfaces.
You can use ListVirtualInterfaceTestHistory to view the virtual interface test history.
If you need to stop the test before the test interval completes, use StopBgpFailoverTest.
#stop_bgp_failover_test(options = {}) ⇒ Types::StopBgpFailoverTestResponse
Stops the virtual interface failover test.
#tag_resource(options = {}) ⇒ Struct
Adds the specified tags to the specified AWS Direct Connect resource. Each resource can have a maximum of 50 tags.
Each tag consists of a key and an optional value. If a tag with the same key is already associated with the resource, this action updates its value.
#untag_resource(options = {}) ⇒ Struct
Removes one or more tags from the specified AWS Direct Connect resource.
#update_direct_connect_gateway_association(options = {}) ⇒ Types::UpdateDirectConnectGatewayAssociationResult
Updates the specified attributes of the Direct Connect gateway association.
Add or remove prefixes from the association.
#update_lag(options = {}) ⇒ Types::Lag
Updates the attributes of the specified link aggregation group (LAG).
You can update the following attributes:
-
The name of the LAG.
-
The value for the minimum number of connections that must be operational for the LAG itself to be operational.
When you create a LAG, the default value for the minimum number of operational connections is zero (0). If you update this value and the number of operational connections falls below the specified value, the LAG automatically goes down to avoid over-utilization of the remaining connections. Adjust this value with care, as it could force the LAG down if it is set higher than the current number of operational connections.
#update_virtual_interface_attributes(options = {}) ⇒ Types::VirtualInterface
Updates the specified attributes of the specified virtual private interface.
Setting the MTU of a virtual interface to 9001 (jumbo frames) can cause an update to the underlying physical connection if it wasn't updated to support jumbo frames. Updating the connection disrupts network connectivity for all virtual interfaces associated with the connection for up to 30 seconds. To check whether your connection supports jumbo frames, call DescribeConnections. To check whether your virtual q interface supports jumbo frames, call DescribeVirtualInterfaces.
#wait_until(waiter_name, params = {}) {|waiter| ... } ⇒ Boolean
Waiters polls an API operation until a resource enters a desired state.
Basic Usage
Waiters will poll until they are succesful, they fail by entering a terminal state, or until a maximum number of attempts are made.
# polls in a loop, sleeping between attempts client.waiter_until(waiter_name, params)
Configuration
You can configure the maximum number of polling attempts, and the delay (in seconds) between each polling attempt. You configure waiters by passing a block to #wait_until:
# poll for ~25 seconds
client.wait_until(...) do |w|
w.max_attempts = 5
w.delay = 5
end
Callbacks
You can be notified before each polling attempt and before each
delay. If you throw :success
or :failure
from these callbacks,
it will terminate the waiter.
started_at = Time.now
client.wait_until(...) do |w|
# disable max attempts
w.max_attempts = nil
# poll for 1 hour, instead of a number of attempts
w.before_wait do |attempts, response|
throw :failure if Time.now - started_at > 3600
end
end
Handling Errors
When a waiter is successful, it returns true
. When a waiter
fails, it raises an error. All errors raised extend from
Waiters::Errors::WaiterFailed.
begin
client.wait_until(...)
rescue Aws::Waiters::Errors::WaiterFailed
# resource did not enter the desired state in time
end
#waiter_names ⇒ Array<Symbol>
Returns the list of supported waiters. The following table lists the supported waiters and the client method they call:
Waiter Name | Client Method | Default Delay: | Default Max Attempts: |
---|