1
0
Fork 0
mirror of https://github.com/fog/fog-aws.git synced 2022-11-09 13:50:52 -05:00

Merge pull request #534 from KevinLoiseau/enhance/add_service_elbv2_to_handle_specificities

Create service ELBV2 to handle specificities of 2015-12-01 API version
This commit is contained in:
Wesley Beary 2019-10-28 08:23:37 -05:00 committed by GitHub
commit 401e86ef22
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
10 changed files with 372 additions and 1 deletions

View file

@ -26,6 +26,7 @@ module Fog
autoload :ECS, File.expand_path('../aws/ecs', __FILE__)
autoload :EFS, File.expand_path('../aws/efs', __FILE__)
autoload :ELB, File.expand_path('../aws/elb', __FILE__)
autoload :ELBV2, File.expand_path('../aws/elbv2', __FILE__)
autoload :EMR, File.expand_path('../aws/emr', __FILE__)
autoload :ElasticBeanstalk, File.expand_path('../aws/beanstalk', __FILE__)
autoload :Elasticache, File.expand_path('../aws/elasticache', __FILE__)
@ -58,6 +59,7 @@ module Fog
service(:ecs, 'ECS')
service(:efs, 'EFS')
service(:elb, 'ELB')
service(:elbv2, 'ELBV2')
service(:emr, 'EMR')
service(:federation, 'Federation')
service(:glacier, 'Glacier')

View file

@ -142,7 +142,7 @@ module Fog
@port = options[:port] || 443
@scheme = options[:scheme] || 'https'
@connection = Fog::XML::Connection.new("#{@scheme}://#{@host}:#{@port}#{@path}", @persistent, @connection_options)
@version = options[:version] || '2012-06-01'
@version ||= options[:version] || '2012-06-01'
setup_credentials(options)
end

17
lib/fog/aws/elbv2.rb Normal file
View file

@ -0,0 +1,17 @@
module Fog
module AWS
class ELBV2 < ELB
request_path 'fog/aws/requests/elbv2'
request :describe_load_balancers
request :describe_listeners
class Real < ELB::Real
def initialize(options={})
@version = '2015-12-01'
super(options)
end
end
end
end
end

View file

@ -0,0 +1,57 @@
module Fog
module Parsers
module AWS
module ELBV2
class DescribeListeners < Fog::Parsers::Base
def reset
reset_listener
@default_action = {}
@results = { 'Listeners' => [] }
@response = { 'DescribeListenersResult' => {}, 'ResponseMetadata' => {} }
end
def reset_listener
@listener= { 'DefaultActions' => [] }
end
def start_element(name, attrs = [])
super
case name
when 'DefaultActions'
@in_default_actions = true
end
end
def end_element(name)
case name
when 'member'
if @in_default_actions
@listener['DefaultActions'] << @default_action
@default_action = {}
else
@results['Listeners'] << @listener
reset_listener
end
when 'LoadBalancerArn', 'Protocol', 'Port', 'ListenerArn'
@listener[name] = value
when 'Type', 'TargetGroupArn'
@default_action[name] = value
when 'DefaultActions'
@in_default_actions = false
when 'RequestId'
@response['ResponseMetadata'][name] = value
when 'NextMarker'
@results['NextMarker'] = value
when 'DescribeListenersResponse'
@response['DescribeListenersResult'] = @results
end
end
end
end
end
end
end

View file

@ -0,0 +1,84 @@
module Fog
module Parsers
module AWS
module ELBV2
class DescribeLoadBalancers < Fog::Parsers::Base
def reset
reset_load_balancer
@availability_zone = { 'LoadBalancerAddresses' => [] }
@load_balancer_addresses = {}
@state = {}
@results = { 'LoadBalancers' => [] }
@response = { 'DescribeLoadBalancersResult' => {}, 'ResponseMetadata' => {} }
end
def reset_load_balancer
@load_balancer = { 'SecurityGroups' => [], 'AvailabilityZones' => [] }
end
def start_element(name, attrs = [])
super
case name
when 'AvailabilityZones'
@in_availability_zones = true
when 'LoadBalancerAddresses'
@in_load_balancer_addresses = true
when 'SecurityGroups'
@in_security_groups = true
when 'State'
@in_state = true
end
end
def end_element(name)
case name
when 'member'
if @in_availability_zones && @in_load_balancer_addresses
@availability_zone['LoadBalancerAddresses'] << @load_balancer_addresses
elsif @in_availability_zones
@load_balancer['AvailabilityZones'] << @availability_zone
@availability_zone = {}
elsif @in_security_groups
@load_balancer['SecurityGroups'] << value
else
@results['LoadBalancers'] << @load_balancer
reset_load_balancer
end
when 'SubnetId', 'ZoneName'
@availability_zone[name] = value
when 'IpAddress', 'AllocationId'
@load_balancer_addresses[name] = value
when 'CanonicalHostedZoneName', 'CanonicalHostedZoneNameID', 'LoadBalancerName', 'DNSName', 'Scheme', 'Type',
'LoadBalancerArn', 'IpAddressType', 'CanonicalHostedZoneId', 'VpcId'
@load_balancer[name] = value
when 'CreatedTime'
@load_balancer[name] = Time.parse(value)
when 'LoadBalancerAddresses'
@in_load_balancer_addresses = false
when 'AvailabilityZones'
@in_availability_zones = false
when 'SecurityGroups'
@in_security_groups = false
when 'State'
@in_state = false
@load_balancer[name] = @state
@state = {}
when 'Code'
@state[name] = value
when 'RequestId'
@response['ResponseMetadata'][name] = value
when 'NextMarker'
@results['NextMarker'] = value
when 'DescribeLoadBalancersResponse'
@response['DescribeLoadBalancersResult'] = @results
end
end
end
end
end
end
end

