States
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 32 def initialize(attributes) #HACK - Since we are hacking how sub-collections work, we have to make sure the service is valid first. # Old 'connection' is renamed as service and should be used instead @service = attributes[:service] || attributes[:connection] super end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 39 def access_rules unless @access_rules @access_rules = Fog::Rackspace::LoadBalancers::AccessRules.new({ :service => service, :load_balancer => self}) # prevents loading access rules from non-existent load balancers @access_rules.clear unless persisted? end @access_rules end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 51 def access_rules=(new_access_rules=[]) access_rules.load(new_access_rules) end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 161 def connection_throttling requires :identity throttle = service.get_connection_throttling(identity).body['connectionThrottle'] throttle.count == 0 ? nil : throttle end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 126 def content_caching requires :identity service.get_content_caching(identity).body['contentCaching']['enabled'] end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 197 def destroy requires :identity service.delete_load_balancer(identity) true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 137 def disable_connection_logging requires :identity service.set_connection_logging identity, false attributes[:connection_logging] = false end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 173 def disable_connection_throttling requires :identity service.remove_connection_throttling(identity) true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 120 def disable_content_caching requires :identity service.set_content_caching identity, false true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 155 def disable_health_monitor requires :identity service.remove_monitor(identity) true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 191 def disable_session_persistence requires :identity service.remove_session_persistence(identity) true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 95 def disable_ssl_termination requires :identity service.remove_ssl_termination(identity) end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 131 def enable_connection_logging requires :identity service.set_connection_logging identity, true attributes[:connection_logging] = true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 167 def enable_connection_throttling(max_connections, min_connections, max_connection_rate, rate_interval) requires :identity service.set_connection_throttling(identity, max_connections, min_connections, max_connection_rate, rate_interval) true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 114 def enable_content_caching requires :identity service.set_content_caching identity, true true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 149 def enable_health_monitor(type, delay, timeout, attempsBeforeDeactivation, options = {}) requires :identity service.set_monitor(identity, type, delay, timeout, attempsBeforeDeactivation, options) true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 185 def enable_session_persistence(type) requires :identity service.set_session_persistence(identity, type) true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 90 def enable_ssl_termination(securePort, privatekey, certificate, options = {}) requires :identity service.set_ssl_termination(identity, securePort, privatekey, certificate, options) end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 226 def error_page requires :identity service.get_error_page(identity).body['errorpage']['content'] end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 231 def error_page=(content) requires :identity service.set_error_page identity, content end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 143 def health_monitor requires :identity monitor = service.get_monitor(identity).body['healthMonitor'] monitor.count == 0 ? nil : monitor end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 71 def https_redirect if @https_redirect.nil? requires :identity @https_redirect = begin service.get_load_balancer(identity).body['loadBalancer']['httpsRedirect'] rescue => e nil end end @https_redirect end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 55 def nodes if @nodes.nil? @nodes = Fog::Rackspace::LoadBalancers::Nodes.new({ :service => service, :load_balancer => self}) # prevents loading nodes from non-existent load balancers @nodes.clear unless persisted? end @nodes end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 67 def nodes=(new_nodes=[]) nodes.load(new_nodes) end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 203 def ready? state == ACTIVE end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 236 def reset_error_page requires :identity service.remove_error_page identity end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 207 def save if persisted? update else create end true end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 179 def session_persistence requires :identity persistence = service.get_session_persistence(identity).body['sessionPersistence'] persistence.count == 0 ? nil : persistence end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 83 def ssl_termination requires :identity ssl_termination = service.get_ssl_termination(identity).body['sslTermination'] rescue Fog::Rackspace::LoadBalancers::NotFound nil end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 221 def stats requires :identity service.get_stats(identity).body end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 216 def usage(options = {}) requires :identity service.get_load_balancer_usage(identity, options).body end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 100 def virtual_ips if @virtual_ips.nil? @virtual_ips = Fog::Rackspace::LoadBalancers::VirtualIps.new({ :service => service, :load_balancer => self}) @virtual_ips.clear unless persisted? end @virtual_ips end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 110 def virtual_ips=(new_virtual_ips=[]) virtual_ips.load(new_virtual_ips) end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 271 def connection_logging=(new_value) if !new_value.nil? and new_value.is_a?(Hash) attributes[:connection_logging] = case new_value['enabled'] when true,'true' true when false,'false' false end else attributes[:connection_logging] = new_value end end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 243 def create requires :name, :protocol, :virtual_ips options = {} options[:algorithm] = algorithm if algorithm options[:timeout] = timeout if timeout data = service.create_load_balancer(name, protocol, port, virtual_ips, nodes, options) merge_attributes(data.body['loadBalancer']) end
# File lib/fog/rackspace/models/load_balancers/load_balancer.rb, line 254 def update requires :name, :protocol, :port, :algorithm, :timeout, :https_redirect options = { :name => name, :algorithm => algorithm, :protocol => protocol, :port => port, :timeout => timeout, :https_redirect => !!https_redirect } service.update_load_balancer(identity, options) # TODO - Should this bubble down to nodes? Without tracking changes this would be very inefficient. # For now, individual nodes will have to be saved individually after saving an LB end