1
0
mirror of https://gitee.com/koogua/course-tencent-cloud.git synced 2025-06-25 04:07:17 +08:00
course-tencent-cloud/app/Console/Tasks/SyncCourseStatTask.php
2021-08-12 16:26:00 +08:00

52 lines
1.1 KiB
PHP

<?php
/**
* @copyright Copyright (c) 2021 深圳市酷瓜软件有限公司
* @license https://opensource.org/licenses/GPL-2.0
* @link https://www.koogua.com
*/
namespace App\Console\Tasks;
use App\Models\Course as CourseModel;
use App\Repos\Course as CourseRepo;
class SyncCourseStatTask extends Task
{
public function mainAction()
{
$courses = $this->findCourses();
echo sprintf('pending courses: %s', $courses->count()) . PHP_EOL;
if ($courses->count() == 0) return;
echo '------ start sync course stat task ------' . PHP_EOL;
foreach ($courses as $course) {
$this->recountUsers($course);
}
echo '------ end sync course stat task ------' . PHP_EOL;
}
protected function recountUsers(CourseModel $course)
{
$courseRepo = new CourseRepo();
$userCount = $courseRepo->countUsers($course->id);
$course->user_count = $userCount;
$course->update();
}
protected function findCourses()
{
return CourseModel::query()
->where('published = 1')
->execute();
}
}