class ActiveFedora::Associations::HasManyAssociation
:nodoc:
def count_records
If the collection is empty the target is set to an empty array and
account and delegates to +count_records+ if needed.
or not. The +size+ method is the one that takes the loaded flag into
That does not depend on whether the collection has already been loaded
Returns the number of records in this collection.
def count_records count = if loaded? @target.size else @reflection.klass.count(:conditions => @counter_query) end # If there's nothing in the database and @target has no new records # we are certain the current target is an empty array. This is a # documented side-effect of the method that may avoid an extra SELECT. @target ||= [] and loaded! if count == 0 return count end
def delete_records(records, method)
def delete_records(records, method) if method == :destroy records.each { |r| r.destroy } else # Find all the records that point to this and nullify them # keys = records.map { |r| r[reflection.association_primary_key] } # scope = scoped.where(reflection.association_primary_key => keys) if method == :delete_all raise "Not Implemented" #update_counter(-scope.delete_all) else if reflection.inverse_of # Can't get an inverse when class_name: 'ActiveFedora::Base' is supplied inverse = reflection.inverse_of records.each do |record| if record.persisted? if inverse.collection? # Remove from a has_and_belongs_to_many record.association(inverse.name).delete(@owner) elsif inverse.klass == ActiveFedora::Base record[inverse.foreign_key] = nil else # Remove from a belongs_to record[reflection.foreign_key] = nil end # Check to see if the object still exists (may be already deleted). # In Rails, they do this with an update_all to avoid callbacks and validations, we may need the same. record.save! if record.class.exists?(record.id) end end end #update_counter(-scope.update_all(reflection.foreign_key => nil)) end end end
def find_polymorphic_inverse(record)
def find_polymorphic_inverse(record) record.reflections.values.find{ |r| !r.has_many? && r.options[:property] == reflection.options[:property]} end
def initialize(owner, reflection)
def initialize(owner, reflection) super end
def insert_record(record, validate = true, raise = false)
def insert_record(record, validate = true, raise = false) set_owner_attributes(record) set_inverse_instance(record) if raise record.save!(validate: validate) else record.save(validate: validate) end end
def set_owner_attributes(record)
def set_owner_attributes(record) if klass == ActiveFedora::Base inverse = find_polymorphic_inverse(record) if inverse.belongs_to? record[inverse.foreign_key] = owner.id else # HABTM record[inverse.foreign_key] ||= [] #TODO use primary_key instead of `owner.id` record[inverse.foreign_key] += [owner.id] end elsif owner.persisted? inverse = reflection.inverse_of if inverse && inverse.collection? record[inverse.foreign_key] ||= [] #TODO use primary_key instead of `owner.id` record[inverse.foreign_key] += [owner.id] elsif inverse && inverse.klass == ActiveFedora::Base record[inverse.foreign_key] = owner.id else #TODO use primary_key instead of `owner.id` record[reflection.foreign_key] = owner.id end end end