Отношение много ко многим, рельсы - PullRequest
0 голосов
/ 02 декабря 2010

У меня есть отношение многие ко многим между пользователями и каналами, на которые они подписываются. Но когда я смотрю на мою модель зависимости между пользовательскими и пользовательскими каналами или каналами и пользовательским каналом, вместо этого возникает прямая связь между пользователями и каналами. Как я могу поставить каналы пользователей между двумя? Модель пользователя

class User < ActiveRecord::Base

  acts_as_authentic

  ROLES = %w[admin  moderator subscriber]

  has_and_belongs_to_many :channels
  has_many :channel_mods
  named_scope :with_role, lambda { |role| {:conditions => "roles_mask & #{2**ROLES.index(role.to_s)} > 0 "} }
  def roles  
    ROLES.reject { |r| ((roles_mask || 0) & 2**ROLES.index(r)).zero? }  
  end

  def roles=(roles)  
    self.roles_mask = (roles & ROLES).map { |r| 2**ROLES.index(r) }.sum  
  end

  def role_symbols
    role.map do |role|
      role.name.underscore.to_sym
    end
  end





end

Модель канала

class Channel < ActiveRecord::Base
  acts_as_taggable
  acts_as_taggable_on :tags
  has_many :messages
  has_many :channel_mods
  has_and_belongs_to_many :users

end

Модель UserChannel

class UsersChannels < ActiveRecord::Base
end

Ответы [ 2 ]

2 голосов
/ 02 декабря 2010

См. has_many: в документации в руководствах по Rails, которые помогут вам настроить отношение has_many с промежуточной моделью.

1 голос
/ 03 декабря 2010

Отношение HABTM автоматически генерирует UsersChannels - если вы хотите получить доступ к модели для таблицы ссылок (добавьте к ней еще несколько атрибутов, например, time_channel_watched или что-то еще), вам придется изменить модели (и явноопределить и перенести модель UsersChannel с атрибутами id: primary_key, user_id: integer, channel_id: integer) в:

class Channel < ActiveRecord::Base 

  has_many :users_channels, :dependent => :destroy
  has_many :users, :through => :users_channels  

end 


class User < ActiveRecord::Base 

  has_many :users_channels, :dependent => :destroy
  has_many :channels, :through => :users_channels 

end

class UsersChannels < ActiveRecord::Base
  belongs_to :user
  belongs_to :channel

end

Примечание: поскольку вы определяете свою собственную модель связи, у вас нетчтобы остаться с HABTM-именем таблицы UsersChannels - вы можете изменить название модели на что-то вроде «Watches».Все вышеперечисленное в значительной степени упомянуто в руководстве по Rails.

...