1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2024-11-29 10:24:20 +01:00
fab-manager/app/policies/user_policy.rb

36 lines
974 B
Ruby
Raw Normal View History

2015-05-05 03:10:25 +02:00
class UserPolicy < ApplicationPolicy
class Scope < Scope
def resolve
if user.admin?
scope.includes(:group, :training_credits, :machine_credits, statistic_profile: [subscriptions: [plan: [:credits]]], profile: [:user_avatar])
.joins(:roles).where("users.is_active = 'true' AND roles.name = 'member'").order('users.created_at desc')
2015-05-05 03:10:25 +02:00
else
scope.includes(profile: [:user_avatar]).joins(:roles).where("users.is_active = 'true' AND roles.name = 'member'")
.where(is_allow_contact: true).order('users.created_at desc')
2015-05-05 03:10:25 +02:00
end
end
end
def show?
user.admin? or (record.is_allow_contact and record.member?) or (user.id == record.id)
2015-05-05 03:10:25 +02:00
end
def update?
user.admin? or (user.id == record.id)
2015-05-05 03:10:25 +02:00
end
2016-03-23 18:39:41 +01:00
def destroy?
user.id == record.id
end
def merge?
user.id == record.id
end
2016-05-30 15:39:19 +02:00
%w[list create mapping].each do |action|
define_method "#{action}?" do
user.admin?
end
2016-05-30 15:39:19 +02:00
end
2015-05-05 03:10:25 +02:00
end