Sha256: 1da8e4739ca5638d5eaa7f488e912510cd4b00422df696b636fbc2a929e02d6f
Contents?: true
Size: 1.76 KB
Versions: 1
Compression:
Stored size: 1.76 KB
Contents
require 'i_am_i_can/permission/p_array' module IAmICan module Permission def matched?(pms_name = nil, pred: nil, obj: nil, **options) PArray.new(options[:in]).matched?(pms_name || naming(pred, obj)) end def which(pred:, obj: nil, **conditions) find_by!(pred: pred, **deconstruct_obj(obj), **conditions) end def naming(pred, obj) obj_type, obj_id = deconstruct_obj(obj).values otp = "_#{obj_type}" if obj_type.present? oid = "_#{obj_id}" if obj_id.present? [pred, otp, oid].join.to_sym end def deconstruct_obj(obj) return { } unless obj if obj.is_a?(String) || obj.is_a?(Symbol) { obj_type: obj } elsif obj.respond_to?(:attributes) { obj_type: obj.class.name, obj_id: obj.id } else { obj_type: obj.to_s, obj_id: nil } end end def exists?(pred, obj) super(pred: pred, **deconstruct_obj(obj)) end def self.extended(kls) kls.include InstanceMethods end end # === End of ClassMethods === module Permission::InstanceMethods # like: manage_User_1 def name otp = "_#{obj_type}" if obj_type.present? oid = "_#{obj_id}" if obj_id.present? [pred, otp, oid].join.to_sym end def assign_to role: nil, group: nil obj = if role role.is_a?(Symbol) ? ii_config.role_model.find(name: role) : role else group.is_a?(Symbol) ? ii_config.role_group_model.find(name: role) : group end obj.have_permission self.pred, obj: self.obj end alias is_assigned_to assign_to # :user, User, user def obj return obj_type.constantize.find(obj_id) if obj_id.present? obj_type[/[A-Z]/] ? obj_type.constantize : obj_type.to_sym end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
i_am_i_can-3.0.0pre | lib/i_am_i_can/permission.rb |