ContentSecurityPolicyProcessor::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\Result\ContentSecurityPolicyHeaderResult;
12
use nicoSWD\SecHeaderCheck\Domain\Result\ParsedHeaders;
13
use nicoSWD\SecHeaderCheck\Domain\Result\Warning\ContentSecurityPolicyMissingFrameAncestorsDirectiveWarning;
14
15
final class ContentSecurityPolicyProcessor extends AbstractProcessor
16
{
17
    public function process(ParsedHeaders $parsedHeaders): void
18
    {
19
        $contentSecurityPolicyHeader = $this->header();
20
        $hasSecureFrameAncestors = false;
21
        $hasSecureXFrameOptions = false;
22
        $observations = new ObservationCollection();
23
24
        if ($contentSecurityPolicyHeader->isSecure()) {
25
            $hasSecureFrameAncestors = true;
26
        }
27
28
        $xFrameOptionsHeader = $parsedHeaders->getXFrameOptionsResult();
29
30
        if ($xFrameOptionsHeader && $xFrameOptionsHeader->isSecure()) {
31
            $hasSecureXFrameOptions = true;
32
        }
33
34
        if (!$hasSecureXFrameOptions) {
35
            if ($contentSecurityPolicyHeader && !$hasSecureFrameAncestors) {
36
                $observations->addWarning(new ContentSecurityPolicyMissingFrameAncestorsDirectiveWarning());
37
            }
38
        }
39
40
        $this->addObservations($observations);
41
    }
42
43
    private function header(): ContentSecurityPolicyHeaderResult
44
    {
45
        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...urityPolicyHeaderResult.
Loading history...
46
    }
47
}
48