2014-05-01 07:14:16 +00:00
|
|
|
class Admin::AuthorizationsController < OrbitAdminController
|
2014-05-05 04:29:39 +00:00
|
|
|
prepend_before_filter :admin_or_manager
|
2014-05-01 07:14:16 +00:00
|
|
|
layout "back_end"
|
|
|
|
|
|
|
|
def index
|
|
|
|
@module_apps ||= ModuleApp.any_of({authorizable: true}).order_by([:title, :asc])
|
|
|
|
if @module_apps && @module_apps.include?(@module_app)
|
|
|
|
if @type
|
|
|
|
case @type
|
|
|
|
when 'category_authorization'
|
|
|
|
if (@module_app.categorizable || @module_app.categories.present?)
|
|
|
|
@objects = @module_app.categories rescue nil
|
|
|
|
else
|
|
|
|
@error = t(:no_category)
|
|
|
|
end
|
|
|
|
else
|
|
|
|
@objects = @klass.all
|
|
|
|
end
|
|
|
|
unless @objects.blank?
|
|
|
|
@object ||= @objects.first
|
2014-05-26 10:52:15 +00:00
|
|
|
@authorizations = Authorization.category_sub_managers(@object) rescue nil
|
2014-05-01 07:14:16 +00:00
|
|
|
else
|
|
|
|
@error = t(:no_data)
|
|
|
|
end
|
2014-05-26 10:52:15 +00:00
|
|
|
else
|
2014-05-27 10:37:59 +00:00
|
|
|
@authorizations = @module_app.module_managers rescue []
|
2014-05-01 07:14:16 +00:00
|
|
|
end
|
|
|
|
elsif @module_apps
|
|
|
|
@module_app = @module_apps.first
|
|
|
|
else
|
|
|
|
redirect_to :root
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-05-05 04:29:39 +00:00
|
|
|
def add_users
|
|
|
|
users = User.find(params[:user_ids]) rescue nil
|
|
|
|
unless users.nil?
|
|
|
|
authorization = users.map {|u| get_or_create_authorization(u.id)}.first
|
|
|
|
end
|
|
|
|
@users = @module_app.module_managers
|
|
|
|
render 'admin/authorizations/reload_users'
|
|
|
|
end
|
|
|
|
|
|
|
|
def add_roles
|
|
|
|
roles = Role.find(params[:role_ids]) rescue nil
|
|
|
|
unless roles.nil?
|
|
|
|
authorization = roles.map { |r| get_or_create_authorization_with_role(r.id)}.first
|
2014-05-01 07:14:16 +00:00
|
|
|
end
|
2014-05-05 04:29:39 +00:00
|
|
|
@users = @module_app.module_managers
|
|
|
|
render 'admin/authorizations/reload_users'
|
|
|
|
end
|
2014-05-01 07:14:16 +00:00
|
|
|
|
|
|
|
def modal_select
|
|
|
|
existing_users = User.find(params[:ids]) rescue []
|
|
|
|
roles = Role.all
|
|
|
|
if @type
|
|
|
|
@object_id = @object.id if @object
|
2014-05-05 06:20:58 +00:00
|
|
|
@sub_mangers = Authorization.category_sub_managers(@object)
|
2014-05-01 07:14:16 +00:00
|
|
|
@sorted_users = roles.inject({}) do |users, role|
|
2014-05-05 04:29:39 +00:00
|
|
|
users_for_role = role.member_profiles.select {|m| !m.user.is_admin?}.map {|u| u.user}
|
2014-05-05 06:20:58 +00:00
|
|
|
users[role] = users_for_role - @sub_mangers
|
2014-05-01 07:14:16 +00:00
|
|
|
users
|
|
|
|
end
|
|
|
|
else
|
|
|
|
@sorted_users = roles.inject({}) do |users, role|
|
2014-05-05 04:29:39 +00:00
|
|
|
users_for_role = role.member_profiles.select {|m| !m.user.is_admin?}.map {|u| u.user}
|
2014-05-05 05:59:38 +00:00
|
|
|
users[role] = users_for_role - @module_app.module_managers
|
2014-05-01 07:14:16 +00:00
|
|
|
users
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-05-05 04:29:39 +00:00
|
|
|
def remove_roles
|
|
|
|
roles = Role.find(params[:role_ids]) rescue []
|
|
|
|
unless roles.blank?
|
|
|
|
authorization = get_or_create_authorization
|
|
|
|
remove_roles_form_auth(authorization, roles)
|
|
|
|
end
|
|
|
|
@users = authorization.authorized_users
|
|
|
|
render 'admin/authorizations/reload_users'
|
|
|
|
end
|
|
|
|
|
|
|
|
def remove_users
|
|
|
|
@users = User.find(params[:ids]) rescue []
|
|
|
|
unless @users.blank?
|
|
|
|
authorization = @users.map {|u| remove_authorizations(u.id)}.first
|
|
|
|
end
|
|
|
|
@users = @module_app.module_managers
|
|
|
|
render 'admin/authorizations/reload_users'
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
def get_or_create_authorization(user_id)
|
|
|
|
case @type
|
|
|
|
when 'category_authorization'
|
|
|
|
if @object
|
|
|
|
Authorization.create_category_authorization(@module_app.id, @object.id, user_id)
|
|
|
|
else
|
|
|
|
@error = t(:no_data)
|
|
|
|
end
|
|
|
|
when nil
|
|
|
|
Authorization.create_module_authorization(@module_app.id, user_id)
|
|
|
|
else
|
|
|
|
auth = @object.get_authorization_by_title("#{@type}_#{@module_app.key}")
|
|
|
|
unless auth
|
|
|
|
auth = Authorization.create_category_authorization(@module_app.id, @object.id, user_id) if @type.include?('authorization')
|
|
|
|
end
|
|
|
|
auth
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def get_or_create_authorization_with_role(role_id)
|
|
|
|
case @type
|
|
|
|
when 'category_authorization'
|
|
|
|
if @object
|
|
|
|
Authorization.create_category_authorization_with_role(@module_app.id, @object.id, role_id)
|
|
|
|
else
|
|
|
|
@error = t(:no_data)
|
|
|
|
end
|
|
|
|
when nil
|
|
|
|
Authorization.create_module_authorization_with_role(@module_app.id,role_id)
|
|
|
|
else
|
|
|
|
auth = @object.get_authorization_by_title("#{@type}_#{@module_app.key}")
|
|
|
|
unless auth
|
|
|
|
auth = Authorization.create_category_authorization_with_role(@module_app.id, @object.id, role_id)
|
|
|
|
end
|
|
|
|
auth
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def remove_authorizations(user_id)
|
|
|
|
case @type
|
|
|
|
when 'category_authorization'
|
|
|
|
if @object
|
|
|
|
Authorization.remove_category_authorization(@object.id, user_id)
|
|
|
|
@error = t(:no_data)
|
|
|
|
end
|
|
|
|
when nil
|
|
|
|
Authorization.remove_module_authorization(@module_app.id, user_id)
|
|
|
|
else
|
|
|
|
auth = @object.get_authorization_by_title("#{@type}_#{@module_app.key}")
|
|
|
|
unless auth
|
|
|
|
auth = Authorization.remove_category_authorization(@object.id, user_id)
|
|
|
|
end
|
|
|
|
auth
|
|
|
|
end
|
|
|
|
end
|
2014-05-01 07:14:16 +00:00
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def admin_or_manager
|
|
|
|
@override_can_use = true
|
|
|
|
setup_vars
|
2014-05-05 04:29:39 +00:00
|
|
|
authenticate_user
|
2014-05-01 07:14:16 +00:00
|
|
|
current_user.is_manager?(@module_app) unless current_user.is_admin?
|
|
|
|
end
|
|
|
|
|
|
|
|
def setup_vars
|
|
|
|
@module_app = ModuleApp.find_by(key: params[:module]) if params[:module]
|
|
|
|
@type = params[:type].underscore if params[:type]
|
|
|
|
if @type
|
|
|
|
@klass = @type.gsub('_authorization', '').gsub('_approval', '').classify.constantize rescue nil
|
|
|
|
@object = @klass.find(params[:id]) rescue nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|