Class: ApiResource::Finders::ResourceFinder
- Inherits:
-
AbstractFinder
- Object
- AbstractFinder
- ApiResource::Finders::ResourceFinder
- Defined in:
- lib/api_resource/finders/resource_finder.rb
Instance Attribute Summary
Attributes inherited from AbstractFinder
#condition, #found, #internal_object, #klass
Instance Method Summary collapse
-
#load ⇒ Object
this is a little bit simpler, it’s always a collection and does not require a remote path.
Methods inherited from AbstractFinder
#all, #initialize, #method_missing
Constructor Details
This class inherits a constructor from ApiResource::Finders::AbstractFinder
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class ApiResource::Finders::AbstractFinder
Instance Method Details
#load ⇒ Object
this is a little bit simpler, it’s always a collection and does not require a remote path
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 |
# File 'lib/api_resource/finders/resource_finder.rb', line 9 def load begin @loaded = true @internal_object = self.klass.connection.get(self.build_load_path) return [] if @internal_object.blank? if @internal_object.is_a?(Array) @internal_object = self.klass.instantiate_collection(@internal_object) else @internal_object = [self.klass.instantiate_record(@internal_object)] end id_hash = self.condition.included_objects.inject({}) do |accum, assoc| accum[assoc] = @internal_object.collect do |obj| obj.send(self.klass.association_foreign_key_field(assoc)) end accum[assoc].flatten! accum[assoc].uniq! accum end included_objects = self.load_includes(id_hash) self.apply_includes(@internal_object, included_objects) # looks hacky, but we want to return only a single # object in case of a find call. if @internal_object.count == 1 && self.build_load_path =~ /find/ @internal_object = @internal_object.first end return @internal_object rescue ApiResource::ResourceNotFound nil end @internal_object end |