# File lib/apipie_bindings/resource.rb, line 7 def initialize(name, api) raise NameError.new("Resource '#{name}' does not exist in the API") unless api.apidoc[:docs][:resources].key?(name) @name = name @api = api end
@param name [Symbol] action name @return [ApipieBindings::Action]
# File lib/apipie_bindings/resource.rb, line 50 def action(name) ApipieBindings::Action.new(@name, name, @api) end
Get list of all actions for a resource
@return [Array<ApipieBindings::Action>]
# File lib/apipie_bindings/resource.rb, line 34 def actions apidoc[:methods].map { |a| action(a[:name].to_sym) } end
Get API documentation for a resource
@return [Hash]
# File lib/apipie_bindings/resource.rb, line 27 def apidoc @api.apidoc[:docs][:resources][@name] end
Execute an action on a resource
@param action [Symbol] @param params [Hash] @param headers [Hash] @param options [Hash] @return [Hash]
# File lib/apipie_bindings/resource.rb, line 20 def call(action, params={}, headers={}, options={}) @api.call(@name, action, params, headers, options) end
Determine if resource has a particular action
@param name [Symbol] name of action to check @return [Bool]
# File lib/apipie_bindings/resource.rb, line 42 def has_action?(name) apidoc[:methods].any? { |action| action[:name].to_sym == name } end
Get string representation
@return [String] ApipieBindings::Resource as a string @note same as #to_s method
# File lib/apipie_bindings/resource.rb, line 72 def inspect to_s end
Get simiple string representation
@return [String] ApipieBindings::Resource as a string
# File lib/apipie_bindings/resource.rb, line 57 def singular_name ApipieBindings::Inflector.singularize(@name.to_s) end
Get string representation
@return [String] ApipieBindings::Resource as a string
# File lib/apipie_bindings/resource.rb, line 64 def to_s "<Resource :#{@name}>" end