Module: ContentfulModel::Associations::HasOne::ClassMethods
- Defined in:
- lib/contentful_model/associations/has_one.rb
Overview
Class method
Instance Method Summary collapse
-
#has_one(association_name, options = {}) ⇒ Object
has_one defines a method on the parent which wraps around the superclass’s implementation.
Instance Method Details
#has_one(association_name, options = {}) ⇒ Object
has_one defines a method on the parent which wraps around the superclass’s implementation. In most cases this will end up at ContentfulModel::Base#method_missing and look at the fields on a content object. We wrap around it like this so we can specify a class_name option to call a different method from the association name.
class Foo
has_one :special_bar, class_name: "Bar"
end
rubocop:disable Style/PredicateName
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
# File 'lib/contentful_model/associations/has_one.rb', line 23 def has_one(association_name, = {}) = { class_name: association_name.to_s.classify, inverse_of: to_s.underscore.to_sym } = .merge() include_discovered([:class_name]) # Define a method which matches the association name define_method association_name do begin # Start by calling the association name as a method on the superclass. # this will end up in ContentfulModel::Base#method_missing and return the value from Contentful. # We set the singular of the association name on this object to allow easy recursing. super().tap do |child| child.send(:"#{[:inverse_of]}=", self) if child.respond_to?(:"#{[:inverse_of]}=") end rescue NoMethodError # If method_missing returns an error, the field doesn't exist. If a class is specified, try that. possible_field_name = [:class_name].underscore.to_sym return send(possible_field_name) if possible_field_name != association_name && respond_to?(possible_field_name) nil end end end |