EmailAddressValue::sanitizeValue()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 6
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 2
nc 1
nop 1
dl 0
loc 6
rs 10
c 1
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace SimpleSAML\SAML2\Type;
6
7
use SimpleSAML\SAML2\Assert\Assert;
8
9
use function preg_replace;
10
11
/**
12
 * @package simplesaml/saml2
13
 */
14
class EmailAddressValue extends SAMLStringValue
15
{
16
    /**
17
     * Sanitize the content of the element.
18
     *
19
     * @throws \Exception on failure
20
     */
21
    protected function sanitizeValue(string $value): string
22
    {
23
        $normalizedValue = static::collapseWhitespace(static::normalizeWhitespace($value));
24
25
        // Remove prefixed schema and forward slashes
26
        return preg_replace('/^(mailto:)+/i', '', $normalizedValue);
27
    }
28
29
30
    /**
31
     * Validate the content of the element.
32
     *
33
     * @throws \Exception on failure
34
     */
35
    protected function validateValue(string $value): void
36
    {
37
        Assert::email($this->sanitizeValue($value));
38
    }
39
}
40