Not doing so has a few gotchas when working with relations, particularly with records which are not stored in the database. I'm excluding the related content file because it's got a very peculiar relationship with itself: the `has_one :opposite_related_content` has no inverse; the relation itself is its inverse. It's a false positive since the inverse condition is true: ``` content.opposite_related_content.opposite_related_content.object_id == content.object_id ```
17 lines
386 B
Ruby
17 lines
386 B
Ruby
module Followable
|
|
extend ActiveSupport::Concern
|
|
|
|
included do
|
|
has_many :follows, as: :followable, inverse_of: :followable, dependent: :destroy
|
|
has_many :followers, through: :follows, source: :user
|
|
|
|
scope :followed_by_user, ->(user) {
|
|
joins(:follows).where("follows.user_id = ?", user.id)
|
|
}
|
|
end
|
|
|
|
def followed_by?(user)
|
|
followers.include?(user)
|
|
end
|
|
end
|