108 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Ruby
		
	
	
	
		
		
			
		
	
	
			108 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Ruby
		
	
	
	
| 
								 | 
							
								class Authorization
							 | 
						||
| 
								 | 
							
								  include Mongoid::Document
							 | 
						||
| 
								 | 
							
								  include Mongoid::Timestamps
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  field :title
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  belongs_to :module_app
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  has_and_belongs_to_many :roles
							 | 
						||
| 
								 | 
							
								  has_and_belongs_to_many :sub_roles
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  delegate :update_auth_approval_users, :update_auth_manager_users, :update_auth_sub_manager_users, to: :module_app, prefix: true, allow_nil: true
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  after_save :update_module_app
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  def add_roles(roles)
							 | 
						||
| 
								 | 
							
								  	users = []
							 | 
						||
| 
								 | 
							
								  	roles = Array(roles)
							 | 
						||
| 
								 | 
							
								    add_operation(:roles, roles)
							 | 
						||
| 
								 | 
							
								    sub_roles = [] 
							 | 
						||
| 
								 | 
							
								    roles.each{|role| role.sub_roles.each{|sub_role| sub_roles << sub_role.id}}
							 | 
						||
| 
								 | 
							
								    add_operation(:sub_roles, sub_roles)
							 | 
						||
| 
								 | 
							
								    roles.each{|role| role.users.where(admin: false).each{|user| users << user}}
							 | 
						||
| 
								 | 
							
										add_users(users, false)
							 | 
						||
| 
								 | 
							
								  end
							 | 
						||
| 
								 | 
							
								  
							 | 
						||
| 
								 | 
							
								  def add_sub_roles(sub_roles)
							 | 
						||
| 
								 | 
							
								  	users = []
							 | 
						||
| 
								 | 
							
								  	sub_roles = Array(sub_roles)
							 | 
						||
| 
								 | 
							
								    add_operation(:sub_roles, sub_roles)
							 | 
						||
| 
								 | 
							
								    sub_roles.each do |sub_role| 
							 | 
						||
| 
								 | 
							
											self.roles << sub_role.role unless self.roles.include?(sub_role.role)
							 | 
						||
| 
								 | 
							
								    	sub_role.users.where(admin: false).each{|user| users << user}
							 | 
						||
| 
								 | 
							
								    end
							 | 
						||
| 
								 | 
							
										add_users(users, false)
							 | 
						||
| 
								 | 
							
								  end
							 | 
						||
| 
								 | 
							
								  
							 | 
						||
| 
								 | 
							
								  def add_users(users, with_parents = true)
							 | 
						||
| 
								 | 
							
								  	users = Array(users)
							 | 
						||
| 
								 | 
							
								    add_operation(:authorized_users, users)
							 | 
						||
| 
								 | 
							
								    users.each do |user|
							 | 
						||
| 
								 | 
							
								    	user.roles.each do |role|
							 | 
						||
| 
								 | 
							
									    	self.roles << role unless self.roles.include?(role)
							 | 
						||
| 
								 | 
							
								    	end
							 | 
						||
| 
								 | 
							
								    	user.sub_roles.each do |sub_role|
							 | 
						||
| 
								 | 
							
									    	self.sub_roles << sub_role unless self.sub_roles.include?(sub_role)
							 | 
						||
| 
								 | 
							
								    	end
							 | 
						||
| 
								 | 
							
								    end if with_parents
							 | 
						||
| 
								 | 
							
								   	self.save
							 | 
						||
| 
								 | 
							
								  end
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  def remove_roles(roles)
							 | 
						||
| 
								 | 
							
								  	users = []
							 | 
						||
| 
								 | 
							
								  	sub_roles = []
							 | 
						||
| 
								 | 
							
								  	roles = Array(roles)
							 | 
						||
| 
								 | 
							
								  	remove_operation(:roles, roles)
							 | 
						||
| 
								 | 
							
								 		roles.each do |role|
							 | 
						||
| 
								 | 
							
								 			role.sub_roles.each{|sub_role| sub_roles << sub_role}
							 | 
						||
| 
								 | 
							
								 			role.users.where(admin: false).each{|user| users << user}
							 | 
						||
| 
								 | 
							
								 		end
							 | 
						||
| 
								 | 
							
										remove_operation(:sub_role_ids, sub_roles)
							 | 
						||
| 
								 | 
							
										remove_operation(:authorized_user_ids, users)
							 | 
						||
| 
								 | 
							
										add_roles(self.roles)
							 | 
						||
| 
								 | 
							
								  end
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  def remove_sub_roles(sub_roles)
							 | 
						||
| 
								 | 
							
								  	users = []
							 | 
						||
| 
								 | 
							
								  	sub_roles = Array(sub_roles)
							 | 
						||
| 
								 | 
							
								  	remove_operation(:sub_roles, sub_roles)
							 | 
						||
| 
								 | 
							
								  	sub_roles.each do |sub_role|
							 | 
						||
| 
								 | 
							
								  		users << sub_role.users.where(admin: false)
							 | 
						||
| 
								 | 
							
								  	end
							 | 
						||
| 
								 | 
							
										remove_operation(:authorized_user_ids, users)
							 | 
						||
| 
								 | 
							
										add_roles(self.roles)
							 | 
						||
| 
								 | 
							
								  end
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  def remove_users(users)
							 | 
						||
| 
								 | 
							
								  	users = Array(users)
							 | 
						||
| 
								 | 
							
								  	remove_operation(:authorized_user_ids, users)
							 | 
						||
| 
								 | 
							
								   	self.save
							 | 
						||
| 
								 | 
							
								  end
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  protected
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  def add_operation(db_field, objs)
							 | 
						||
| 
								 | 
							
								   	objs.each do |obj|
							 | 
						||
| 
								 | 
							
									   	self.send(db_field) << obj unless self.send(db_field).include?(obj)
							 | 
						||
| 
								 | 
							
								   	end
							 | 
						||
| 
								 | 
							
								  end  
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  def remove_operation(db_field, obj)
							 | 
						||
| 
								 | 
							
								    self.write_attribute(db_field, self.send(db_field) - obj.map{|y| y.id})
							 | 
						||
| 
								 | 
							
								  end
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  private
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  def update_module_app
							 | 
						||
| 
								 | 
							
								  	case self._type
							 | 
						||
| 
								 | 
							
								  	when "AuthApproval"
							 | 
						||
| 
								 | 
							
								  		self.module_app_update_auth_approval_users
							 | 
						||
| 
								 | 
							
								  	when "AuthManager"
							 | 
						||
| 
								 | 
							
								  		self.module_app_update_auth_manager_users
							 | 
						||
| 
								 | 
							
								  	when "AuthSubManager"
							 | 
						||
| 
								 | 
							
								  		self.module_app_update_auth_sub_manager_users
							 | 
						||
| 
								 | 
							
								  	end
							 | 
						||
| 
								 | 
							
								  end
							 | 
						||
| 
								 | 
							
								end
							 |