File indexing completed on 2025-01-19 05:21:07

0001 <?php
0002 /**
0003  * Zend Framework
0004  *
0005  * LICENSE
0006  *
0007  * This source file is subject to the new BSD license that is bundled
0008  * with this package in the file LICENSE.txt.
0009  * It is also available through the world-wide-web at this URL:
0010  * http://framework.zend.com/license/new-bsd
0011  * If you did not receive a copy of the license and are unable to
0012  * obtain it through the world-wide-web, please send an email
0013  * to license@zend.com so we can send you a copy immediately.
0014  *
0015  * @category   Zend
0016  * @package    Zend_Feed_Writer
0017  * @copyright  Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
0018  * @license    http://framework.zend.com/license/new-bsd     New BSD License
0019  * @version    $Id$
0020  */
0021 
0022 /**
0023  * @category   Zend
0024  * @package    Zend_Feed_Writer
0025  * @copyright  Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
0026  * @license    http://framework.zend.com/license/new-bsd     New BSD License
0027  */
0028 class Zend_Feed_Writer
0029 {
0030     /**
0031      * Namespace constants
0032      */
0033     const NAMESPACE_ATOM_03  = 'http://purl.org/atom/ns#';
0034     const NAMESPACE_ATOM_10  = 'http://www.w3.org/2005/Atom';
0035     const NAMESPACE_RDF      = 'http://www.w3.org/1999/02/22-rdf-syntax-ns#';
0036     const NAMESPACE_RSS_090  = 'http://my.netscape.com/rdf/simple/0.9/';
0037     const NAMESPACE_RSS_10   = 'http://purl.org/rss/1.0/';
0038 
0039     /**
0040      * Feed type constants
0041      */
0042     const TYPE_ANY              = 'any';
0043     const TYPE_ATOM_03          = 'atom-03';
0044     const TYPE_ATOM_10          = 'atom-10';
0045     const TYPE_ATOM_ANY         = 'atom';
0046     const TYPE_RSS_090          = 'rss-090';
0047     const TYPE_RSS_091          = 'rss-091';
0048     const TYPE_RSS_091_NETSCAPE = 'rss-091n';
0049     const TYPE_RSS_091_USERLAND = 'rss-091u';
0050     const TYPE_RSS_092          = 'rss-092';
0051     const TYPE_RSS_093          = 'rss-093';
0052     const TYPE_RSS_094          = 'rss-094';
0053     const TYPE_RSS_10           = 'rss-10';
0054     const TYPE_RSS_20           = 'rss-20';
0055     const TYPE_RSS_ANY          = 'rss';
0056 
0057     /**
0058      * PluginLoader instance used by component
0059      *
0060      * @var Zend_Loader_PluginLoader_Interface
0061      */
0062     protected static $_pluginLoader = null;
0063 
0064     /**
0065      * Path on which to search for Extension classes
0066      *
0067      * @var array
0068      */
0069     protected static $_prefixPaths = array();
0070 
0071     /**
0072      * Array of registered extensions by class postfix (after the base class
0073      * name) across four categories - data containers and renderers for entry
0074      * and feed levels.
0075      *
0076      * @var array
0077      */
0078     protected static $_extensions = array(
0079         'entry'         => array(),
0080         'feed'          => array(),
0081         'entryRenderer' => array(),
0082         'feedRenderer'  => array(),
0083     );
0084 
0085     /**
0086      * Set plugin loader for use with Extensions
0087      *
0088      * @param  Zend_Loader_PluginLoader_Interface
0089      */
0090     public static function setPluginLoader(Zend_Loader_PluginLoader_Interface $loader)
0091     {
0092         self::$_pluginLoader = $loader;
0093     }
0094 
0095     /**
0096      * Get plugin loader for use with Extensions
0097      *
0098      * @return  Zend_Loader_PluginLoader_Interface
0099      */
0100     public static function getPluginLoader()
0101     {
0102         if (!isset(self::$_pluginLoader)) {
0103             // require_once 'Zend/Loader/PluginLoader.php';
0104             self::$_pluginLoader = new Zend_Loader_PluginLoader(array(
0105                 'Zend_Feed_Writer_Extension_' => 'Zend/Feed/Writer/Extension/',
0106             ));
0107         }
0108         return self::$_pluginLoader;
0109     }
0110 
0111     /**
0112      * Add prefix path for loading Extensions
0113      *
0114      * @param  string $prefix
0115      * @param  string $path
0116      * @return void
0117      */
0118     public static function addPrefixPath($prefix, $path)
0119     {
0120         $prefix = rtrim($prefix, '_');
0121         $path   = rtrim($path, DIRECTORY_SEPARATOR);
0122         self::getPluginLoader()->addPrefixPath($prefix, $path);
0123     }
0124 
0125     /**
0126      * Add multiple Extension prefix paths at once
0127      *
0128      * @param  array $spec
0129      * @return void
0130      */
0131     public static function addPrefixPaths(array $spec)
0132     {
0133         if (isset($spec['prefix']) && isset($spec['path'])) {
0134             self::addPrefixPath($spec['prefix'], $spec['path']);
0135         }
0136         foreach ($spec as $prefixPath) {
0137             if (isset($prefixPath['prefix']) && isset($prefixPath['path'])) {
0138                 self::addPrefixPath($prefixPath['prefix'], $prefixPath['path']);
0139             }
0140         }
0141     }
0142 
0143     /**
0144      * Register an Extension by name
0145      *
0146      * @param  string $name
0147      * @return void
0148      * @throws Zend_Feed_Exception if unable to resolve Extension class
0149      */
0150     public static function registerExtension($name)
0151     {
0152         $feedName  = $name . '_Feed';
0153         $entryName = $name . '_Entry';
0154         $feedRendererName  = $name . '_Renderer_Feed';
0155         $entryRendererName = $name . '_Renderer_Entry';
0156         if (self::isRegistered($name)) {
0157             if (self::getPluginLoader()->isLoaded($feedName)
0158                 || self::getPluginLoader()->isLoaded($entryName)
0159                 || self::getPluginLoader()->isLoaded($feedRendererName)
0160                 || self::getPluginLoader()->isLoaded($entryRendererName)
0161             ) {
0162                 return;
0163             }
0164         }
0165         try {
0166             self::getPluginLoader()->load($feedName);
0167             self::$_extensions['feed'][] = $feedName;
0168         } catch (Zend_Loader_PluginLoader_Exception $e) {
0169         }
0170         try {
0171             self::getPluginLoader()->load($entryName);
0172             self::$_extensions['entry'][] = $entryName;
0173         } catch (Zend_Loader_PluginLoader_Exception $e) {
0174         }
0175         try {
0176             self::getPluginLoader()->load($feedRendererName);
0177             self::$_extensions['feedRenderer'][] = $feedRendererName;
0178         } catch (Zend_Loader_PluginLoader_Exception $e) {
0179         }
0180         try {
0181             self::getPluginLoader()->load($entryRendererName);
0182             self::$_extensions['entryRenderer'][] = $entryRendererName;
0183         } catch (Zend_Loader_PluginLoader_Exception $e) {
0184         }
0185         if (!self::getPluginLoader()->isLoaded($feedName)
0186             && !self::getPluginLoader()->isLoaded($entryName)
0187             && !self::getPluginLoader()->isLoaded($feedRendererName)
0188             && !self::getPluginLoader()->isLoaded($entryRendererName)
0189         ) {
0190             // require_once 'Zend/Feed/Exception.php';
0191             throw new Zend_Feed_Exception('Could not load extension: ' . $name
0192                 . 'using Plugin Loader. Check prefix paths are configured and extension exists.');
0193         }
0194     }
0195 
0196     /**
0197      * Is a given named Extension registered?
0198      *
0199      * @param  string $extensionName
0200      * @return boolean
0201      */
0202     public static function isRegistered($extensionName)
0203     {
0204         $feedName  = $extensionName . '_Feed';
0205         $entryName = $extensionName . '_Entry';
0206         $feedRendererName  = $extensionName . '_Renderer_Feed';
0207         $entryRendererName = $extensionName . '_Renderer_Entry';
0208         if (in_array($feedName, self::$_extensions['feed'])
0209             || in_array($entryName, self::$_extensions['entry'])
0210             || in_array($feedRendererName, self::$_extensions['feedRenderer'])
0211             || in_array($entryRendererName, self::$_extensions['entryRenderer'])
0212         ) {
0213             return true;
0214         }
0215         return false;
0216     }
0217 
0218     /**
0219      * Get a list of extensions
0220      *
0221      * @return array
0222      */
0223     public static function getExtensions()
0224     {
0225         return self::$_extensions;
0226     }
0227 
0228     /**
0229      * Reset class state to defaults
0230      *
0231      * @return void
0232      */
0233     public static function reset()
0234     {
0235         self::$_pluginLoader = null;
0236         self::$_prefixPaths  = array();
0237         self::$_extensions   = array(
0238             'entry'         => array(),
0239             'feed'          => array(),
0240             'entryRenderer' => array(),
0241             'feedRenderer'  => array(),
0242         );
0243     }
0244 
0245     /**
0246      * Register core (default) extensions
0247      *
0248      * @return void
0249      */
0250     public static function registerCoreExtensions()
0251     {
0252         self::registerExtension('DublinCore');
0253         self::registerExtension('Content');
0254         self::registerExtension('Atom');
0255         self::registerExtension('Slash');
0256         self::registerExtension('WellFormedWeb');
0257         self::registerExtension('Threading');
0258         self::registerExtension('ITunes');
0259     }
0260 
0261     public static function lcfirst($str)
0262     {
0263         $str[0] = strtolower($str[0]);
0264         return $str;
0265     }
0266 
0267 }