These are methods that belong to the API object but are callable from the client for convenience.
# File lib/rhc/rest/client.rb, line 17 def add_domain(id) debug "Adding domain #{id}" @domains = nil api.rest_method "ADD_DOMAIN", :id => id end
# File lib/rhc/rest/client.rb, line 136 def add_key(name, key, content) debug "Adding key #{key} for #{user.login}" user.add_key name, key, content end
# File lib/rhc/rest/client.rb, line 37 def applications(options={}) if link = api.link_href(:LIST_APPLICATIONS) api.rest_method :LIST_APPLICATIONS, options else self.domains.map{ |d| d.applications(options) }.flatten end end
# File lib/rhc/rest/client.rb, line 45 def cartridges debug "Getting all cartridges" @cartridges ||= api.rest_method("LIST_CARTRIDGES", nil, :lazy_auth => true) end
# File lib/rhc/rest/client.rb, line 141 def delete_key(name) debug "Deleting key '#{name}'" key = find_key(name) key.destroy end
# File lib/rhc/rest/client.rb, line 23 def domains debug "Getting all domains" @domains ||= api.rest_method "LIST_DOMAINS" end
# File lib/rhc/rest/client.rb, line 68 def find_application(domain, application, options={}) response = request({ :url => link_show_application_by_domain_name(domain, application), :method => "GET", :payload => options }) end
# File lib/rhc/rest/client.rb, line 84 def find_application_aliases(domain, application, options={}) response = request({ :url => link_show_application_by_domain_name(domain, application, "aliases"), :method => "GET", :payload => options }) end
# File lib/rhc/rest/client.rb, line 76 def find_application_gear_groups(domain, application, options={}) response = request({ :url => link_show_application_by_domain_name(domain, application, "gear_groups"), :method => "GET", :payload => options }) end
Find Cartridge by name or regex
# File lib/rhc/rest/client.rb, line 106 def find_cartridges(name) debug "Finding cartridge #{name}" if name.is_a?(Hash) regex = name[:regex] type = name[:type] name = name[:name] end filtered = Array.new cartridges.each do |cart| if regex filtered.push(cart) if cart.name.match(regex) and (type.nil? or cart.type == type) else filtered.push(cart) if (name.nil? or cart.name == name) and (type.nil? or cart.type == type) end end return filtered end
Find Domain by namesapce
# File lib/rhc/rest/client.rb, line 56 def find_domain(id) debug "Finding domain #{id}" if link = api.link_href(:SHOW_DOMAIN, ':name' => id) request({ :url => link, :method => "GET", }) else domains.find{ |d| d.id.downcase == id.downcase } end or raise DomainNotFoundException.new("Domain #{id} not found") end
find Key by name
# File lib/rhc/rest/client.rb, line 126 def find_key(name) debug "Finding key #{name}" user.find_key(name) or raise RHC::KeyNotFoundException.new("Key #{name} does not exist") end
# File lib/rhc/rest/client.rb, line 92 def link_show_application_by_domain_name(domain, application, *args) [ api.links['LIST_DOMAINS']['href'], domain, "applications", application, ].concat(args).map{ |s| URI.escape(s) }.join("/") end
# File lib/rhc/rest/client.rb, line 101 def link_show_domain_by_name(domain, *args) api.link_href(:SHOW_DOMAIN, ':id' => domain) end
Returns nil if creating sessions is not supported, raises on error, otherwise returns an Authorization object.
# File lib/rhc/rest/client.rb, line 160 def new_session(options={}) if supports_sessions? api.rest_method('ADD_AUTHORIZATION', { :scope => 'session', :note => "RHC/#{RHC::VERSION::STRING} (from #{Socket.gethostname rescue 'unknown'} on #{RUBY_PLATFORM})", :reuse => true }, options) end end
# File lib/rhc/rest/client.rb, line 28 def owned_domains debug "Getting owned domains" if link = api.link_href(:LIST_DOMAINS_BY_OWNER) @owned_domains ||= api.rest_method 'LIST_DOMAINS_BY_OWNER', :owner => '@self' else domains end end
# File lib/rhc/rest/client.rb, line 131 def sshkeys debug "Finding all keys for #{user.login}" user.keys end
# File lib/rhc/rest/client.rb, line 147 def supports_sessions? api.supports? 'ADD_AUTHORIZATION' end
# File lib/rhc/rest/client.rb, line 50 def user debug "Getting user info" @user ||= api.rest_method "GET_USER" end