* #118 - wip * #118 - keys * #118 - fix * #118 - fix menu * #118 - fix to policies and added translations * #118 - wip * #118 - tests * #118 - fix * #118 - fix * #118 - fix * Update resources/lang/pl.json Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com> * #118 - cr fix Co-authored-by: EwelinaLasowy <ewelina.lasowy@blumilk.pl> Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com>
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| declare(strict_types=1);
 | |
| 
 | |
| namespace Toby\Architecture\Providers;
 | |
| 
 | |
| use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;
 | |
| use Illuminate\Support\Facades\Gate;
 | |
| use Toby\Domain\Enums\Role;
 | |
| use Toby\Domain\Policies\KeyPolicy;
 | |
| use Toby\Domain\Policies\VacationRequestPolicy;
 | |
| use Toby\Eloquent\Models\Key;
 | |
| use Toby\Eloquent\Models\User;
 | |
| use Toby\Eloquent\Models\VacationRequest;
 | |
| 
 | |
| class AuthServiceProvider extends ServiceProvider
 | |
| {
 | |
|     protected $policies = [
 | |
|         VacationRequest::class => VacationRequestPolicy::class,
 | |
|         Key::class => KeyPolicy::class,
 | |
|     ];
 | |
| 
 | |
|     public function boot(): void
 | |
|     {
 | |
|         $this->registerPolicies();
 | |
| 
 | |
|         Gate::before(function (User $user) {
 | |
|             if ($user->role === Role::Administrator) {
 | |
|                 return true;
 | |
|             }
 | |
|         });
 | |
| 
 | |
|         Gate::define("manageUsers", fn(User $user) => $user->role === Role::AdministrativeApprover);
 | |
|         Gate::define("manageHolidays", fn(User $user) => $user->role === Role::AdministrativeApprover);
 | |
|         Gate::define("manageVacationLimits", fn(User $user) => $user->role === Role::AdministrativeApprover);
 | |
|         Gate::define("generateTimesheet", fn(User $user) => $user->role === Role::AdministrativeApprover);
 | |
|         Gate::define("listMonthlyUsage", fn(User $user) => $user->role === Role::AdministrativeApprover);
 | |
|     }
 | |
| }
 |