Вопрос

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

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

UsersChannel Model.

class UsersChannels < ActiveRecord::Base
end
Это было полезно?

Решение

Увидеть has_many: через документацию на направляющих рельсов, которые направляют вас через настройку has_many Отношения с промежуточной моделью.

Другие советы

Отношения HABTM создают Auto Magicially UsersChannels, если вы хотите получить доступ к модели для таблицы ссылок (добавьте еще несколько атрибутов, например - time_channel_watched или что-то еще), вам придется изменить модели (и явно определить и мигрировать Модель пользователей с атрибутами 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 - вы можете изменить название модели к чему-то вроде «часов». Все вышеперечисленное в значительной степени в руководстве рельсов, которое было упомянуто.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top