1
0
mirror of https://gitee.com/koogua/course-tencent-cloud.git synced 2025-07-15 12:52:21 +08:00
2023-08-28 15:55:40 +08:00

58 lines
1.3 KiB
PHP

<?php
/**
* @copyright Copyright (c) 2023 深圳市酷瓜软件有限公司
* @license https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
* @link https://www.koogua.com
*/
namespace App\Console\Migrations;
use App\Models\Course as CourseModel;
use App\Repos\Chapter as ChapterRepo;
use App\Repos\Course as CourseRepo;
class V20230817240809 extends Migration
{
public function run()
{
$this->handleCourseResourceCount();
}
protected function handleCourseResourceCount()
{
$courses = CourseModel::find();
if ($courses->count() == 0) return;
foreach ($courses as $course) {
if ($course->resource_count > 0) {
$this->recountCourseResources($course);
}
}
}
protected function recountCourseResources(CourseModel $course)
{
$courseRepo = new CourseRepo();
$lessons = $courseRepo->findLessons($course->id);
$chapterRepo = new ChapterRepo();
$resourceCount = 0;
if ($lessons->count() > 0) {
foreach ($lessons as $lesson) {
if ($lesson->deleted == 0) {
$resourceCount += $chapterRepo->countResources($lesson->id);
}
}
}
$course->resource_count = $resourceCount;
$course->update();
}
}