NotUnderstood   A
last analyzed

Complexity

Total Complexity 5

Size/Duplication

Total Lines 67
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
wmc 5
eloc 18
dl 0
loc 67
rs 10
c 0
b 0
f 0

4 Methods

Rating   Name   Duplication   Size   Complexity  
A getQName() 0 3 1
A __construct() 0 3 1
A fromXML() 0 8 1
A toXML() 0 17 2
1
<?php
2
3
declare(strict_types=1);
4
5
namespace SimpleSAML\SOAP12\XML;
6
7
use DOMElement;
8
use SimpleSAML\SOAP12\Assert\Assert;
9
use SimpleSAML\XML\Attribute as XMLAttribute;
10
use SimpleSAML\XML\SchemaValidatableElementInterface;
11
use SimpleSAML\XML\SchemaValidatableElementTrait;
12
use SimpleSAML\XMLSchema\Exception\InvalidDOMElementException;
13
use SimpleSAML\XMLSchema\Exception\MissingAttributeException;
14
use SimpleSAML\XMLSchema\Type\QNameValue;
15
16
/**
17
 * Class representing a env:NotUnderstood element.
18
 *
19
 * @package simplesaml/xml-soap
20
 */
21
final class NotUnderstood extends AbstractSoapElement implements SchemaValidatableElementInterface
0 ignored issues
show
Bug introduced by
The type SimpleSAML\SOAP12\XML\AbstractSoapElement was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
22
{
23
    use SchemaValidatableElementTrait;
24
25
26
    /**
27
     * Initialize a soap:NotUnderstood
28
     *
29
     * @param \SimpleSAML\XMLSchema\Type\QNameValue $qname
30
     */
31
    public function __construct(
32
        protected QNameValue $qname,
33
    ) {
34
    }
35
36
37
    /**
38
     * @return \SimpleSAML\XMLSchema\Type\QNameValue
39
     */
40
    public function getQName(): QNameValue
41
    {
42
        return $this->qname;
43
    }
44
45
46
    /*
47
     * Convert XML into a NotUnderstood element
48
     *
49
     * @param \DOMElement $xml The XML element we should load
50
     *
51
     * @throws \SimpleSAML\XMLSchema\Exception\InvalidDOMElementException
52
     *   If the qualified name of the supplied element is wrong
53
     */
54
    public static function fromXML(DOMElement $xml): static
55
    {
56
        Assert::same($xml->localName, 'NotUnderstood', InvalidDOMElementException::class);
57
        Assert::same($xml->namespaceURI, static::NS, InvalidDOMElementException::class);
58
        Assert::notNull($xml->hasAttribute('qname'), MissingAttributeException::class);
59
60
        return new static(
61
            QNameValue::fromDocument($xml->getAttribute('qname'), $xml),
62
        );
63
    }
64
65
66
    /**
67
     * Convert this NotUnderstood to XML.
68
     *
69
     * @param \DOMElement|null $parent The element we should add this Body to.
70
     */
71
    public function toXML(?DOMElement $parent = null): DOMElement
72
    {
73
        $e = $this->instantiateParentElement($parent);
74
75
        if (!$e->lookupPrefix($this->getQName()->getNamespaceURI()->getValue())) {
76
            $namespace = new XMLAttribute(
77
                'http://www.w3.org/2000/xmlns/',
78
                'xmlns',
79
                $this->getQName()->getNamespacePrefix()->getValue(),
80
                $this->getQName()->getNamespaceURI(),
0 ignored issues
show
Bug introduced by
It seems like $this->getQName()->getNamespaceURI() can also be of type null; however, parameter $attrValue of SimpleSAML\XML\Attribute::__construct() does only seem to accept SimpleSAML\XMLSchema\Typ...face\ValueTypeInterface, maybe add an additional type check? ( Ignorable by Annotation )

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

80
                /** @scrutinizer ignore-type */ $this->getQName()->getNamespaceURI(),
Loading history...
81
            );
82
            $namespace->toXML($e);
83
        }
84
85
        $e->setAttribute('qname', strval($this->getQName()->getValue()));
86
87
        return $e;
88
    }
89
}
90