1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
module Fog
module AWS
class ELB
class Real
require 'fog/aws/parsers/elb/describe_load_balancer_attributes'
# Describe the load balancer attributes
# http://docs.aws.amazon.com/ElasticLoadBalancing/latest/APIReference/API_DescribeLoadBalancerAttributes.html
# ==== Parameters
# * lb_name<~String> - The mnemonic name associated with the LoadBalancer.
#
# ==== Returns
# * response<~Excon::Response>:
# * body<~Hash>:
# * 'ResponseMetadata'<~Hash>:
# * 'RequestId'<~String> - Id of request
# * 'DescribeLoadBalancerAttributesResult'<~Hash>:
# * 'LoadBalancerAttributes'<~Hash>
# * 'ConnectionDraining'<~Hash>
# * 'Enabled'<~Boolean> - whether connection draining is enabled
# * 'Timeout'<~Integer> - max time (in seconds) to keep existing conns open before deregistering instances.
# * 'CrossZoneLoadBalancing'<~Hash>
# * 'Enabled'<~Boolean> - whether crosszone load balancing is enabled
# * 'ConnectionSettings'<~Hash>
# * 'IdleTimeout'<~Integer> - time (in seconds) the connection is allowed to be idle (no data has been sent over the connection) before it is closed by the load balancer.
def describe_load_balancer_attributes(lb_name)
request({
'Action' => 'DescribeLoadBalancerAttributes',
'LoadBalancerName' => lb_name,
:parser => Fog::Parsers::AWS::ELB::DescribeLoadBalancerAttributes.new
})
end
end
class Mock
def describe_load_balancer_attributes(lb_name = nil, names = [])
raise Fog::AWS::ELB::NotFound unless load_balancer = self.data[:load_balancers][lb_name]
attributes = load_balancer['LoadBalancerAttributes']
response = Excon::Response.new
response.status = 200
response.body = {
'ResponseMetadata' => {
'RequestId' => Fog::AWS::Mock.request_id
},
'DescribeLoadBalancerAttributesResult' => {
'LoadBalancerAttributes' => attributes
}
}
response
end
end
end
end
end
|