![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/ts.corals.io/corals-api/Corals/modules/Timesheet/Policies/ |
<?php namespace Corals\Modules\Timesheet\Policies; use Corals\Foundation\Policies\BasePolicy; use Corals\Modules\Timesheet\Facades\Timesheet; use Corals\Modules\Timesheet\Models\Client; use Corals\Modules\Timesheet\Services\EntryService; use Corals\User\Models\User; class ClientPolicy extends BasePolicy { /** * @var string[] */ protected $skippedAbilities = [ 'generateInvoice', ]; /** * @var string */ protected $administrationPermission = 'Administrations::admin.timesheet'; /** * @param User $user * @param Client $client * @return bool */ public function view(User $user, Client $client = null) { if ($client && !Timesheet::isClientBelongsToUser($user, $client)) { return false; } return $user->can('Timesheet::client.view'); } /** * @param User $user * @return bool */ public function create(User $user) { return $user->can('Timesheet::client.create'); } /** * @param User $user * @param Client $client * @return bool */ public function update(User $user, Client $client) { if ($user->can('Timesheet::client.update')) { return true; } return false; } /** * @param User $user * @param Client $client * @return bool */ public function destroy(User $user, Client $client) { if ($user->can('Timesheet::client.delete')) { return true; } return false; } /** * @param User $user * @param Client $client * @return bool */ public function generateInvoice(User $user, Client $client) { $cycleForClient = (new EntryService())->setClient($client)->getBillingCycleEdges(now(), $client); $hasInvoiceableEntries = $client->billableProjects() ->whereHas('entries', function ($entriesQB) use ($cycleForClient) { $entriesQB->join('timesheet_activities', 'timesheet_entries.activity_id', 'timesheet_activities.id') ->where('timesheet_activities.billable', 1) ->whereNull('timesheet_entries.invoice_id') ->where('timesheet_entries.spent_at', '<', $cycleForClient['start']); })->exists(); if (!$hasInvoiceableEntries) { return false; } return $user->can('Timesheet::client.update') || Timesheet::isTimesheetAdministration(); } }