require 'fog/rackspace' module Fog module Rackspace class LoadBalancers < Fog::Service #These references exist for backwards compatibility class ServiceError < Fog::Rackspace::Errors::ServiceError; end class InternalServerError < Fog::Rackspace::Errors::InternalServerError; end class BadRequest < Fog::Rackspace::Errors::BadRequest; end DFW_ENDPOINT = 'https://dfw.loadbalancers.api.rackspacecloud.com/v1.0/' ORD_ENDPOINT = 'https://ord.loadbalancers.api.rackspacecloud.com/v1.0/' LON_ENDPOINT = 'https://lon.loadbalancers.api.rackspacecloud.com/v1.0/' requires :rackspace_api_key, :rackspace_username recognizes :rackspace_auth_url recognizes :rackspace_auth_token recognizes :rackspace_lb_endpoint model_path 'fog/rackspace/models/load_balancers' collection :load_balancers model :load_balancer collection :nodes model :node collection :virtual_ips model :virtual_ip collection :access_rules model :access_rule request_path 'fog/rackspace/requests/load_balancers' request :get_ssl_termination request :set_ssl_termination request :remove_ssl_termination request :create_load_balancer request :get_load_balancer request :list_load_balancers request :update_load_balancer request :delete_load_balancer request :create_node request :list_nodes request :get_node request :update_node request :delete_node request :delete_nodes request :create_virtual_ip request :list_virtual_ips request :delete_virtual_ip request :list_protocols request :list_algorithms request :get_connection_logging request :set_connection_logging request :get_content_caching request :set_content_caching request :create_access_rule request :list_access_rules request :delete_access_rule request :delete_all_access_rules request :get_session_persistence request :set_session_persistence request :remove_session_persistence request :get_connection_throttling request :remove_connection_throttling request :set_connection_throttling request :get_monitor request :set_monitor request :remove_monitor request :get_usage request :get_load_balancer_usage request :get_error_page request :set_error_page request :remove_error_page module Shared def algorithms list_algorithms.body['algorithms'].collect { |i| i['name'] } end def protocols list_protocols.body['protocols'] end def usage(options = {}) get_usage(options).body end end class Mock include Shared def initialize(options={}) @rackspace_api_key = options[:rackspace_api_key] @rackspace_username = options[:rackspace_username] @rackspace_auth_url = options[:rackspace_auth_url] end end class Real include Shared def initialize(options={}) @rackspace_api_key = options[:rackspace_api_key] @rackspace_username = options[:rackspace_username] @rackspace_auth_url = options[:rackspace_auth_url] @rackspace_must_reauthenticate = false @connection_options = options[:connection_options] || {} uri = URI.parse(options[:rackspace_lb_endpoint] || DFW_ENDPOINT) @host = uri.host @persistent = options[:persistent] || false @path = uri.path.end_with?('/') ? uri.path.chop : uri.path @port = uri.port @scheme = uri.scheme authenticate @connection = Fog::Connection.new(uri.to_s, @persistent, @connection_options) end def request(params) #TODO - Unify code with other rackspace services begin response = @connection.request(params.merge!({ :headers => { 'Content-Type' => 'application/json', 'X-Auth-Token' => @auth_token }.merge!(params[:headers] || {}), :host => @host, :path => "#{@path}/#{params[:path]}" })) rescue Excon::Errors::NotFound => error raise NotFound.slurp error rescue Excon::Errors::BadRequest => error raise BadRequest.slurp error rescue Excon::Errors::InternalServerError => error raise InternalServerError.slurp error rescue Excon::Errors::HTTPStatusError => error raise ServiceError.slurp error end unless response.body.empty? response.body = Fog::JSON.decode(response.body) end response end def authenticate options = { :rackspace_api_key => @rackspace_api_key, :rackspace_username => @rackspace_username, :rackspace_auth_url => @rackspace_auth_url } credentials = Fog::Rackspace.authenticate(options, @connection_options) @auth_token = credentials['X-Auth-Token'] account_id = credentials['X-Server-Management-Url'].match(/.*\/([\d]+)$/)[1] @path = "#{@path}/#{account_id}" end end end end end