Viewing file: RoleDescriptor.php (4.7 KB) -rwxrwxr-x Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/** * Class representing SAML 2 RoleDescriptor element. * * @package simpleSAMLphp * @version $Id$ */ class SAML2_XML_md_RoleDescriptor extends SAML2_SignedElementHelper {
/** * The name of this descriptor element. * * @var string */ private $elementName;
/** * The ID of this element. * * @var string|NULL */ public $ID;
/** * How long this element is valid, as a unix timestamp. * * @var int|NULL */ public $validUntil;
/** * The length of time this element can be cached, as string. * * @var string|NULL */ public $cacheDuration;
/** * List of supported protocols. * * @var array */ public $protocolSupportEnumeration = array();
/** * Error URL for this role. * * @var string|NULL */ public $errorURL;
/** * Extensions on this element. * * Array of extension elements. * * @var array */ public $Extensions = array();
/** * KeyDescriptor elements. * * Array of SAML2_XML_md_KeyDescriptor elements. * * @var array */ public $KeyDescriptor = array();
/** * Organization of this role. * * @var SAML2_XML_md_Organization|NULL */ public $Organization = NULL;
/** * ContactPerson elements for this role. * * Array of SAML2_XML_md_ContactPerson objects. * * @var array */ public $ContactPerson = array();
/** * Initialize a RoleDescriptor. * * @param string $elementName The name of this element. * @param DOMElement|NULL $xml The XML element we should load. */ protected function __construct($elementName, DOMElement $xml = NULL) { assert('is_string($elementName)');
parent::__construct($xml); $this->elementName = $elementName;
if ($xml === NULL) { return; }
if ($xml->hasAttribute('ID')) { $this->ID = $xml->getAttribute('ID'); } if ($xml->hasAttribute('validUntil')) { $this->validUntil = SimpleSAML_Utilities::parseSAML2Time($xml->getAttribute('validUntil')); } if ($xml->hasAttribute('cacheDuration')) { $this->cacheDuration = $xml->getAttribute('cacheDuration'); }
if (!$xml->hasAttribute('protocolSupportEnumeration')) { throw new Exception('Missing protocolSupportEnumeration attribute on ' . $xml->localName); } $this->protocolSupportEnumeration = preg_split('/[\s]+/', $xml->getAttribute('protocolSupportEnumeration'));
if ($xml->hasAttribute('errorURL')) { $this->errorURL = $xml->getAttribute('errorURL'); }
$this->Extensions = SAML2_XML_md_Extensions::getList($xml);
foreach (SAML2_Utils::xpQuery($xml, './saml_metadata:KeyDescriptor') as $kd) { $this->KeyDescriptor[] = new SAML2_XML_md_KeyDescriptor($kd); }
$organization = SAML2_Utils::xpQuery($xml, './saml_metadata:Organization'); if (count($organization) > 1) { throw new Exception('More than one Organization in the entity.'); } elseif (!empty($organization)) { $this->Organization = new SAML2_XML_md_Organization($organization[0]); }
foreach (SAML2_Utils::xpQuery($xml, './saml_metadata:ContactPerson') as $cp) { $this->contactPersons[] = new SAML2_XML_md_ContactPerson($cp); } }
/** * Add this RoleDescriptor to an EntityDescriptor. * * @param DOMElement $parent The EntityDescriptor we should append this endpoint to. * @param string $name The name of the element we should create. */ protected function toXML(DOMElement $parent) { assert('is_null($this->ID) || is_string($this->ID)'); assert('is_null($this->validUntil) || is_int($this->validUntil)'); assert('is_null($this->cacheDuration) || is_string($this->cacheDuration)'); assert('is_array($this->protocolSupportEnumeration)'); assert('is_null($this->errorURL) || is_string($this->errorURL)'); assert('is_array($this->Extensions)'); assert('is_array($this->KeyDescriptor)'); assert('is_null($this->Organization) || $this->Organization instanceof SAML2_XML_md_Organization'); assert('is_array($this->ContactPerson)');
$e = $parent->ownerDocument->createElementNS(SAML2_Const::NS_MD, $this->elementName); $parent->appendChild($e);
if (isset($this->ID)) { $e->setAttribute('ID', $this->ID); }
if (isset($this->validUntil)) { $e->setAttribute('validUntil', gmdate('Y-m-d\TH:i:s\Z', $this->validUntil)); }
if (isset($this->cacheDuration)) { $e->setAttribute('cacheDuration', $this->cacheDuration); }
$e->setAttribute('protocolSupportEnumeration', implode(' ', $this->protocolSupportEnumeration));
if (isset($this->errorURL)) { $e->setAttribute('errorURL', $this->errorURL); }
SAML2_XML_md_Extensions::addList($e, $this->Extensions);
foreach ($this->KeyDescriptor as $kd) { $kd->toXML($e); }
if (isset($this->Organization)) { $this->Organization->toXML($e); }
foreach ($this->ContactPerson as $cp) { $cp->toXML($e); }
return $e; }
}
|