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

ACFMiddleware::handle()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 2
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 5
rs 10
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