由另一个协会过滤协会

时间:2013-08-29 19:34:50

标签: ruby-on-rails ruby

我有一个包含状态的友谊模型。

class Friendship < ActiveRecord::Base
  attr_accessible :friend_id, :user_id, :source_id

  after_create :check_friend_status

  # Relationships
  belongs_to :user, :touch => true
  belongs_to :friend, :class_name => "User", :touch => true
  belongs_to :source

  has_one :status, :class_name => "FriendStatusDescriptor", :foreign_key => 'friendship_id'


  validates_uniqueness_of :user_id, :scope => [:friend_id, :source_id]


  def check_friend_status
    # Check user/friend for existing friend status
    if FriendStatusDescriptor.find(:first, :conditions => ["friendship_id = ?", self.id]).nil?
        status = FriendStatusDescriptor.new
        status.friendship_id = self.id
        status.save
    end
  end
end

class FriendStatusDescriptor < ActiveRecord::Base
  attr_accessible :alert, :friendship_id, :hide

  belongs_to :friendship

  validates_uniqueness_of :friendship_id

end

状态模型有一个名为hide的布尔变量。我希望能够通过hide设置为false来过滤用户的友谊。这些方面的东西。

      #  In User Model
  # Friendships
  has_many :friendships do
    def visible
         #  Where !friendship.status.hide
    end
  end

所以在我的控制器中我可以这样做

 user.friendships.visible

我不知道如何使用此方法访问个人友谊。

1 个答案:

答案 0 :(得分:0)

我想你想要:

class User
  has_many :friendships,
    :class_name => "FriendStatusDescriptor",
    :foreign_key => 'friendship_id'

如果您想通过separete过滤可见和不可见的友谊,可以将范围添加到友谊模型中:

class Friendship
  scope :visible, -> { joins(:status).where("friend_status_descriptors.hide = ?", false) }

然后应用该范围:

user.friendships.visible