Ngiler SH3LL 360
Home
Information
Create File
Create Folder
:
/
home
/
tbf
/
tbfguestbe.tbf.ro
/
app
/
Policies
/
Information Server
MySQL :
OFF
Perl :
OFF
CURL :
ON
WGET :
OFF
PKEXEC :
OFF
Directive
Local Value
IP Address
89.40.16.97
System
Linux server.atelieruldeit.ro 3.10.0-1160.el7.x86_64 #1 SMP Mon Oct 19 16:18:59 UTC 2020 x86_64
User
tbf
PHP Version
7.3.33
Software
Apache
Doc root
Writable
close
Edit File :
ActivityPolicy.php
| Size :
4.60
KB
Copy
<?php namespace App\Policies; use App\Models\Activity; use App\Models\Position; use App\Models\User; class ActivityPolicy extends BasePolicy { /** * Can the user see this activity? * * @param User $user * @param Position $position * @param Activity $activity * * @return bool */ public function view(User $user, Position $position, Activity $activity): bool { $positionPolicy = new PositionPolicy(); $responsibleUserId = $activity->position->users()->wherePivot('is_responsible', true)->first()?->id; $adminUserId = $activity->position->users()->wherePivot('is_admin', true)->first()?->id; // Verificăm dacă utilizatorul este admin sau are permisiunea de a accesa poziția (responsabil sau entitate proprie) return ( $this->adminsAndEntityInstance($user, $position) || $responsibleUserId == $user->id || $adminUserId == $user->id || $user->id == $activity->user_id) && $this->entityInstance($user, $position) && $positionPolicy->view($user, $position) ; } /** * Can the user see this activity? * * @param Position $position * @param User $user * * @return bool */ public function create(User $user, Position $position, User $urlUser): bool { $positionPolicy = new PositionPolicy(); $responsibleUserId = $position->users()->wherePivot('is_responsible', true)->first()?->id; $adminUserId =$position->users()->wherePivot('is_admin', true)->first()?->id; return ( $this->adminsAndEntityInstance($user, $position) || $responsibleUserId == $user->id || $adminUserId == $user->id || $user->id == $urlUser->id) && $this->entityInstance($user, $position) && $positionPolicy->view($user, $position) ; } /** * Can the user see this activity? * * @param User $user * @param Position $position * @param User $urlUser * @param Activity $activity * * @return bool */ public function update(User $user, Position $position, User $urlUser, Activity $activity): bool { return $this->view($user, $position, $activity); } /** * Can the user edit this activity? * * @param User $user * @param Position $position * @param Activity $activity * * @return bool */ public function edit(User $user, Position $position, Activity $activity): bool { return $this->view($user, $position, $activity); } /** * Can the user delete this activity? * * @param User $user * @param Position $position * @param Activity $activity * * @return bool */ public function delete(User $user, Position $position, Activity $activity): bool { return $this->view($user, $position, $activity); } /** * Can the user view activities? * * @param User $user * @param Position $position * @param User $urlUser * * @return bool */ public function viewActivities(User $user, Position $position, User $urlUser): bool { $positionPolicy = new PositionPolicy(); $responsibleUserId = $position->users()->wherePivot('is_responsible', true)->first()?->id; $adminUserId =$position->users()->wherePivot('is_admin', true)->first()?->id; return ( ( $responsibleUserId == $user->id || $user->id == $adminUserId || $user->id == $urlUser->id || $this->adminsAndEntityInstance($user, $position) ) && $this->entityInstance($user, $position) && $positionPolicy->view($user, $position) ); } /** * Can the user update evaluation for this activity? * * @param User $user * @param Position $position * @param Activity $activity * * @return bool */ public function updateEvaluation(User $user, Position $position, Activity $activity): bool { $positionPolicy = new PositionPolicy(); $responsibleUserId = $position->users()->wherePivot('is_responsible', true)->first()?->id; $adminUserId =$position->users()->wherePivot('is_admin', true)->first()?->id; return ( $this->adminsAndEntityInstance($user, $position) || $responsibleUserId == $user->id || $adminUserId == $user->id) && $this->entityInstance($user, $position) && $positionPolicy->viewEvaluation($user, $position) ; } }
Back