ActiveRecord :: HasManyThroughAssociationNotFoundError проблема, с поворотом - PullRequest
0 голосов
/ 20 июня 2011

У меня есть следующие три модели

LegacyRole:

class LegacyRole < LegacyModel
  has_many :permissions_roles
  has_many :permissions, :through => :permissions_roles
end

LegacyPermissionsRole:

class LegacyPermissionsRole < LegacyModel
  belongs_to :role
  belongs_to :permission
end

и LegacyPermission:

class LegacyPermission < LegacyModel
  has_many :permissions_roles
  has_many :roles, :through => :permissions_roles
end

И чтобы все это работало и связывало устаревшую базу данных и еще много чего, у меня есть следующий класс LegacyModel, который, возможно, пытается быть слишком умным ...

require 'active_record'

class LegacyModel < ActiveRecord::Base
  self.abstract_class = true

  establish_connection "legacy_#{::Rails.env}"

  def self.inherited(subclass)
    tabeleized_name = subclass.name.tableize
    raise "Legacy models must be prefixed with 'Legacy'" unless tabeleized_name.start_with?('legacy_')

    logger.info "***********LOAD***********"
    logger.info "Loaded legacy model: #{subclass.name} using table: #{tabeleized_name.gsub('legacy_', '')}"
    super
    subclass.set_table_name tabeleized_name.gsub('legacy_','')
  end


  # these methods do much the same thing, can probably abstract some of this out
  def self.belongs_to(association_id, options = {})
    new_association = association_id.to_s.insert(0, 'legacy_').to_sym
    old_association = association_id


    logger.info "Legacy model has belongs_to association: '#{association_id}'"
    association_id = association_id.to_s.insert(0, 'legacy_').to_sym
    logger.info "Converting association to: '#{association_id}'"

    unless options.has_key?(:foreign_key)  
      # our foreign_key is missing
      options[:foreign_key] = old_association.to_s.foreign_key
      logger.info("Foreign_key was missing, is now: #{options[:foreign_key]}")
    end

    super
    alias_method old_association, new_association
  end

  def self.has_many(association_id, options = {})
    new_association = association_id.to_s.insert(0, 'legacy_').to_sym
    old_association = association_id


    logger.info "Legacy model has_many to association: '#{association_id}'"
    association_id = association_id.to_s.insert(0, 'legacy_').to_sym
    logger.info "Converting association to: '#{association_id}'"
    logger.debug("Association options are: #{options.inspect}")

    if options.has_key?(:through)
      options[:through] = options[:through].to_s.insert(0, 'legacy_')
      logger.info("Through mutated, is now: #{options[:through]}")
    end

    super
    alias_method old_association, new_association
  end

end

Всякий раз, когда я пытаюсь получить доступ к разрешениям на экземпляре LegacyRole, я получаю следующую ошибку Active Record: ActiveRecord :: HasManyThroughAssociationNotFoundError: Не удалось найти ассоциацию "legacy_permissions_roles" в модели LegacyRole

Я прошел через все это как мог, и я действительно не могу понять, почему это происходит, очевидно, из-за того, что класс LegacyModel немного сложнее стандартного, я действительно не знаю, как диагностировать это далее ... Теперь я нахожусь в точке, где я не вижу леса за деревьями и чувствую, что это может быть что-то действительно простое, что я упустил!

Edit:

Здесь выводится лог загрузки моделей

****************************
Loaded legacy model: LegacyPermission using table: permissions
Legacy model has_many association: 'permissions_roles'
Converting association to: 'legacy_permissions_roles'
Association options are: {}
Legacy model has_many association: 'roles'
Converting association to: 'legacy_roles'
Association options are: {:through=>:permissions_roles}
Changed :through to: 'legacy_permissions_roles'

****************************
Loaded legacy model: LegacyPermissionsRole using table: permissions_roles
Legacy model has belongs_to association: 'role'
Converting association to: 'legacy_role'
Legacy model has belongs_to association: 'permission'
Converting association to: 'legacy_permission'
Foreign_key was missing, is now: 'permission_id'

****************************
Loaded legacy model: LegacyRole using table: roles
Legacy model has_many association: 'permissions_roles'
Converting association to: 'legacy_permissions_roles'
Association options are: {}
Legacy model has_many association: 'permissions'
Converting association to: 'legacy_permissions'
Association options are: {:through=>:permissions_roles}
Changed :through to: 'legacy_permissions_roles'

1 Ответ

0 голосов
/ 20 июня 2011

Возможно, вы хотите

class LegacyRole < LegacyModel
  has_many :permissions_roles
  has_many :permissions, :through => :legacy_permissions_roles # note the `legacy` prefix
end

Или это была опечатка в вашем посте?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...