EncryptedElementTrait   A
last analyzed

Complexity

Total Complexity 10

Size/Duplication

Total Lines 100
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 34
dl 0
loc 100
rs 10
c 0
b 0
f 0
wmc 10

6 Methods

Rating   Name   Duplication   Size   Complexity  
A getEncryptionBackend() 0 5 1
A getBlacklistedAlgorithms() 0 4 1
A toXML() 0 8 2
A fromXML() 0 22 1
A getDecryptionKeys() 0 3 1
A __construct() 0 21 4
1
<?php
2
3
declare(strict_types=1);
4
5
namespace SimpleSAML\SAML2\XML;
6
7
use DOMElement;
8
use SimpleSAML\Assert\Assert;
9
use SimpleSAML\SAML2\Compat\ContainerSingleton;
10
use SimpleSAML\SAML2\Exception\ProtocolViolationException;
11
use SimpleSAML\XML\AbstractElement;
12
use SimpleSAML\XML\Exception\InvalidDOMElementException;
13
use SimpleSAML\XML\Exception\TooManyElementsException;
14
use SimpleSAML\XMLSecurity\Backend\EncryptionBackend;
15
use SimpleSAML\XMLSecurity\Constants as C;
16
use SimpleSAML\XMLSecurity\XML\EncryptedElementTrait as ParentEncryptedElementTrait;
17
use SimpleSAML\XMLSecurity\XML\xenc\EncryptedData;
18
use SimpleSAML\XMLSecurity\XML\xenc\EncryptedKey;
19
20
/**
21
 * Trait aggregating functionality for elements that are encrypted.
22
 *
23
 * @package simplesamlphp/saml2
24
 */
25
trait EncryptedElementTrait
26
{
27
    use ParentEncryptedElementTrait;
28
29
30
    /**
31
     * Constructor for encrypted elements.
32
     *
33
     * @param \SimpleSAML\XMLSecurity\XML\xenc\EncryptedData $encryptedData The EncryptedData object.
34
     * @param \SimpleSAML\XMLSecurity\XML\xenc\EncryptedKey[] $decryptionKeys The EncryptedKey objects.
35
     */
36
    public function __construct(
37
        protected EncryptedData $encryptedData,
38
        protected array $decryptionKeys = [],
39
    ) {
40
        Assert::allIsInstanceOf($decryptionKeys, EncryptedKey::class, ProtocolViolationException::class);
41
42
        /**
43
         * 6.2: The <EncryptedData> element's Type attribute SHOULD be used and, if it is
44
         * present, MUST have the value http://www.w3.org/2001/04/xmlenc#Element.
45
         */
46
        Assert::nullOrSame($encryptedData->getType(), C::XMLENC_ELEMENT);
47
48
        $keyInfo = $this->encryptedData->getKeyInfo();
49
        if ($keyInfo === null) {
50
            return;
51
        }
52
53
        foreach ($keyInfo->getInfo() as $info) {
54
            if ($info instanceof EncryptedKey) {
55
                $this->encryptedKey = $info;
56
                break;
57
            }
58
        }
59
    }
60
61
62
    public function getBlacklistedAlgorithms(): ?array
63
    {
64
        $container = ContainerSingleton::getInstance();
65
        return $container->getBlacklistedEncryptionAlgorithms();
66
    }
67
68
69
    public function getEncryptionBackend(): ?EncryptionBackend
70
    {
71
        // return the encryption backend you want to use,
72
        // or null if you are fine with the default
73
        return null;
74
    }
75
76
77
    public function getDecryptionKeys(): array
78
    {
79
        return $this->decryptionKeys;
80
    }
81
82
83
    /**
84
     * @inheritDoc
85
     *
86
     * @throws \SimpleSAML\XML\Exception\InvalidDOMElementException
87
     *   If the qualified name of the supplied element is wrong
88
     */
89
    public static function fromXML(DOMElement $xml): static
90
    {
91
        Assert::same(
92
            $xml->localName,
93
            AbstractElement::getClassName(static::class),
94
            InvalidDOMElementException::class,
95
        );
96
        Assert::same($xml->namespaceURI, static::NS, InvalidDOMElementException::class);
0 ignored issues
show
Bug introduced by
The constant SimpleSAML\SAML2\XML\EncryptedElementTrait::NS was not found. Maybe you did not declare it correctly or list all dependencies?
Loading history...
97
98
        $ed = EncryptedData::getChildrenOfClass($xml);
99
        Assert::count(
100
            $ed,
101
            1,
102
            sprintf(
103
                'No more or less than one EncryptedData element allowed in %s.',
104
                AbstractElement::getClassName(static::class),
105
            ),
106
            TooManyElementsException::class,
107
        );
108
109
        $ek = EncryptedKey::getChildrenOfClass($xml);
110
        return new static($ed[0], $ek);
111
    }
112
113
114
    /**
115
     * @inheritDoc
116
     */
117
    public function toXML(?DOMElement $parent = null): DOMElement
118
    {
119
        $e = $this->instantiateParentElement($parent);
120
        $this->encryptedData->toXML($e);
121
        foreach ($this->getDecryptionKeys() as $key) {
122
            $key->toXML($e);
123
        }
124
        return $e;
125
    }
126
}
127