Skip to content

Commit

Permalink
Add exclusion-list for ExtendableAttributesTrait
Browse files Browse the repository at this point in the history
  • Loading branch information
tvdijen committed Sep 12, 2024
1 parent 900bfed commit fe7ec61
Show file tree
Hide file tree
Showing 3 changed files with 67 additions and 25 deletions.
66 changes: 41 additions & 25 deletions src/ExtendableAttributesTrait.php
Original file line number Diff line number Diff line change
Expand Up @@ -93,38 +93,28 @@ public function getAttributesNS(): array
*
* @return array<int, \SimpleSAML\XML\Attribute> $attributes
*/
protected static function getAttributesNSFromXML(DOMElement $xml, NS|array $namespace = null): array
{
protected static function getAttributesNSFromXML(DOMElement $xml, NS|array $namespace = null): array {
$namespace = $namespace ?? static::XS_ANY_ATTR_NAMESPACE;
$exclusionList = static::getAttributeExclusions();
$attributes = [];

// Validate namespace value
if (!is_array($namespace)) {
// Must be one of the predefined values
Assert::oneOf($namespace, NS::cases());

if ($namespace === NS::ANY) {
foreach ($xml->attributes as $a) {
$attributes[] = new Attribute($a->namespaceURI, $a->prefix, $a->localName, $a->nodeValue);
}
} elseif ($namespace === NS::LOCAL) {
foreach ($xml->attributes as $a) {
if ($a->namespaceURI === null) {
$attributes[] = new Attribute($a->namespaceURI, $a->prefix, $a->localName, $a->nodeValue);
}
}
} elseif ($namespace === NS::OTHER) {
foreach ($xml->attributes as $a) {
if (!in_array($a->namespaceURI, [static::NS, null], true)) {
$attributes[] = new Attribute($a->namespaceURI, $a->prefix, $a->localName, $a->nodeValue);
}
}
} elseif ($namespace === NS::TARGET) {
foreach ($xml->attributes as $a) {
if ($a->namespaceURI === static::NS) {
$attributes[] = new Attribute($a->namespaceURI, $a->prefix, $a->localName, $a->nodeValue);
}
foreach ($xml->attributes as $a) {
if (in_array([$a->namespaceURI, $a->localName], $exclusionList, true)) {
continue;
} elseif ($namespace === NS::OTHER && in_array($a->namespaceURI, [static::NS, null], true)) {
continue;
} elseif ($namespace === NS::TARGET && $a->namespaceURI !== static::NS) {
continue;
} elseif ($namespace === NS::LOCAL && $a->namespaceURI !== null) {
continue;
}

$attributes[] = new Attribute($a->namespaceURI, $a->prefix, $a->localName, $a->nodeValue);
}
} else {
// Array must be non-empty and cannot contain ##any or ##other
Expand All @@ -144,9 +134,13 @@ protected static function getAttributesNSFromXML(DOMElement $xml, NS|array $name
}

foreach ($xml->attributes as $a) {
if (in_array($a->namespaceURI, $namespace, true)) {
$attributes[] = new Attribute($a->namespaceURI, $a->prefix, $a->localName, $a->nodeValue);
if (in_array([$a->namespaceURI, $a->localName], $exclusionList, true)) {
continue;
} elseif (!in_array($a->namespaceURI, $namespace, true)) {
continue;
}

$attributes[] = new Attribute($a->namespaceURI, $a->prefix, $a->localName, $a->nodeValue);
}
}

Expand Down Expand Up @@ -230,6 +224,13 @@ function (Attribute $attr) {
}
}

$exclusionList = static::getAttributeExclusions();
foreach ($attributes as $i => $attr) {
if (in_array([$attr->getNamespaceURI(), $attr->getAttrName()], $exclusionList, true)) {
unset($attributes[$i]);
}
}

$this->namespacedAttributes = $attributes;
}

Expand All @@ -249,4 +250,19 @@ public function getAttributeNamespace(): array|NS

return static::XS_ANY_ATTR_NAMESPACE;
}


/**
* Get the exclusions list for getAttributeNSFromXML.
*
* @return array<string, string>
*/
public static function getAttributeExclusions(): array
{
if (defined('static::XS_ANY_ATTR_EXCLUSIONS')) {
return static::XS_ANY_ATTR_EXCLUSIONS;
}

return [];
}
}
5 changes: 5 additions & 0 deletions tests/Utils/ExtendableAttributesElement.php
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,11 @@ class ExtendableAttributesElement extends AbstractElement
/** @var string|\SimpleSAML\XML\XsNamespace */
public const XS_ANY_ATTR_NAMESPACE = NS::ANY;

/** @var array */
public const XS_ANY_ATTR_EXCLUSIONS = [
['urn:x-simplesamlphp:namespace', 'attr3'],
];


/**
* Get the namespace for the element.
Expand Down
21 changes: 21 additions & 0 deletions tests/XML/ExtendableAttributesTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ public function testMarshalling(): void
[
new Attribute('urn:x-simplesamlphp:namespace', 'ssp', 'attr1', 'testval1'),
new Attribute('urn:x-simplesamlphp:namespace', 'ssp', 'attr2', 'testval2'),
new Attribute('urn:x-simplesamlphp:namespace', 'ssp', 'attr3', 'testval3'),
],
);

Expand All @@ -57,4 +58,24 @@ public function testMarshalling(): void
strval($extendableElement),
);
}


/**
*/
public function testGetAttributesNSFromXML(): void
{
$elt = ExtendableAttributesElement::fromXML(self::$xmlRepresentation->documentElement);
$attributes = $elt->getAttributesNS();

$this->assertCount(2, $attributes);
$this->assertEquals($attributes[0]->getNamespaceURI(), 'urn:x-simplesamlphp:namespace');
$this->assertEquals($attributes[0]->getNamespacePrefix(), 'ssp');
$this->assertEquals($attributes[0]->getAttrName(), 'attr1');
$this->assertEquals($attributes[0]->getAttrValue(), 'testval1');

$this->assertEquals($attributes[1]->getNamespaceURI(), 'urn:x-simplesamlphp:namespace');
$this->assertEquals($attributes[1]->getNamespacePrefix(), 'ssp');
$this->assertEquals($attributes[1]->getAttrName(), 'attr2');
$this->assertEquals($attributes[1]->getAttrValue(), 'testval2');
}
}

0 comments on commit fe7ec61

Please sign in to comment.