diff -r 000000000000 -r 4eba9c11703f web/Zend/Feed/Builder/Entry.php
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/web/Zend/Feed/Builder/Entry.php Mon Dec 13 18:29:26 2010 +0100
@@ -0,0 +1,297 @@
+offsetSet('title', $title);
+ $this->offsetSet('link', $link);
+ $this->offsetSet('description', $description);
+ $this->setLastUpdate(time());
+ }
+
+ /**
+ * Read only properties accessor
+ *
+ * @param string $name property to read
+ * @return mixed
+ */
+ public function __get($name)
+ {
+ if (!$this->offsetExists($name)) {
+ return NULL;
+ }
+
+ return $this->offsetGet($name);
+ }
+
+ /**
+ * Write properties accessor
+ *
+ * @param string $name name of the property to set
+ * @param mixed $value value to set
+ * @return void
+ */
+ public function __set($name, $value)
+ {
+ $this->offsetSet($name, $value);
+ }
+
+ /**
+ * Isset accessor
+ *
+ * @param string $key
+ * @return boolean
+ */
+ public function __isset($key)
+ {
+ return $this->offsetExists($key);
+ }
+
+ /**
+ * Unset accessor
+ *
+ * @param string $key
+ * @return void
+ */
+ public function __unset($key)
+ {
+ if ($this->offsetExists($key)) {
+ $this->offsetUnset($key);
+ }
+ }
+
+ /**
+ * Sets the author of the entry
+ *
+ * @param string $author
+ * @return Zend_Feed_Builder_Entry
+ */
+ public function setAuthor($author)
+ {
+ $this->offsetSet('author', $author);
+ return $this;
+ }
+
+ /**
+ * Sets the id/guid of the entry
+ *
+ * @param string $id
+ * @return Zend_Feed_Builder_Entry
+ */
+ public function setId($id)
+ {
+ $this->offsetSet('guid', $id);
+ return $this;
+ }
+
+ /**
+ * Sets the full html content of the entry
+ *
+ * @param string $content
+ * @return Zend_Feed_Builder_Entry
+ */
+ public function setContent($content)
+ {
+ $this->offsetSet('content', $content);
+ return $this;
+ }
+
+ /**
+ * Timestamp of the update date
+ *
+ * @param int $lastUpdate
+ * @return Zend_Feed_Builder_Entry
+ */
+ public function setLastUpdate($lastUpdate)
+ {
+ $this->offsetSet('lastUpdate', $lastUpdate);
+ return $this;
+ }
+
+ /**
+ * Sets the url of the commented page associated to the entry
+ *
+ * @param string $comments
+ * @return Zend_Feed_Builder_Entry
+ */
+ public function setCommentsUrl($comments)
+ {
+ $this->offsetSet('comments', $comments);
+ return $this;
+ }
+
+ /**
+ * Sets the url of the comments feed link
+ *
+ * @param string $commentRss
+ * @return Zend_Feed_Builder_Entry
+ */
+ public function setCommentsRssUrl($commentRss)
+ {
+ $this->offsetSet('commentRss', $commentRss);
+ return $this;
+ }
+
+ /**
+ * Defines a reference to the original source
+ *
+ * @param string $title
+ * @param string $url
+ * @return Zend_Feed_Builder_Entry
+ */
+ public function setSource($title, $url)
+ {
+ $this->offsetSet('source', array('title' => $title,
+ 'url' => $url));
+ return $this;
+ }
+
+ /**
+ * Sets the categories of the entry
+ * Format of the array:
+ *
+ * array(
+ * array(
+ * 'term' => 'first category label',
+ * 'scheme' => 'url that identifies a categorization scheme' // optional
+ * ),
+ * // second category and so one
+ * )
+ *
+ *
+ * @param array $categories
+ * @return Zend_Feed_Builder_Entry
+ */
+ public function setCategories(array $categories)
+ {
+ foreach ($categories as $category) {
+ $this->addCategory($category);
+ }
+ return $this;
+ }
+
+ /**
+ * Add a category to the entry
+ *
+ * @param array $category see Zend_Feed_Builder_Entry::setCategories() for format
+ * @return Zend_Feed_Builder_Entry
+ * @throws Zend_Feed_Builder_Exception
+ */
+ public function addCategory(array $category)
+ {
+ if (empty($category['term'])) {
+ /**
+ * @see Zend_Feed_Builder_Exception
+ */
+ require_once 'Zend/Feed/Builder/Exception.php';
+ throw new Zend_Feed_Builder_Exception("you have to define the name of the category");
+ }
+
+ if (!$this->offsetExists('category')) {
+ $categories = array($category);
+ } else {
+ $categories = $this->offsetGet('category');
+ $categories[] = $category;
+ }
+ $this->offsetSet('category', $categories);
+ return $this;
+ }
+
+ /**
+ * Sets the enclosures of the entry
+ * Format of the array:
+ *
+ * array(
+ * array(
+ * 'url' => 'url of the linked enclosure',
+ * 'type' => 'mime type of the enclosure' // optional
+ * 'length' => 'length of the linked content in octets' // optional
+ * ),
+ * // second enclosure and so one
+ * )
+ *
+ *
+ * @param array $enclosures
+ * @return Zend_Feed_Builder_Entry
+ * @throws Zend_Feed_Builder_Exception
+ */
+ public function setEnclosures(array $enclosures)
+ {
+ foreach ($enclosures as $enclosure) {
+ if (empty($enclosure['url'])) {
+ /**
+ * @see Zend_Feed_Builder_Exception
+ */
+ require_once 'Zend/Feed/Builder/Exception.php';
+ throw new Zend_Feed_Builder_Exception("you have to supply an url for your enclosure");
+ }
+ $type = isset($enclosure['type']) ? $enclosure['type'] : '';
+ $length = isset($enclosure['length']) ? $enclosure['length'] : '';
+ $this->addEnclosure($enclosure['url'], $type, $length);
+ }
+ return $this;
+ }
+
+ /**
+ * Add an enclosure to the entry
+ *
+ * @param string $url
+ * @param string $type
+ * @param string $length
+ * @return Zend_Feed_Builder_Entry
+ */
+ public function addEnclosure($url, $type = '', $length = '')
+ {
+ if (!$this->offsetExists('enclosure')) {
+ $enclosure = array();
+ } else {
+ $enclosure = $this->offsetGet('enclosure');
+ }
+ $enclosure[] = array('url' => $url,
+ 'type' => $type,
+ 'length' => $length);
+ $this->offsetSet('enclosure', $enclosure);
+ return $this;
+ }
+}