У меня небольшая проблема со следующими моделями (на Rails 3.2rc1). Собственность отображает проекты и блоги для пользователей (владельцев) и существуют различные типы блогов, которые обрабатывают собственность по-разному.has_many: через отношение с одной полиморфной и подклассовой ногами неправильно
class User < ActiveRecord::Base
has_many :ownerships, dependent: :destroy
has_many :projects, through: :ownerships, source: :ownable, :source_type => 'Project'
has_many :site_blogs, through: :ownerships, source: :ownable, :source_type => 'SiteBlog'
end
class Ownership < ActiveRecord::Base
belongs_to :ownable, polymorphic: true
belongs_to :owner, :class_name => 'User', foreign_key: 'user_id'
end
class Project < ActiveRecord::Base
has_many :owners, through: :ownerships, as: :ownable
has_many :ownerships, as: :ownable, dependent: :destroy
end
class Blog < ActiveRecord::Base
end
class SiteBlog < Blog
has_many :owners, through: :ownerships, as: :ownable
has_many :ownerships, as: :ownable, dependent: :destroy
end
class ProjectBlog < Blog
belongs_to :project
end
Это все прекрасно работает до сих пор, но SiteBlog#owners
: плохо ведет себя
SiteBlog.first.owners
SiteBlog Load (0.8ms) SELECT "blogs".* FROM "blogs" WHERE "blogs"."type" IN ('SiteBlog') LIMIT 1
User Load (1.4ms) SELECT "users".* FROM "users" INNER JOIN "ownerships" ON "users"."id" = "ownerships"."user_id" WHERE "ownerships"."ownable_id" = 231145885 AND "ownerships"."ownable_type" = 'Blog'
=> []
Проблема в том, в самом конце генерируемой SELECT: "ownable_type" = 'Blog'
. Для этого это должно быть "ownable_type" = 'SiteBlog'
, однако я не понимаю, как научить AREL сделать это.
Любые идеи?
Это просто немного смущает :-) Это действительно работает, опечатка вызвала проблему в моем пробном приложении. Время писать спецификации для этого. – svoop