mirror of
https://github.com/fog/fog-aws.git
synced 2022-11-09 13:50:52 -05:00
[AWS|VPC] ability to enable/disable classiclink
This commit is contained in:
parent
3dad29880c
commit
dd30ec7972
4 changed files with 99 additions and 2 deletions
|
@ -124,8 +124,10 @@ module Fog
|
||||||
request :detach_network_interface
|
request :detach_network_interface
|
||||||
request :detach_internet_gateway
|
request :detach_internet_gateway
|
||||||
request :detach_volume
|
request :detach_volume
|
||||||
|
request :disable_vpc_classic_link
|
||||||
request :disassociate_address
|
request :disassociate_address
|
||||||
request :disassociate_route_table
|
request :disassociate_route_table
|
||||||
|
request :enable_vpc_classic_link
|
||||||
request :get_console_output
|
request :get_console_output
|
||||||
request :get_password_data
|
request :get_password_data
|
||||||
request :import_key_pair
|
request :import_key_pair
|
||||||
|
@ -454,7 +456,7 @@ module Fog
|
||||||
@region = options[:region] ||= 'us-east-1'
|
@region = options[:region] ||= 'us-east-1'
|
||||||
@instrumentor = options[:instrumentor]
|
@instrumentor = options[:instrumentor]
|
||||||
@instrumentor_name = options[:instrumentor_name] || 'fog.aws.compute'
|
@instrumentor_name = options[:instrumentor_name] || 'fog.aws.compute'
|
||||||
@version = options[:version] || '2014-06-15'
|
@version = options[:version] || '2014-10-01'
|
||||||
|
|
||||||
@use_iam_profile = options[:use_iam_profile]
|
@use_iam_profile = options[:use_iam_profile]
|
||||||
setup_credentials(options)
|
setup_credentials(options)
|
||||||
|
|
|
@ -50,7 +50,8 @@ module Fog
|
||||||
'tagSet' => {},
|
'tagSet' => {},
|
||||||
'enableDnsSupport' => true,
|
'enableDnsSupport' => true,
|
||||||
'enableDnsHostnames' => false,
|
'enableDnsHostnames' => false,
|
||||||
'mapPublicIpOnLaunch'=> false
|
'mapPublicIpOnLaunch'=> false,
|
||||||
|
'classicLinkEnabled' => false
|
||||||
}
|
}
|
||||||
self.data[:vpcs].push(vpc)
|
self.data[:vpcs].push(vpc)
|
||||||
|
|
||||||
|
|
47
lib/fog/aws/requests/compute/disable_vpc_classic_link.rb
Normal file
47
lib/fog/aws/requests/compute/disable_vpc_classic_link.rb
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
module Fog
|
||||||
|
module Compute
|
||||||
|
class AWS
|
||||||
|
class Real
|
||||||
|
require 'fog/aws/parsers/compute/basic'
|
||||||
|
# disavbles classic link for a vpc
|
||||||
|
#
|
||||||
|
# ==== Parameters
|
||||||
|
# * vpc_id<~String> - The ID of the VPC you want to describe an attribute of
|
||||||
|
# * dry_run<~Boolean> - defaults to false
|
||||||
|
#
|
||||||
|
# === Returns
|
||||||
|
# * response<~Excon::Response>:
|
||||||
|
# * body<~Hash>:
|
||||||
|
# * 'requestId'<~String> - Id of request
|
||||||
|
# * 'return'<~Boolean> - Whether the request succeeded
|
||||||
|
#
|
||||||
|
# (Amazon API Reference)[http://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_DisableVpcClassicLink.html]
|
||||||
|
def disable_vpc_classic_link(vpc_id, dry_run=false)
|
||||||
|
request(
|
||||||
|
'Action' => 'DisableVpcClassicLink',
|
||||||
|
'VpcId' => vpc_id,
|
||||||
|
'DryRun' => dry_run,
|
||||||
|
:parser => Fog::Parsers::Compute::AWS::Basic.new
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class Mock
|
||||||
|
def disable_vpc_classic_link(vpc_id, dry_run=false)
|
||||||
|
response = Excon::Response.new
|
||||||
|
if vpc = self.data[:vpcs].find{ |v| v['vpcId'] == vpc_id }
|
||||||
|
response.status = 200
|
||||||
|
response.body = {
|
||||||
|
'requestId' => Fog::AWS::Mock.request_id,
|
||||||
|
'return' => true
|
||||||
|
}
|
||||||
|
vpc['classicLinkEnabled'] = false unless dry_run
|
||||||
|
response
|
||||||
|
else
|
||||||
|
raise Fog::Compute::AWS::NotFound.new("The VPC '#{vpc_id}' does not exist")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
47
lib/fog/aws/requests/compute/enable_vpc_classic_link.rb
Normal file
47
lib/fog/aws/requests/compute/enable_vpc_classic_link.rb
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
module Fog
|
||||||
|
module Compute
|
||||||
|
class AWS
|
||||||
|
class Real
|
||||||
|
require 'fog/aws/parsers/compute/basic'
|
||||||
|
# enables classic link for a vpc
|
||||||
|
#
|
||||||
|
# ==== Parameters
|
||||||
|
# * vpc_id<~String> - The ID of the VPC you want to describe an attribute of
|
||||||
|
# * dry_run<~Boolean> - defaults to false
|
||||||
|
#
|
||||||
|
# === Returns
|
||||||
|
# * response<~Excon::Response>:
|
||||||
|
# * body<~Hash>:
|
||||||
|
# * 'requestId'<~String> - Id of request
|
||||||
|
# * 'return'<~Boolean> - Whether the request succeeded
|
||||||
|
#
|
||||||
|
# (Amazon API Reference)[http://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_EnableVpcClassicLink.html]
|
||||||
|
def enable_vpc_classic_link(vpc_id, dry_run=false)
|
||||||
|
request(
|
||||||
|
'Action' => 'EnableVpcClassicLink',
|
||||||
|
'VpcId' => vpc_id,
|
||||||
|
'DryRun' => dry_run,
|
||||||
|
:parser => Fog::Parsers::Compute::AWS::Basic.new
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class Mock
|
||||||
|
def enable_vpc_classic_link(vpc_id, dry_run=false)
|
||||||
|
response = Excon::Response.new
|
||||||
|
if vpc = self.data[:vpcs].find{ |v| v['vpcId'] == vpc_id }
|
||||||
|
response.status = 200
|
||||||
|
response.body = {
|
||||||
|
'requestId' => Fog::AWS::Mock.request_id,
|
||||||
|
'return' => true
|
||||||
|
}
|
||||||
|
vpc['classicLinkEnabled'] = true unless dry_run
|
||||||
|
response
|
||||||
|
else
|
||||||
|
raise Fog::Compute::AWS::NotFound.new("The VPC '#{vpc_id}' does not exist")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue