Монгоидное отслеживание в стиле Twitter, невозможно указать критерии/условия для массива отношений

Я в своем уме, пытаясь справиться с этими ошибками. По сути, я создал следующие шаблоны пользователей и отношений, используя Mongoid для обработки моей базы данных. Это похоже на точную копию примера внизу страницы здесь. Я пытаюсь вызвать любое из следующего:

user1.relationships.find(:all, :conditions => {:rel_user => user_in_question, :rel_type => "following" })
user1.relationships.all(:conditions => {:rel_user => user_in_question, :rel_type => "following" })
user1.relationships.where(:rel_type => "following")
user1.relationships.following #with a named scope

Все они, кажется, просто возвращают весь массив отношений; они не ищут по критериям. Метод find() также выдает ошибку о том, что он может принимать только 1 аргумент. im_following? метод всегда возвращает true.

Я не уверен, что лучше размещать код в строке или из сути, так что вот суть:

user.rb
user_follow_spec.rb
relationship.rb

Буду признателен за любую помощь.


person Rockmaninoff    schedule 21.06.2010    source источник


Ответы (3)


Рокманиофф, я тоже столкнулся с той же проблемой. Вы также можете просмотреть это. Mongoid планирует поддерживать эту функцию в своей версии-кандидате на выпуск. Пока нам приходится делать что-то вручную.

class User
  include Mongoid::Document
  include Mongoid::Timestamps

  references_many :fans, :stored_as => :array, :class_name => 'User', :inverse_of => :fan_of
  references_many :fan_of, :stored_as => :array, :class_name => 'User', :inverse_of => :fans

  def become_fan_of user
    fan_of << user
    self.save

    user.fans << self
    user.save
  end

  def is_a_fan? user
    fan_of_ids.include? user.id
  end

  def unfan user
    fan_of_ids.delete user.id
    self.save

    user.fan_ids.delete self.id
    user.save
  end

  ...
end 

В консоли вы можете сделать:

User.first.become_fan_of User.last
User.first.is_a_fan? User.last
User.first.unfan User.last

В вашем случае вы можете заменить «fan / fan_of» на «followers/following соответственно». Надеюсь это поможет.

person Christian Fazzini    schedule 29.11.2010

Я бы посоветовал вам упростить ваши отношения, используя самореферентные ассоциации. Посмотрите мой ответ на этот вопрос:

Практическое руководство. У пользователя есть поклонники

Я думаю, что это довольно близко к ассоциации, которую вы хотите:

class User
  include Mongoid::Document
  references_many :following, 
                  :class_name => 'User', 
                  :stored_as => :array, 
                  :inverse_of => :followed_by

  references_many :followed_by, 
                  :class_name => 'User', 
                  :stored_as => :array, 
                  :inverse_of => :following
end

# let's say we have users: al, ed, sports_star, movie_star    
sports_star.followed_by << al
movie_star.followed_by << al
sports_star.followed_by << ed
movie_star.followed_by << ed

movie_star.followed_by  # => al, ed
al.following            # => sports_star, movie_star
person bowsersenior    schedule 22.11.2010

Попробуй это:

class User

  # follows and followers
  references_many :follows, :stored_as => :array , :inverse_of => :followers ,:class_name=>"User"
  references_many :followers, :stored_as => :array , :inverse_of => :follows ,:class_name=>"User"


  def followers
    followers.map 
  end

end
person ming yeow    schedule 22.11.2010