View file

@ -0,0 +1,38 @@
module Fog
module AWS
class ELBV2
class Real
require 'fog/aws/parsers/elbv2/describe_listeners'
# Describe all or specified load balancers
#
# ==== Parameters
# * 'LoadBalancerArn'<~String> - The Amazon Resource Name (ARN) of the load balancer
# * options<~Hash>
# * 'Marker'<String> - Indicates where to begin in your list of load balancers
#
# ==== Returns
# * response<~Excon::Response>:
# * body<~Hash>:
# * 'ResponseMetadata'<~Hash>:
# * 'RequestId'<~String> - Id of request
# * 'DescribeListenersResult'<~Hash>:
# * 'Listeners'<~Array>
# * 'LoadBalancerArn'<~String> - The Amazon Resource Name (ARN) of the load balancer
# * 'Protocol'<~String> - The protocol for connections from clients to the load balancer
# * 'Port'<~String> - The port on which the load balancer is listening
# * 'DefaultActions'<~Array> - The default actions for the listener
# * 'Type'<~String> - The type of action
# * 'TargetGroupArn'<~String> - The Amazon Resource Name (ARN) of the target group. Specify only when Type is forward
# * 'NextMarker'<~String> - Marker to specify for next page
def describe_listeners(load_balancer_arn, options = {})
request({
'Action' => 'DescribeListeners',
'LoadBalancerArn' => load_balancer_arn,
:parser => Fog::Parsers::AWS::ELBV2::DescribeListeners.new
}.merge!(options))
end
end
end
end
end

View file

@ -0,0 +1,52 @@
module Fog
module AWS
class ELBV2
class Real
require 'fog/aws/parsers/elbv2/describe_load_balancers'
# Describe all or specified load balancers
#
# ==== Parameters
# * options<~Hash>
# * 'LoadBalancerNames'<~Array> - List of load balancer names to describe, defaults to all
# * 'Marker'<String> - Indicates where to begin in your list of load balancers
#
# ==== Returns
# * response<~Excon::Response>:
# * body<~Hash>:
# * 'ResponseMetadata'<~Hash>:
# * 'RequestId'<~String> - Id of request
# * 'DescribeLoadBalancersResult'<~Hash>:
# * 'LoadBalancers'<~Array>
# * 'AvailabilityZones'<~Array>:
# * 'SubnetId'<~String> - ID of the subnet
# * 'ZoneName'<~String> - Name of the Availability Zone
# * 'LoadBalancerAddresses'<~Array>:
# * 'IpAddress'<~String> - IP address
# * 'AllocationId'<~String> - ID of the AWS allocation
# * 'CanonicalHostedZoneName'<~String> - name of the Route 53 hosted zone associated with the load balancer
# * 'CanonicalHostedZoneNameID'<~String> - ID of the Route 53 hosted zone associated with the load balancer
# * 'CreatedTime'<~Time> - time load balancer was created
# * 'DNSName'<~String> - external DNS name of load balancer
# * 'LoadBalancerName'<~String> - name of load balancer
# * 'SecurityGroups'<~Array> - array of security group id
# * 'NextMarker'<~String> - Marker to specify for next page
def describe_load_balancers(options = {})
unless options.is_a?(Hash)
Fog::Logger.deprecation("describe_load_balancers with #{options.class} is deprecated, use all('LoadBalancerNames' => []) instead [light_black](#{caller.first})[/]")
options = { 'LoadBalancerNames' => [options].flatten }
end
if names = options.delete('LoadBalancerNames')
options.update(Fog::AWS.indexed_param('LoadBalancerNames.member', [*names]))
end
request({
'Action' => 'DescribeLoadBalancers',
:parser => Fog::Parsers::AWS::ELBV2::DescribeLoadBalancers.new
}.merge!(options))
end
end
end
end
end

View file

