<?php /** * Zend Framework * * LICENSE * * This source file is subject to the new BSD license that is bundled * with this package in the file LICENSE.txt. * It is also available through the world-wide-web at this URL: * http://framework.zend.com/license/new-bsd * If you did not receive a copy of the license and are unable to * obtain it through the world-wide-web, please send an email * to [email protected] so we can send you a copy immediately. * * @category Zend * @package Zend_InfoCard * @subpackage Zend_InfoCard_Xml * @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com) * @license http://framework.zend.com/license/new-bsd New BSD License * @version $Id: Abstract.php 24594 2012-01-05 21:27:01Z matthew $ */ /** * Zend_InfoCard_Xml_Element */ require_once 'Zend/InfoCard/Xml/Element.php'; /** * Zend_InfoCard_Xml_KeyInfo */ require_once 'Zend/InfoCard/Xml/KeyInfo.php'; /** * An abstract class representing a generic EncryptedData XML block. This class is extended * into a specific type of EncryptedData XML block (i.e. XmlEnc) as necessary * * @category Zend * @package Zend_InfoCard * @subpackage Zend_InfoCard_Xml * @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com) * @license http://framework.zend.com/license/new-bsd New BSD License */ abstract class Zend_InfoCard_Xml_EncryptedData_Abstract extends Zend_InfoCard_Xml_Element { /** * Returns the KeyInfo Block * * @return Zend_InfoCard_Xml_KeyInfo_Abstract */ public function getKeyInfo() { return Zend_InfoCard_Xml_KeyInfo::getInstance($this->KeyInfo[0]); } /** * Return the Encryption method used to encrypt the assertion document * (the symmetric cipher) * * @throws Zend_InfoCard_Xml_Exception * @return string The URI of the Symmetric Encryption Method used */ public function getEncryptionMethod() { /** * @todo This is pretty hacky unless we can always be confident that the first * EncryptionMethod block is the correct one (the AES or compariable symetric algorithm).. * the second is the PK method if provided. */ list($encryption_method) = $this->xpath("//enc:EncryptionMethod"); if(!($encryption_method instanceof Zend_InfoCard_Xml_Element)) { throw new Zend_InfoCard_Xml_Exception("Unable to find the enc:EncryptionMethod symmetric encryption block"); } $dom = self::convertToDOM($encryption_method); if(!$dom->hasAttribute('Algorithm')) { throw new Zend_InfoCard_Xml_Exception("Unable to determine the encryption algorithm in the Symmetric enc:EncryptionMethod XML block"); } return $dom->getAttribute('Algorithm'); } /** * Returns the value of the encrypted block * * @return string the value of the encrypted CipherValue block */ abstract function getCipherValue(); }
| # | Change | User | Description | Committed | |
|---|---|---|---|---|---|
| #1 | 16170 | perforce_software | Move Chronicle files to follow new path scheme for branching. | ||
| //guest/perforce_software/chronicle/library/Zend/InfoCard/Xml/EncryptedData/Abstract.php | |||||
| #1 | 8972 | Matt Attaway | Initial add of the Chronicle source code | ||