SetCookieProcessor   A
last analyzed

Complexity

Total Complexity 5

Size/Duplication

Total Lines 28
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

Changes 0
Metric Value
wmc 5
eloc 14
dl 0
loc 28
c 0
b 0
f 0
ccs 0
cts 14
cp 0
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A process() 0 21 4
A header() 0 3 1
1
<?php declare(strict_types=1);
2
3
/**
4
 * @license  http://opensource.org/licenses/mit-license.php MIT
5
 * @link     https://github.com/nicoSWD
6
 * @author   Nicolas Oelgart <[email protected]>
7
 */
8
namespace nicoSWD\SecHeaderCheck\Domain\Result\Processor;
9
10
use nicoSWD\SecHeaderCheck\Domain\Result\ObservationCollection;
11
use nicoSWD\SecHeaderCheck\Domain\Result\ParsedHeaders;
12
use nicoSWD\SecHeaderCheck\Domain\Result\Result\SetCookieHeaderResult;
13
use nicoSWD\SecHeaderCheck\Domain\Result\Warning\CookieWithHttpOnlyFlagKudos;
14
use nicoSWD\SecHeaderCheck\Domain\Result\Warning\CookieWithMissingHttpOnlyFlagInfo;
15
use nicoSWD\SecHeaderCheck\Domain\Result\Warning\CookieWithMissingSameSiteFlagInfo;
16
use nicoSWD\SecHeaderCheck\Domain\Result\Warning\CookieWithMissingSecureFlagWarning;
17
use nicoSWD\SecHeaderCheck\Domain\Result\Warning\CookieWithSecureFlagKudos;
18
19
final class SetCookieProcessor extends AbstractProcessor
20
{
21
    public function process(ParsedHeaders $parsedHeaders): void
22
    {
23
        $observations = new ObservationCollection();
24
25
        if (!$this->header()->hasFlagHttpOnly()) {
26
            $observations->addInfo(new CookieWithMissingHttpOnlyFlagInfo());
27
        } else {
28
            $observations->addKudos(new CookieWithHttpOnlyFlagKudos());
29
        }
30
31
        if (!$this->header()->hasFlagSecure()) {
32
            $observations->addWarning(new CookieWithMissingSecureFlagWarning());
33
        } else {
34
            $observations->addKudos(new CookieWithSecureFlagKudos());
35
        }
36
37
        if (!$this->header()->hasFlagSameSite()) {
38
            $observations->addInfo(new CookieWithMissingSameSiteFlagInfo());
39
        }
40
41
        $this->addObservations($observations);
42
    }
43
44
    private function header(): SetCookieHeaderResult
45
    {
46
        return $this->parsedHeader;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $this->parsedHeader returns the type nicoSWD\SecHeaderCheck\D...lt\AbstractParsedHeader which includes types incompatible with the type-hinted return nicoSWD\SecHeaderCheck\D...t\SetCookieHeaderResult.
Loading history...
47
    }
48
}
49