Passed
Pull Request — master (#55)
by Tim
01:48
created

HexBinaryValue   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 30
Duplicated Lines 0 %

Importance

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

2 Methods

Rating   Name   Duplication   Size   Complexity  
A sanitizeContent() 0 3 1
A validateContent() 0 7 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace SimpleSAML\XML\Type;
6
7
use SimpleSAML\XML\Assert\Assert;
8
use SimpleSAML\XML\Exception\SchemaViolationException;
9
10
use function str_replace;
11
12
/**
13
 * @package simplesaml/xml-common
14
 */
15
class HexBinaryValue extends AbstractValueType
16
{
17
    /**
18
     * Sanitize the content.
19
     *
20
     * Note:  There are no processing rules for xs:hexBinary regarding whitespace. General consensus is to strip them
21
     *
22
     * @param string $content  The unsanitized content
23
     * @return string
24
     */
25
    protected function sanitizeContent(string $content): string
26
    {
27
        return str_replace(["\f", "\r", "\n", "\t", "\v", ' '], '', $content);
28
    }
29
30
31
    /**
32
     * Validate the content.
33
     *
34
     * @param string $content
35
     * @throws \SimpleSAML\XML\Exception\SchemaViolationException on failure
36
     * @return void
37
     */
38
    protected function validateContent(string $content): void
39
    {
40
        // Note: content must already be sanitized before validating
41
        Assert::regex(
42
            $this->sanitizeContent($content),
43
            '/([0-9A-F]{2})*/i',
44
            SchemaViolationException::class,
45
        );
46
    }
47
}
48