File indexing completed on 2025-01-19 05:21:06
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 * @see Zend_Date 0024 */ 0025 // require_once 'Zend/Date.php'; 0026 0027 /** 0028 * @see Zend_Date 0029 */ 0030 // require_once 'Zend/Uri.php'; 0031 0032 /** 0033 * @see Zend_Feed_Writer 0034 */ 0035 // require_once 'Zend/Feed/Writer.php'; 0036 0037 /** 0038 * @see Zend_Feed_Writer_Entry 0039 */ 0040 // require_once 'Zend/Feed/Writer/Entry.php'; 0041 0042 /** 0043 * @see Zend_Feed_Writer_Deleted 0044 */ 0045 // require_once 'Zend/Feed/Writer/Deleted.php'; 0046 0047 /** 0048 * @see Zend_Feed_Writer_Renderer_Feed_Atom 0049 */ 0050 // require_once 'Zend/Feed/Writer/Renderer/Feed/Atom.php'; 0051 0052 /** 0053 * @see Zend_Feed_Writer_Renderer_Feed_Rss 0054 */ 0055 // require_once 'Zend/Feed/Writer/Renderer/Feed/Rss.php'; 0056 0057 // require_once 'Zend/Feed/Writer/Feed/FeedAbstract.php'; 0058 0059 /** 0060 * @category Zend 0061 * @package Zend_Feed_Writer 0062 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com) 0063 * @license http://framework.zend.com/license/new-bsd New BSD License 0064 */ 0065 class Zend_Feed_Writer_Feed extends Zend_Feed_Writer_Feed_FeedAbstract 0066 implements Iterator, Countable 0067 { 0068 0069 /** 0070 * Contains all entry objects 0071 * 0072 * @var array 0073 */ 0074 protected $_entries = array(); 0075 0076 /** 0077 * A pointer for the iterator to keep track of the entries array 0078 * 0079 * @var int 0080 */ 0081 protected $_entriesKey = 0; 0082 0083 /** 0084 * Creates a new Zend_Feed_Writer_Entry data container for use. This is NOT 0085 * added to the current feed automatically, but is necessary to create a 0086 * container with some initial values preset based on the current feed data. 0087 * 0088 * @return Zend_Feed_Writer_Entry 0089 */ 0090 public function createEntry() 0091 { 0092 $entry = new Zend_Feed_Writer_Entry; 0093 if ($this->getEncoding()) { 0094 $entry->setEncoding($this->getEncoding()); 0095 } 0096 $entry->setType($this->getType()); 0097 return $entry; 0098 } 0099 0100 /** 0101 * Appends a Zend_Feed_Writer_Deleted object representing a new entry tombstone 0102 * to the feed data container's internal group of entries. 0103 * 0104 * @param Zend_Feed_Writer_Deleted $entry 0105 */ 0106 public function addTombstone(Zend_Feed_Writer_Deleted $deleted) 0107 { 0108 $this->_entries[] = $deleted; 0109 } 0110 0111 /** 0112 * Creates a new Zend_Feed_Writer_Deleted data container for use. This is NOT 0113 * added to the current feed automatically, but is necessary to create a 0114 * container with some initial values preset based on the current feed data. 0115 * 0116 * @return Zend_Feed_Writer_Deleted 0117 */ 0118 public function createTombstone() 0119 { 0120 $deleted = new Zend_Feed_Writer_Deleted; 0121 if ($this->getEncoding()) { 0122 $deleted->setEncoding($this->getEncoding()); 0123 } 0124 $deleted->setType($this->getType()); 0125 return $deleted; 0126 } 0127 0128 /** 0129 * Appends a Zend_Feed_Writer_Entry object representing a new entry/item 0130 * the feed data container's internal group of entries. 0131 * 0132 * @param Zend_Feed_Writer_Entry $entry 0133 */ 0134 public function addEntry(Zend_Feed_Writer_Entry $entry) 0135 { 0136 $this->_entries[] = $entry; 0137 } 0138 0139 /** 0140 * Removes a specific indexed entry from the internal queue. Entries must be 0141 * added to a feed container in order to be indexed. 0142 * 0143 * @param int $index 0144 */ 0145 public function removeEntry($index) 0146 { 0147 if (isset($this->_entries[$index])) { 0148 unset($this->_entries[$index]); 0149 } 0150 // require_once 'Zend/Feed/Exception.php'; 0151 throw new Zend_Feed_Exception('Undefined index: ' . $index . '. Entry does not exist.'); 0152 } 0153 0154 /** 0155 * Retrieve a specific indexed entry from the internal queue. Entries must be 0156 * added to a feed container in order to be indexed. 0157 * 0158 * @param int $index 0159 */ 0160 public function getEntry($index = 0) 0161 { 0162 if (isset($this->_entries[$index])) { 0163 return $this->_entries[$index]; 0164 } 0165 // require_once 'Zend/Feed/Exception.php'; 0166 throw new Zend_Feed_Exception('Undefined index: ' . $index . '. Entry does not exist.'); 0167 } 0168 0169 /** 0170 * Orders all indexed entries by date, thus offering date ordered readable 0171 * content where a parser (or Homo Sapien) ignores the generic rule that 0172 * XML element order is irrelevant and has no intrinsic meaning. 0173 * 0174 * Using this method will alter the original indexation. 0175 * 0176 * @return void 0177 */ 0178 public function orderByDate() 0179 { 0180 /** 0181 * Could do with some improvement for performance perhaps 0182 */ 0183 $timestamp = time(); 0184 $entries = array(); 0185 foreach ($this->_entries as $entry) { 0186 if ($entry->getDateModified()) { 0187 $timestamp = (int) $entry->getDateModified()->get(Zend_Date::TIMESTAMP); 0188 } elseif ($entry->getDateCreated()) { 0189 $timestamp = (int) $entry->getDateCreated()->get(Zend_Date::TIMESTAMP); 0190 } 0191 $entries[$timestamp] = $entry; 0192 } 0193 krsort($entries, SORT_NUMERIC); 0194 $this->_entries = array_values($entries); 0195 } 0196 0197 /** 0198 * Get the number of feed entries. 0199 * Required by the Iterator interface. 0200 * 0201 * @return int 0202 */ 0203 public function count() 0204 { 0205 return count($this->_entries); 0206 } 0207 0208 /** 0209 * Return the current entry 0210 * 0211 * @return Zend_Feed_Reader_Entry_Interface 0212 */ 0213 public function current() 0214 { 0215 return $this->_entries[$this->key()]; 0216 } 0217 0218 /** 0219 * Return the current feed key 0220 * 0221 * @return unknown 0222 */ 0223 public function key() 0224 { 0225 return $this->_entriesKey; 0226 } 0227 0228 /** 0229 * Move the feed pointer forward 0230 * 0231 * @return void 0232 */ 0233 public function next() 0234 { 0235 ++$this->_entriesKey; 0236 } 0237 0238 /** 0239 * Reset the pointer in the feed object 0240 * 0241 * @return void 0242 */ 0243 public function rewind() 0244 { 0245 $this->_entriesKey = 0; 0246 } 0247 0248 /** 0249 * Check to see if the iterator is still valid 0250 * 0251 * @return boolean 0252 */ 0253 public function valid() 0254 { 0255 return 0 <= $this->_entriesKey && $this->_entriesKey < $this->count(); 0256 } 0257 0258 /** 0259 * Attempt to build and return the feed resulting from the data set 0260 * 0261 * @param string $type The feed type "rss" or "atom" to export as 0262 * @param bool $ignoreExceptions 0263 * @return string 0264 */ 0265 public function export($type, $ignoreExceptions = false) 0266 { 0267 $this->setType(strtolower($type)); 0268 $type = ucfirst($this->getType()); 0269 if ($type !== 'Rss' && $type !== 'Atom') { 0270 // require_once 'Zend/Feed/Exception.php'; 0271 throw new Zend_Feed_Exception('Invalid feed type specified: ' . $type . '.' 0272 . ' Should be one of "rss" or "atom".'); 0273 } 0274 $renderClass = 'Zend_Feed_Writer_Renderer_Feed_' . $type; 0275 $renderer = new $renderClass($this); 0276 if ($ignoreExceptions) { 0277 $renderer->ignoreExceptions(); 0278 } 0279 return $renderer->render()->saveXml(); 0280 } 0281 0282 }