53 lines
No EOL
1.2 KiB
PHP
53 lines
No EOL
1.2 KiB
PHP
<?php
|
|
|
|
class Mapper_BlogPost extends Fiktiv_Data_Mapper_DbTable_Abstract
|
|
{
|
|
|
|
protected $_mapperUser = null;
|
|
|
|
public function __construct($dbtable = null) {
|
|
parent::__construct($dbtable);
|
|
|
|
$this->_mapperUser = new Mapper_User(new Table_User());
|
|
}
|
|
|
|
protected function _createBlogPost($obj)
|
|
{
|
|
$blogPost = new BlogPost();
|
|
|
|
if ($obj instanceof Zend_Db_Table_Row) {
|
|
|
|
$blogPost->setTitle($obj->title);
|
|
$blogPost->setContent($obj->content);
|
|
$blogPost->setPubDate(new Fiktiv_Date($obj->pubDate));
|
|
$blogPost->setAuthor($this->_mapperUser->findById($obj->userId));
|
|
|
|
} else {
|
|
$blogPost = null;
|
|
}
|
|
|
|
return $blogPost;
|
|
}
|
|
|
|
public function findAllPostByAuthor($user)
|
|
{
|
|
if ($user instanceof User) {
|
|
return $this->_createBlogPost($this->_dbTable->findByUser($user->getId()));
|
|
}
|
|
}
|
|
|
|
public function findAll($limit = null)
|
|
{
|
|
|
|
$rows = $this->_dbTable->fetchAll(null, 'pubDate DESC');
|
|
|
|
$posts = array();
|
|
|
|
foreach ($rows as $row) {
|
|
$posts[] = $this->_createBlogPost($row);
|
|
}
|
|
|
|
return $posts;
|
|
}
|
|
|
|
} |