@ -0,0 +1,34 @@
require 'fog/xml'
require 'fog/aws/parsers/elbv2/describe_listeners'
DESCRIBE_LISTENERS_RESULT = <<-EOF
<DescribeListenersResponse xmlns="http://elasticloadbalancing.amazonaws.com/doc/2015-12-01/">
<DescribeListenersResult>
<Listeners>
<member>
<LoadBalancerArn>arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/app/my-load-balancer/50dc6c495c0c9188</LoadBalancerArn>
<Protocol>HTTP</Protocol>
<Port>80</Port>
<ListenerArn>arn:aws:elasticloadbalancing:us-west-2:123456789012:listener/app/my-load-balancer/50dc6c495c0c9188/f2f7dc8efc522ab2</ListenerArn>
<DefaultActions>
<member>
<Type>forward</Type>
<TargetGroupArn>arn:aws:elasticloadbalancing:us-west-2:123456789012:targetgroup/my-targets/73e2d6bc24d8a067</TargetGroupArn>
</member>
</DefaultActions>
</member>
</Listeners>
</DescribeListenersResult>
<ResponseMetadata>
<RequestId>18e470d3-f39c-11e5-a53c-67205c0d10fd</RequestId>
</ResponseMetadata>
</DescribeListenersResponse>
EOF
Shindo.tests('AWS::ELBV2 | parsers | describe_listeners', %w[aws elb parser]) do
tests('parses the xml').formats(AWS::ELBV2::Formats::DESCRIBE_LISTENERS) do
parser = Nokogiri::XML::SAX::Parser.new(Fog::Parsers::AWS::ELBV2::DescribeListeners.new)
parser.parse(DESCRIBE_LISTENERS_RESULT)
parser.document.response
end
end

View file

@ -0,0 +1,48 @@
require 'fog/xml'
require 'fog/aws/parsers/elbv2/describe_load_balancers'
DESCRIBE_LOAD_BALANCERS_RESULT = <<-EOF
<DescribeLoadBalancersResponse xmlns="http://elasticloadbalancing.amazonaws.com/doc/2015-12-01/">
<DescribeLoadBalancersResult>
<LoadBalancers>
<member>
<LoadBalancerArn>arn:aws:elasticloadbalancing:us-west-2:123456789012:loadbalancer/app/my-load-balancer/50dc6c495c0c9188</LoadBalancerArn>
<Scheme>internet-facing</Scheme>
<LoadBalancerName>my-load-balancer</LoadBalancerName>
<VpcId>vpc-3ac0fb5f</VpcId>
<CanonicalHostedZoneId>Z2P70J7EXAMPLE</CanonicalHostedZoneId>
<CreatedTime>2016-03-25T21:26:12.920Z</CreatedTime>
<AvailabilityZones>
<member>
<SubnetId>subnet-8360a9e7</SubnetId>
<ZoneName>us-west-2a</ZoneName>
</member>
<member>
<SubnetId>subnet-b7d581c0</SubnetId>
<ZoneName>us-west-2b</ZoneName>
</member>
</AvailabilityZones>
<SecurityGroups>
<member>sg-5943793c</member>
</SecurityGroups>
<DNSName>my-load-balancer-424835706.us-west-2.elb.amazonaws.com</DNSName>
<State>
<Code>active</Code>
</State>
<Type>application</Type>
</member>
</LoadBalancers>
</DescribeLoadBalancersResult>
<ResponseMetadata>
<RequestId>6581c0ac-f39f-11e5-bb98-57195a6eb84a</RequestId>
</ResponseMetadata>
</DescribeLoadBalancersResponse>
EOF
Shindo.tests('AWS::ELBV2 | parsers | describe_load_balancers', %w[aws elb parser]) do
tests('parses the xml').formats(AWS::ELBV2::Formats::DESCRIBE_LOAD_BALANCERS) do
parser = Nokogiri::XML::SAX::Parser.new(Fog::Parsers::AWS::ELBV2::DescribeLoadBalancers.new)
parser.parse(DESCRIBE_LOAD_BALANCERS_RESULT)
parser.document.response
end
end

View file

@ -0,0 +1,39 @@
class AWS
module ELBV2
module Formats
BASIC = {
'ResponseMetadata' => {'RequestId' => String}
}
LOAD_BALANCER = {
"AvailabilityZones" => Array,
"LoadBalancerArn" => String,
"DNSName" => String,
"CreatedTime" => Time,
"LoadBalancerName" => String,
"VpcId" => String,
"CanonicalHostedZoneId" => String,
"Scheme" => String,
"Type" => String,
"State" => {"Code" => String},
"SecurityGroups" => [Fog::Nullable::String]
}
DESCRIBE_LOAD_BALANCERS = BASIC.merge({
'DescribeLoadBalancersResult' => {'LoadBalancers' => [LOAD_BALANCER], 'NextMarker' => Fog::Nullable::String}
})
LISTENER = {
"LoadBalancerArn" => String,
"Protocol" => String,
"Port" => String,
"ListenerArn" => String,
"DefaultActions" => [{"Type" => String, "TargetGroupArn" => String}]
}
DESCRIBE_LISTENERS = BASIC.merge({
'DescribeListenersResult' => {'Listeners' => [LISTENER], 'NextMarker' => Fog::Nullable::String}
})
end
end
end