SetCookieProcessor::header()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
eloc 1
dl 0
loc 3
c 0
b 0
f 0
ccs 0
cts 2
cp 0
rs 10
cc 1
nc 1
nop 0
crap 2
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