Passed
Push — main ( bae336...1e821c )
by Roberto
01:48
created

ACFMiddleware   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 39
Duplicated Lines 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
eloc 21
c 2
b 0
f 0
dl 0
loc 39
rs 10
wmc 5

2 Methods

Rating   Name   Duplication   Size   Complexity  
A checkPermissions() 0 20 4
A handle() 0 5 1
1
<?php
2
3
namespace Lepton\Middleware;
4
5
use Lepton\Authenticator\AccessControlAttributes\LoginRequired;
6
use Lepton\Http\Request;
7
use Lepton\Routing\Match\{BaseMatch, MatchRoute};
8
use Lepton\Http\Response\{SuccessResponse, HttpResponse, RedirectResponse};
9
use Lepton\Middleware\BaseAccessControlMiddleware;
10
11
class ACFMiddleware extends BaseAccessControlMiddleware
12
{
13
    public string $level_field;
14
15
    public const CIRCOLO = 1;
16
    public const FEDERAZIONE = 2;
17
    public const REGIONALE = 4;
18
    public const NAZIONALE = 8;
19
20
21
22
    protected function handle(mixed ...$middlewareParams): HttpResponse|Request
23
    {
24
        $this->level_field = $middlewareParams["level_field"] ?? "level";
25
26
        return parent::handle(...$middlewareParams);
27
    }
28
29
30
    protected function checkPermissions(string $modifier, mixed ...$params): bool
31
    {
32
33
        if($modifier == LoginRequired::class) {
34
35
            $level = $params[0] ?? 1;
36
            $authenticator = new \Lepton\Authenticator\UserAuthenticator();
37
            $loggedIn = $authenticator->isLoggedIn();
38
            if(! $loggedIn){
39
                return false;
40
            }
41
            $user = $authenticator->getLoggedUser();
42
            $splitted = explode("__", $this->level_field);
43
            $user_level = $user;
44
            foreach($splitted as $part){
45
                $user_level = $user_level->$part;
46
            }
47
            return ($user_level >= $level);
48
        }
49
        return true;
50
    }
51
}
52