# frozen_string_literal: true class UserRolePolicy < ApplicationPolicy def index? role.can?(:manage_roles) end def create? role.can?(:manage_roles) end def update? role.can?(:manage_roles) && (role.overrides?(record) || self_editing?) end def destroy? !record.everyone? && role.can?(:manage_roles) && role.overrides?(record) && !self_editing? end private def self_editing? role.id == record.id end end