diff options
author | Alessandro Cosentino <cosenal@gmail.com> | 2012-06-07 16:19:25 -0400 |
---|---|---|
committer | Alessandro Cosentino <cosenal@gmail.com> | 2012-06-07 16:19:25 -0400 |
commit | e583df60d3c77d4e7f64a889b8951907c594b922 (patch) | |
tree | 13d48731ecd73a612db1c4e92c59f0d5e0a35c10 /lib | |
parent | b1fc686d2079d63fe5e6cf10124981e69aa73194 (diff) |
creates a superclass collection for feeds and folders
Diffstat (limited to 'lib')
-rw-r--r-- | lib/feed.php | 11 | ||||
-rw-r--r-- | lib/folder.php | 24 | ||||
-rw-r--r-- | lib/foldermapper.php | 13 |
3 files changed, 15 insertions, 33 deletions
diff --git a/lib/feed.php b/lib/feed.php index 311068463..870fd64f6 100644 --- a/lib/feed.php +++ b/lib/feed.php @@ -23,10 +23,9 @@ /** * This class models a feed. */ -class OC_News_Feed { +class OC_News_Feed extends OC_News_Collection { private $url; - private $id; //id of the feed in the database private $spfeed; //encapsulate a SimplePie_Core object private $items; //array that contains all the items of the feed @@ -39,14 +38,6 @@ class OC_News_Feed { } } - public function getId(){ - return $this->id; - } - - public function setId($id){ - $this->id = $id; - } - public function getUrl(){ return $this->url; } diff --git a/lib/folder.php b/lib/folder.php index 6c7c4c2f5..2bdc1fb78 100644 --- a/lib/folder.php +++ b/lib/folder.php @@ -23,18 +23,18 @@ /** * This class models a folder that contains feeds. */ -class OC_News_Folder { +class OC_News_Folder extends OC_News_Collection { private $name; - private $id; - private $feeds; private $children; private $parent; public function __construct($name, $parent = null){ $this->name = $name; - $this->parent = $parent; - $this->feeds = array(); + $this->children = array(); + if ($parent !== null){ + $this->parent = $parent; + } } public function getName(){ @@ -45,23 +45,15 @@ class OC_News_Folder { $this->name = $name; } - public function getId(){ - return $this->id; - } - - public function setId($id){ - $this->id = $id; - } - public function getParentId(){ - if ($this->parent == null){ + if ($this->parent === null){ return 0; } return $this->parent->getId(); } - public function addFeed(OC_News_Feed $feed){ - $this->feeds[] = $feed; + public function addChild(OC_News_Collection $child){ + $this->children[] = $child; } }
\ No newline at end of file diff --git a/lib/foldermapper.php b/lib/foldermapper.php index e9de89341..f4ff6239b 100644 --- a/lib/foldermapper.php +++ b/lib/foldermapper.php @@ -27,19 +27,18 @@ class OC_News_FolderMapper { const tableName = '*PREFIX*news_folders'; + public function root(){ + $root = new OC_News_Folder('All feeds'); + + return $root; + } + /** * @brief Retrieve a feed from the database * @param id The id of the feed in the database table. * @returns */ public function find($id){ - $stmt = OCP\DB::prepare('SELECT * FROM ' . self::tableName . ' WHERE id = ?'); - $result = $stmt->execute(array($id)); - $row = $result->fetchRow(); - $url = $row['url']; - $title = $row['title']; - $feed = new OC_News_Feed($url, $title, null, $id); - return $feed; } /** |