![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/vendor/litesaml/lightsaml/src/Model/XmlDSig/ |
<?php namespace LightSaml\Model\XmlDSig; use LightSaml\Error\LightSamlSecurityException; use LightSaml\Model\Context\DeserializationContext; use LightSaml\Model\Context\SerializationContext; use RobRichards\XMLSecLibs\XMLSecurityKey; class SignatureStringReader extends AbstractSignatureReader { /** @var string */ protected $signature; /** @var string */ protected $algorithm; /** @var string */ protected $data; /** * @param string|null $signature * @param string|null $algorithm * @param string|null $data */ public function __construct($signature = null, $algorithm = null, $data = null) { $this->signature = $signature; $this->algorithm = $algorithm; $this->data = $data; } /** * @param string $algorithm */ public function setAlgorithm($algorithm) { $this->algorithm = (string) $algorithm; } /** * @return string */ public function getAlgorithm() { return $this->algorithm; } /** * @param string $data */ public function setData($data) { $this->data = (string) $data; } /** * @return string */ public function getData() { return $this->data; } /** * @param string $signature */ public function setSignature($signature) { $this->signature = (string) $signature; } /** * @return string */ public function getSignature() { return $this->signature; } /** * @return bool True if validated, False if validation was not performed * * @throws LightSamlSecurityException If validation fails */ public function validate(XMLSecurityKey $key) { if (null == $this->getSignature()) { return false; } $key = $this->castKeyIfNecessary($key); $signature = base64_decode($this->getSignature()); if (false == $key->verifySignature($this->getData(), $signature)) { throw new LightSamlSecurityException('Unable to validate signature on query string'); } return true; } /** * @throws \LogicException */ public function serialize(\DOMNode $parent, SerializationContext $context) { throw new \LogicException('SignatureStringReader can not be serialized'); } public function deserialize(\DOMNode $node, DeserializationContext $context) { throw new \LogicException('SignatureStringReader can not be deserialized'); } }