Uname: Linux webm005.cluster107.gra.hosting.ovh.net 5.15.167-ovh-vps-grsec-zfs-classid #1 SMP Tue Sep 17 08:14:20 UTC 2024 x86_64
User: 6036 (villadal)
Group: 100 (users)
Disabled functions: NONE
Safe mode: On[ PHPinfo ]
//home/villadal/www/old/////booked/lib/Application/Authorization      ( Reset | Go to )
File Name: AuthorizationService.php
Edit
<?php
/**
Copyright 2011-2014 Nick Korbel

This file is part of Booked SchedulerBooked SchedulereIt is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later versBooked SchedulerduleIt is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
alBooked SchedulercheduleIt.  If not, see <http://www.gnu.org/licenses/>.
 */

interface IRoleService
{
    
/**
     * @abstract
     * @param User $user
     * @return bool
     */
    
public function IsApplicationAdministrator(User $user);

    
/**
     * @abstract
     * @param User $user
     * @return bool
     */
    
public function IsResourceAdministrator(User $user);

    
/**
     * @abstract
     * @param User $user
     * @return bool
     */
    
public function IsGroupAdministrator(User $user);

    
/**
     * @abstract
     * @param User $user
     * @return bool
     */
    
public function IsScheduleAdministrator(User $user);
}

interface 
IAuthorizationService extends IRoleService
{
    
/**
     * @abstract
     * @param UserSession $reserver user who is requesting access to perform action
     * @return bool
     */
    
public function CanReserveForOthers(UserSession $reserver);

    
/**
     * @abstract
     * @param UserSession $reserver user who is requesting access to perform action
     * @param int $reserveForId user to reserve for
     * @return bool
     */
    
public function CanReserveFor(UserSession $reserver$reserveForId);

    
/**
     * @abstract
     * @param UserSession $approver user who is requesting access to perform action
     * @param int $approveForId user to approve for
     * @return bool
     */
    
public function CanApproveFor(UserSession $approver$approveForId);

    
/**
     * @param UserSession $user
     * @param IResource $resource
     * @return bool
     */
    
public function CanEditForResource(UserSession $userIResource $resource);

    
/**
     * @param UserSession $user
     * @param IResource $resource
     * @return bool
     */
    
public function CanApproveForResource(UserSession $userIResource $resource);

}

class 
AuthorizationService implements IAuthorizationService
{
    
/**
     * @var IUserRepository
     */
    
private $userRepository;

    public function 
__construct(IUserRepository $userRepository)
    {
        
$this->userRepository $userRepository;
    }

    
/**
     * @param UserSession $reserver user who is requesting access to perform action
     * @return bool
     */
    
public function CanReserveForOthers(UserSession $reserver)
    {
        if (
$reserver->IsAdmin)
        {
            return 
true;
        }

        
$user $this->userRepository->LoadById($reserver->UserId);

        return 
$user->IsGroupAdmin();
    }

    
/**
     * @param UserSession $reserver user who is requesting access to perform action
     * @param int $reserveForId user to reserve for
     * @return bool
     */
    
public function CanReserveFor(UserSession $reserver$reserveForId)
    {
        return 
$this->IsAdminFor($reserver$reserveForId);
    }

    
/**
     * @param UserSession $approver user who is requesting access to perform action
     * @param int $approveForId user to approve for
     * @return bool
     */
    
public function CanApproveFor(UserSession $approver$approveForId)
    {
        return 
$this->IsAdminFor($approver$approveForId);
    }

    
/**
     * @param User $user
     * @return bool
     */
    
public function IsApplicationAdministrator(User $user)
    {
        if (
$user->EmailAddress() == Configuration::Instance()->GetKey(ConfigKeys::ADMIN_EMAIL))
        {
            return 
true;
        }

        return 
$user->IsInRole(RoleLevel::APPLICATION_ADMIN);
    }

    
/**
     * @param User $user
     * @return bool
     */
    
public function IsResourceAdministrator(User $user)
    {
        return 
$user->IsInRole(RoleLevel::RESOURCE_ADMIN);
    }

    
/**
     * @param User $user
     * @return bool
     */
    
public function IsGroupAdministrator(User $user)
    {
        return 
$user->IsInRole(RoleLevel::GROUP_ADMIN);
    }

    
/**
     * @param User $user
     * @return bool
     */
    
public function IsScheduleAdministrator(User $user)
    {
        return 
$user->IsInRole(RoleLevel::SCHEDULE_ADMIN);
    }

    
/**
     * @param UserSession $userSession
     * @param int $otherUserId
     * @return bool
     */
    
private function IsAdminFor(UserSession $userSession$otherUserId)
    {
        if (
$userSession->IsAdmin)
        {
            return 
true;
        }

        if (!
$userSession->IsGroupAdmin)
        {
            
// dont even bother checking if the user isnt a group admin
            
return false;
        }

        
$user1 $this->userRepository->LoadById($userSession->UserId);
        
$user2 $this->userRepository->LoadById($otherUserId);

        return 
$user1->IsAdminFor($user2);
    }

    
/**
     * @param UserSession $userSession
     * @param IResource $resource
     * @return bool
     */
    
public function CanEditForResource(UserSession $userSessionIResource $resource)
    {
        if (
$userSession->IsAdmin)
        {
            return 
true;
        }

        if (!
$userSession->IsResourceAdmin && !$userSession->IsScheduleAdmin)
        {
            return 
false;
        }

        
$user $this->userRepository->LoadById($userSession->UserId);

        return 
$user->IsResourceAdminFor($resource);
    }

    
/**
     * @param UserSession $userSession
     * @param IResource $resource
     * @return bool
     */
    
public function CanApproveForResource(UserSession $userSessionIResource $resource)
    {
        if (
$userSession->IsAdmin)
        {
            return 
true;
        }

        if (!
$userSession->IsResourceAdmin)
        {
            return 
false;
        }

        
$user $this->userRepository->LoadById($userSession->UserId);

        return 
$user->IsResourceAdminFor($resource);
    }
}

All system for education purposes only. For more tools: Telegram @jackleet

Mr.X Private Shell

Logo
-
New File | New Folder
Command
SQL