получить список объектов с ролями, примененными в be9 acl9 - PullRequest
1 голос
/ 27 ноября 2009

Я думаю примерно так:

def self.obj_list(opts = {:include => [] , :exclude => []})
    # Returns an array with all objects with roles applied
    # +:exclude+:: (array,string) optional object type to exclude from list
    # +:include+:: (array,string) optional object type to include in list
    # Example:
    #   Role.obj_list(:include => ["Device", "User"])
    #   Role.obj_list(:exclude => ["User"])

    inc = opts[:include].to_a
    exc = opts[:exclude].to_a

    objs = []
    if inc.empty?

      self.all.each do |r|
        unless r.authorizable_type.nil?
          objs << r.authorizable_type.constantize.find(r.authorizable_id) unless exc.include?(r.authorizable_type)
        end
      end

    else

      self.all.each do |r|
        unless r.authorizable_type.nil?
          objs << r.authorizable_type.constantize.find(r.authorizable_id) if inc.include?(r.authorizable_type)
        end
      end

    end
    objs
  end

Ответы [ 2 ]

0 голосов
/ 23 января 2015

Вы можете использовать предложения where для включения / исключения в SQL:

( inc.empty?
? where.not( :authorizable_type => exc )
: where( :authorizable_type => inc )
).map(&:authorizable)

Используя authorizable, вы получите собственную обработку Rails полиморфных ассоциаций, которая обеспечит возврат только реальных объектов, поэтому нет необходимости проверять nil

0 голосов
/ 23 июня 2010

Не знаю, может быть, вы хотите связать объект и тему? Если это так, вот учебник для этого: http://wiki.github.com/be9/acl9/tutorial-linking-object-and-subject-with-hmt

...