mirror of
https://gitee.com/koogua/course-tencent-cloud.git
synced 2025-06-28 21:31:37 +08:00
* !6 develop->master 1.1.0 * 更新版本号 * 完善后台今日统计,增加权限白名单,增加后台首页菜单,调整后台登录页样式 * Merge branch 'koogua/I1XFCF' of https://gitee.com/koogua/course-tencen… * 前台学习资料部分完成 * !2 后台运营统计合并 * 后台学习资料部分完成 * Merge branch 'master' into develop * Merge branch 'master' of https://github.com/xiaochong0302/course-tencent-cloud * 1.增加changelog.md * 1.简化部分路由地址 * Merge pull request #2 from xiaochong0302/dependabot/composer/symfony/h… * Bump symfony/http-foundation from 4.3.4 to 5.1.6 * !7 纠正迁移文件和代码实际使用字段不一致 * 纠正迁移文件和时间代码中字段不一致 * 更新版本号 * 完善后台今日统计,增加权限白名单,增加后台首页菜单,调整后台登录页样式 * Merge branch 'koogua/I1XFCF' of https://gitee.com/koogua/course-tencen… * 前台学习资料部分完成 * !2 后台运营统计合并 * 后台学习资料部分完成 * Merge branch 'master' into develop * Merge branch 'master' of https://github.com/xiaochong0302/course-tencent-cloud * 1.增加changelog.md * 1.简化部分路由地址 * Merge pull request #2 from xiaochong0302/dependabot/composer/symfony/h… * Bump symfony/http-foundation from 4.3.4 to 5.1.6 * !9 修正插入数据不一致以及后台菜单参数类型报错 * 1.修正插入的管理帐号数据 * 纠正迁移文件和时间代码中字段不一致 * 更新版本号 * 完善后台今日统计,增加权限白名单,增加后台首页菜单,调整后台登录页样式 * Merge branch 'koogua/I1XFCF' of https://gitee.com/koogua/course-tencen… * 前台学习资料部分完成 * !2 后台运营统计合并 * 后台学习资料部分完成 * Merge branch 'master' into develop * Merge branch 'master' of https://github.com/xiaochong0302/course-tencent-cloud * 1.增加changelog.md * 1.简化部分路由地址 * Merge pull request #2 from xiaochong0302/dependabot/composer/symfony/h… * Bump symfony/http-foundation from 4.3.4 to 5.1.6 * !12 修正退款项目空白以及弹窗自适应 * 修复退款项目空白,以及弹窗高度自适应 * !13 修正退款项目空白以及弹窗自适应 * 修复退款项目空白,以及弹窗高度自适应 * !14 修正点击退款404 * 修复退款项目空白,以及弹窗高度自适应,取消退款内部错误 * 删除文件 LICENSE * add LICENSE. * update app/Http/Admin/Controllers/UploadController.php. 去除重复的signatureAction方法 * !19 v1.2.0阶段性合并 * 增加微信H5支付需要的Referer头信息 * 更新H5支付方式 * 更新H5支付方式 * 更新H5支付方式 * !23 修复添加课时后进入编辑页面500错误 * 修复添加课时后进入编辑页面500错误 * !24 修复添加课时后进入编辑页面500错误 * 修复添加课时后进入编辑页面500错误 * !33 开放登录阶段性合并 * Merge remote-tracking branch 'gitee/xiaochong0302/I280IZ' into xiaocho… * 初步完成开放登录,待线上测试7 * Merge branch 'demo' of gitee.com:koogua/course-tencent-cloud into xiao… * 初步完成开放登录,待线上测试6 * !30 开放登录线上测试5 * !29 开放登录线上测试5 * 初步完成开放登录,待线上测试5 * !28 开放登录线上测试4 * 初步完成开放登录,待线上测试4 * !27 开放登录线上测试3 * 初步完成开放登录,待线上测试3 * !26 开放登录线上测试2 * 初步完成开放登录,待线上测试2 * !25 开放登录线上测试 * 初步完成开放登录,待线上测试 * !22 验证更新h5支付 * Merge remote-tracking branch 'remotes/gitee/develop' into demo * !20 验证更新h5支付 * Merge branch 'develop' of https://gitee.com/koogua/course-tencent-clou… * !16 v1.2.0阶段性合并 * 删除调试断点代码 * 删除重复的signature方法 * Merge branch 'develop' of https://gitee.com/koogua/course-tencent-clou… * demo后台增加统计 * !5 更新版本号1.1.0 * !4 v1.1.0版本develop->demo * Merge branch 'develop' into demo * 1.增加changelog.md * Merge branch 'develop' into demo * Merge branch 'develop' into demo * Merge branch 'develop' into demo * !1 精简优化代码 * Merge branch 'develop' into demo * 合并修改 * !34 修复创建课时相关属性表数据未生成的问题 * 修复创建课时相关属性表数据未生成的问题 * !35 修复腾讯云回调数据结构改变导致的错误 * 修复腾讯云回调数据结构改变导致的错误,缩短vod_event计划任务时间 * !36 修复添加课程后进入列表500错误 * 修复未填充教师和分类的列表错误 * 优化第三方登录,修复注册密码加密问题 * !38 修复课程分类未过滤 * 过滤课程分类 * !39 修复课程分类未过滤 * 过滤课程分类 * !40 修复课程分类未过滤2 * 过滤课程分类 * 过滤课程分类 * !41 修复课程分类未过滤2 * 过滤课程分类 * 过滤课程分类 * 优化开发登录,计划任务执行路径,周期
287 lines
7.5 KiB
PHP
287 lines
7.5 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Admin\Services;
|
|
|
|
use App\Builders\ResourceList as ResourceListBuilder;
|
|
use App\Caches\Chapter as ChapterCache;
|
|
use App\Caches\CourseChapterList as CatalogCache;
|
|
use App\Models\Chapter as ChapterModel;
|
|
use App\Models\ChapterLive as ChapterLiveModel;
|
|
use App\Models\ChapterRead as ChapterReadModel;
|
|
use App\Models\ChapterVod as ChapterVodModel;
|
|
use App\Models\Course as CourseModel;
|
|
use App\Repos\Chapter as ChapterRepo;
|
|
use App\Repos\Course as CourseRepo;
|
|
use App\Repos\Resource as ResourceRepo;
|
|
use App\Services\CourseStat as CourseStatService;
|
|
use App\Validators\Chapter as ChapterValidator;
|
|
|
|
class Chapter extends Service
|
|
{
|
|
|
|
public function getResources($id)
|
|
{
|
|
$resourceRepo = new ResourceRepo();
|
|
|
|
$resources = $resourceRepo->findByChapterId($id);
|
|
|
|
if ($resources->count() == 0) {
|
|
return [];
|
|
}
|
|
|
|
$builder = new ResourceListBuilder();
|
|
|
|
$items = $resources->toArray();
|
|
|
|
$items = $builder->handleUploads($items);
|
|
|
|
return $builder->objects($items);
|
|
}
|
|
|
|
public function getLessons($parentId)
|
|
{
|
|
$deleted = $this->request->getQuery('deleted', 'int', 0);
|
|
|
|
$chapterRepo = new ChapterRepo();
|
|
|
|
return $chapterRepo->findAll([
|
|
'parent_id' => $parentId,
|
|
'deleted' => $deleted,
|
|
]);
|
|
}
|
|
|
|
public function getChapter($id)
|
|
{
|
|
return $this->findOrFail($id);
|
|
}
|
|
|
|
public function createChapter()
|
|
{
|
|
$post = $this->request->getPost();
|
|
|
|
$validator = new ChapterValidator();
|
|
|
|
$data = [];
|
|
|
|
$course = $validator->checkCourse($post['course_id']);
|
|
|
|
$data['course_id'] = $course->id;
|
|
$data['title'] = $validator->checkTitle($post['title']);
|
|
$data['summary'] = $validator->checkSummary($post['summary']);
|
|
|
|
$chapterRepo = new ChapterRepo();
|
|
|
|
$parentId = 0;
|
|
|
|
if (isset($post['parent_id'])) {
|
|
$parent = $validator->checkParent($post['parent_id']);
|
|
$data['parent_id'] = $parent->id;
|
|
$data['free'] = $validator->checkFreeStatus($post['free']);
|
|
$data['priority'] = $chapterRepo->maxLessonPriority($post['parent_id']);
|
|
$parentId = $parent->id;
|
|
} else {
|
|
$data['priority'] = $chapterRepo->maxChapterPriority($post['course_id']);
|
|
$data['parent_id'] = $parentId;
|
|
}
|
|
|
|
$data['priority'] += 1;
|
|
|
|
try {
|
|
|
|
$this->db->begin();
|
|
|
|
$chapter = new ChapterModel();
|
|
|
|
if ($chapter->create($data) === false) {
|
|
throw new \RuntimeException('Create Chapter Failed');
|
|
}
|
|
|
|
$data = [
|
|
'course_id' => $course->id,
|
|
'chapter_id' => $chapter->id,
|
|
];
|
|
|
|
if ($parentId > 0) {
|
|
|
|
$attrs = false;
|
|
|
|
switch ($course->model) {
|
|
case CourseMOdel::MODEL_VOD:
|
|
$chapterVod = new ChapterVodModel();
|
|
$attrs = $chapterVod->create($data);
|
|
break;
|
|
case CourseModel::MODEL_LIVE:
|
|
$chapterLive = new ChapterLiveModel();
|
|
$attrs = $chapterLive->create($data);
|
|
break;
|
|
case CourseModel::MODEL_READ:
|
|
$chapterRead = new ChapterReadModel();
|
|
$attrs = $chapterRead->create($data);
|
|
break;
|
|
}
|
|
|
|
if ($attrs === false) {
|
|
throw new \RuntimeException("Create Chapter Related Attrs Failed");
|
|
}
|
|
}
|
|
|
|
$this->db->commit();
|
|
|
|
$this->updateChapterStats($chapter);
|
|
|
|
$this->updateCourseStat($chapter);
|
|
|
|
return $chapter;
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
$this->db->rollback();
|
|
|
|
$logger = $this->getLogger();
|
|
|
|
$logger->error('Create Chapter Error ' . kg_json_encode([
|
|
'code' => $e->getCode(),
|
|
'message' => $e->getMessage(),
|
|
]));
|
|
|
|
throw new \RuntimeException('sys.trans_rollback');
|
|
}
|
|
}
|
|
|
|
public function updateChapter($id)
|
|
{
|
|
$chapter = $this->findOrFail($id);
|
|
|
|
$post = $this->request->getPost();
|
|
|
|
$validator = new ChapterValidator();
|
|
|
|
$data = [];
|
|
|
|
if (isset($post['title'])) {
|
|
$data['title'] = $validator->checkTitle($post['title']);
|
|
}
|
|
|
|
if (isset($post['summary'])) {
|
|
$data['summary'] = $validator->checkSummary($post['summary']);
|
|
}
|
|
|
|
if (isset($post['priority'])) {
|
|
$data['priority'] = $validator->checkPriority($post['priority']);
|
|
}
|
|
|
|
if (isset($post['free'])) {
|
|
$data['free'] = $validator->checkFreeStatus($post['free']);
|
|
}
|
|
|
|
if (isset($post['published'])) {
|
|
$data['published'] = $validator->checkPublishStatus($post['published']);
|
|
if ($chapter->published == 0 && $post['published'] == 1) {
|
|
$validator->checkPublishAbility($chapter);
|
|
}
|
|
}
|
|
|
|
$chapter->update($data);
|
|
|
|
$this->updateChapterStats($chapter);
|
|
|
|
$this->updateCourseStat($chapter);
|
|
|
|
$this->rebuildCatalogCache($chapter);
|
|
|
|
return $chapter;
|
|
}
|
|
|
|
public function deleteChapter($id)
|
|
{
|
|
$chapter = $this->findOrFail($id);
|
|
|
|
$validator = new ChapterValidator();
|
|
|
|
$validator->checkDeleteAbility($chapter);
|
|
|
|
$chapter->deleted = 1;
|
|
|
|
$chapter->update();
|
|
|
|
$this->updateChapterStats($chapter);
|
|
|
|
$this->updateCourseStat($chapter);
|
|
|
|
$this->rebuildCatalogCache($chapter);
|
|
|
|
return $chapter;
|
|
}
|
|
|
|
public function restoreChapter($id)
|
|
{
|
|
$chapter = $this->findOrFail($id);
|
|
|
|
$chapter->deleted = 0;
|
|
|
|
$chapter->update();
|
|
|
|
$this->updateChapterStats($chapter);
|
|
|
|
$this->updateCourseStat($chapter);
|
|
|
|
$this->rebuildCatalogCache($chapter);
|
|
|
|
return $chapter;
|
|
}
|
|
|
|
protected function updateChapterStats(ChapterModel $chapter)
|
|
{
|
|
$chapterRepo = new ChapterRepo();
|
|
|
|
if ($chapter->parent_id > 0) {
|
|
$chapter = $chapterRepo->findById($chapter->parent_id);
|
|
}
|
|
|
|
$lessonCount = $chapterRepo->countLessons($chapter->id);
|
|
$chapter->lesson_count = $lessonCount;
|
|
$chapter->update();
|
|
}
|
|
|
|
protected function updateCourseStat(ChapterModel $chapter)
|
|
{
|
|
$courseRepo = new CourseRepo();
|
|
|
|
$course = $courseRepo->findById($chapter->course_id);
|
|
|
|
$courseStats = new CourseStatService();
|
|
|
|
$courseStats->updateLessonCount($course->id);
|
|
|
|
if ($course->model == CourseModel::MODEL_VOD) {
|
|
$courseStats->updateVodAttrs($course->id);
|
|
} elseif ($course->model == CourseModel::MODEL_LIVE) {
|
|
$courseStats->updateLiveAttrs($course->id);
|
|
} elseif ($course->model == CourseModel::MODEL_READ) {
|
|
$courseStats->updateReadAttrs($course->id);
|
|
}
|
|
}
|
|
|
|
protected function rebuildChapterCache(ChapterModel $chapter)
|
|
{
|
|
$cache = new ChapterCache();
|
|
|
|
$cache->rebuild($chapter->id);
|
|
}
|
|
|
|
protected function rebuildCatalogCache(ChapterModel $chapter)
|
|
{
|
|
$cache = new CatalogCache();
|
|
|
|
$cache->rebuild($chapter->course_id);
|
|
}
|
|
|
|
protected function findOrFail($id)
|
|
{
|
|
$validator = new ChapterValidator();
|
|
|
|
return $validator->checkChapter($id);
|
|
}
|
|
|
|
}
|