1
0
mirror of https://gitee.com/koogua/course-tencent-cloud.git synced 2025-06-23 03:50:56 +08:00
course-tencent-cloud/app/Caches/CourseTopicList.php
xiaochong0302 5985576065 1.优化语法层面
2.增加推荐课程|文章|考试widget
2023-05-23 17:27:14 +08:00

74 lines
1.4 KiB
PHP

<?php
/**
* @copyright Copyright (c) 2021 深圳市酷瓜软件有限公司
* @license https://opensource.org/licenses/GPL-2.0
* @link https://www.koogua.com
*/
namespace App\Caches;
use App\Models\Topic as TopicModel;
use Phalcon\Mvc\Model\Resultset;
use Phalcon\Mvc\Model\ResultsetInterface;
class CourseTopicList extends Cache
{
protected $lifetime = 86400;
public function getLifetime()
{
return $this->lifetime;
}
public function getKey($id = null)
{
return "course_topic_list:{$id}";
}
public function getContent($id = null)
{
$topics = $this->findTopics(5);
if ($topics->count() == 0) {
return [];
}
return $this->handleContent($topics);
}
/**
* @param TopicModel[] $topics
* @return array
*/
public function handleContent($topics)
{
$result = [];
foreach ($topics as $topic) {
$result[] = [
'id' => $topic->id,
'title' => $topic->title,
];
}
return $result;
}
/**
* @param int $limit
* @return ResultsetInterface|Resultset|TopicModel[]
*/
public function findTopics($limit = 5)
{
return TopicModel::query()
->where('published = 1')
->andWhere('deleted = 0')
->orderBy('RAND()')
->limit($limit)
->execute();
}
}