Passed
Pull Request — master (#2)
by Tim
02:03
created

AbstractSignedXMLElement::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 3
nc 1
nop 3
dl 0
loc 5
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace SimpleSAML\XMLSecurity\XML;
6
7
use DOMElement;
8
use SimpleSAML\XMLSecurity\XML\ds\Signature;
9
10
/**
11
 * Abstract class to be implemented by all signed classes
12
 *
13
 * @package simplesamlphp/xml-security
14
 */
15
abstract class AbstractSignedXMLElement implements SignedElementInterface
16
{
17
    use SignedElementTrait;
18
19
    /**
20
     * The signed DOM structure.
21
     *
22
     * @var \DOMElement
23
     */
24
    protected DOMElement $structure;
25
26
    /**
27
     * The unsigned elelement.
28
     *
29
     * @var \SimpleSAML\XMLSecurity\XML\SignableElementInterface
30
     */
31
    protected SignableElementInterface $element;
32
33
34
    /**
35
     * Create/parse an alg:SigningMethod element.
36
     *
37
     * @param \DOMElement $xml
38
     * @param \SimpleSAML\XMLSecurity\XML\SignableElementInterface $elt
39
     * @param \SimpleSAML\XMLSecurity\XML\ds\Signature $signature
40
     */
41
    private function __construct(DOMElement $xml, SignableElementInterface $elt, Signature $signature)
42
    {
43
        $this->setStructure($xml);
44
        $this->setElement($elt);
45
        $this->setSignature($signature);
46
    }
47
48
49
    /**
50
     * Collect the value of the unsigned element
51
     *
52
     * @return \SimpleSAML\XMLSecurity\XML\SignableElementInterface
53
     */
54
    public function getElement(): SignableElementInterface
55
    {
56
        return $this->element;
57
    }
58
59
60
    /**
61
     * Set the value of the elment-property
62
     *
63
     * @param \SimpleSAML\XMLSecurity\XML\SignableElementInterface $elt
64
     */
65
    private function setElement(SignableElementInterface $elt): void
66
    {
67
        $this->element = $elt;
68
    }
69
70
71
    /**
72
     * Collect the value of the structure-property
73
     *
74
     * @return \DOMElement
75
     */
76
    public function getStructure(): DOMElement
77
    {
78
        return $this->structure;
79
    }
80
81
82
    /**
83
     * Set the value of the structure-property
84
     *
85
     * @param \DOMElement $structure
86
     */
87
    private function setStructure(DOMElement $structure): void
88
    {
89
        $this->structure = $structure;
90
    }
91
92
93
    /**
94
     * Create XML from this class
95
     *
96
     * @param \DOMElement|null $parent
97
     * @return \DOMElement
98
     */
99
    public function toXML(DOMElement $parent = null): DOMElement
0 ignored issues
show
Unused Code introduced by
The parameter $parent is not used and could be removed. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-unused  annotation

99
    public function toXML(/** @scrutinizer ignore-unused */ DOMElement $parent = null): DOMElement

This check looks for parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
100
    {
101
        return $this->structure;
102
    }
103
104
105
    /**
106
     * Create a class from XML
107
     *
108
     * @param \DOMElement $xml
109
     * @return self
110
     */
111
    abstract public static function fromXML(DOMElement $xml): object;
112
}
113