*/ class Post { /** * The format the comment categories should follow. */ const COMMENT_CATEGORY_FORMAT = "news-%s-%u"; /** * The id of this news post. * @var int */ public $id = 0; /** * The category this post is part of. * @var string */ public $category = ""; /** * The user who made this post. * @var int */ public $user = 0; /** * The timestamp when this post was made. * @var int */ public $time = 0; /** * The title of this news post. * @var string */ public $title = ""; /** * The content of this news post. * @var string */ public $text = ""; /** * A cache of the amount of comments this post has. * @var int */ private $commentCountCache = 0; /** * A cache of comments. * @var array */ private $commentsCache = []; /** * Constructor. * @param int $id */ public function __construct($id = 0) { // Get comment data from the database $data = DB::table('news') ->where('news_id', $id) ->get(); // Check if anything was returned and assign data if ($data) { $data = $data[0]; $this->id = $data->news_id; $this->category = $data->news_category; $this->user = $data->user_id; $this->time = $data->news_timestamp; $this->title = $data->news_title; $this->text = $data->news_content; } } /** * Saving changes to this news post. */ public function save() { // Create submission data, insert and update take the same format $data = [ 'news_category' => $this->category, 'user_id' => $this->user, 'news_timestamp' => $this->time, 'news_title' => $this->title, 'news_content' => $this->text, ]; // Update if id isn't 0 if ($this->id) { DB::table('news') ->where('news_id', $this->id) ->update($data); } else { $this->id = DB::table('news') ->insertGetId($data); } } /** * Deleting this news post. */ public function delete() { DB::table('news') ->where('news_id', $this->id) ->delete(); $this->id = 0; } /** * Get the user object of the poster. * @return User */ public function userData() { return User::construct($this->user); } /** * Count the amount of comments this post has. * @return int */ public function commentCount() { if (!$this->commentCountCache) { $this->commentCountCache = DB::table('comments') ->where('comment_category', sprintf(self::COMMENT_CATEGORY_FORMAT, $this->category, $this->id)) ->count(); } return $this->commentCountCache; } /** * Get the comments on this post. * @return array */ public function comments() { if (!$this->commentsCache) { $commentIds = DB::table('comments') ->where('comment_category', sprintf(self::COMMENT_CATEGORY_FORMAT, $this->category, $this->id)) ->orderBy('comment_id', 'desc') ->where('comment_reply_to', 0) ->get(['comment_id']); $commentIds = array_column($commentIds, 'comment_id'); foreach ($commentIds as $comment) { $this->commentsCache[$comment] = new Comment($comment); } } return $this->commentsCache; } }