Frage

Ich habe eine viel zu viele Beziehung zwischen Benutzern und den von ihnen abonnierten Kanälen. Wenn ich jedoch meine Modellabhängigkeit zwischen Benutzer- und Benutzerkanälen oder -kanälen und Benutzerkanal betrachte, besteht stattdessen eine direkte Verbindung zwischen Benutzern und Kanälen. Wie bringe ich Benutzerkanäle zwischen zwei? Benutzermodell

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

Kanalmodell

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 -Modell

class UsersChannels < ActiveRecord::Base
end
War es hilfreich?

Lösung

Siehe das Has_Many: Durch Dokumentation Auf den Rails Guides, die Sie durch die Konfiguration a leitet has_many Beziehung zu einem intervenierenden Modell.

Andere Tipps

Die HABTM -Beziehung generiert die UserSchannels automatisch - wenn Sie zum Beispiel auf das Modell für die Link -Tabelle zugreifen möchten (fügen Sie ihm einige weitere Attribute hinzu - time_channel_watched oder was auch immer), müssen Sie die Modelle ändern (und explizit definieren und migrieren Ein UserSchannel -Modell mit der Attribute -ID: primär_key, user_id: Integer, Channel_ID: Integer) zu:

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

Hinweis: Da Sie Ihr eigenes Linkmodell definieren, müssen Sie nicht beim HABTM -definierten Tabellennamen von UserSchannels bleiben - Sie können den Modellnamen in so etwas wie "Uhren" ändern. All das ist so ziemlich im Rails Guide, der erwähnt wurde.

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top