class ActiveFedora::Associations::Builder::CollectionAssociation

:nodoc:

def self.define_callback(model, callback_name, name, options)

def self.define_callback(model, callback_name, name, options)
  full_callback_name = "#{callback_name}_for_#{name}"
  # TODO : why do i need method_defined? I think its because of the inheritance chain
  # See https://github.com/samvera/active_fedora/issues/1333
  model.class_attribute full_callback_name.to_sym unless model.method_defined?(full_callback_name)
  callbacks = Array(options[callback_name.to_sym]).map do |callback|
    case callback
    when Symbol
      ->(_method, owner, record) { owner.send(callback, record) }
    when Proc
      ->(_method, owner, record) { callback.call(owner, record) }
    else
      ->(method, owner, record) { callback.send(method, owner, record) }
    end
  end
  model.send("#{full_callback_name}=", callbacks)
end

def self.define_callbacks(model, reflection)

def self.define_callbacks(model, reflection)
  super
  name = reflection.name
  options = reflection.options
  CALLBACKS.each { |callback_name| define_callback(model, callback_name, name, options) }
end

def self.define_extensions(model, name)

def self.define_extensions(model, name)
  return unless block_given?
  extension_module_name = "#{model.name.demodulize}#{name.to_s.camelize}AssociationExtension"
  extension = Module.new(&Proc.new)
  model.parent.const_set(extension_module_name, extension)
end

def self.valid_options(options)

def self.valid_options(options)
  super + CALLBACKS
end

def self.wrap_scope(scope, mod)

def self.wrap_scope(scope, mod)
  if scope
    if scope.arity.positive?
      proc { |owner| instance_exec(owner, &scope).extending(mod) }
    else
      proc { instance_exec(&scope).extending(mod) }
    end
  else
    proc { extending(mod) }
  end
end