CourseController.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. <?php
  2. namespace App\Http\Controllers\Admin\Course;
  3. use App\Http\Controllers\Controller;
  4. use App\Repositories\Criteria\Course\CourseCriteria;
  5. use App\Repositories\Enums\CourseTypeEnum;
  6. use App\Repositories\Enums\ModelStatusEnum;
  7. use App\Repositories\Enums\ResponseCodeEnum;
  8. use App\Repositories\Models\Course\Chapter;
  9. use App\Repositories\Models\Course\Course;
  10. use App\Repositories\Models\Course\UserRecord;
  11. use App\Repositories\Models\UserVideoWatchRecord;
  12. use Carbon\Carbon;
  13. use Illuminate\Http\Request;
  14. use Jiannei\Response\Laravel\Support\Facades\Response;
  15. use Overtrue\LaravelPinyin\Facades\Pinyin;
  16. use Prettus\Validator\Contracts\ValidatorInterface;
  17. use App\Contracts\Repositories\Course\CourseRepository;
  18. use App\Repositories\Validators\Course\CourseValidator;
  19. /**
  20. * Class CoursesController.
  21. *
  22. * @package namespace App\Http\Controllers;
  23. */
  24. class CourseController extends Controller
  25. {
  26. /**
  27. * @var CourseRepository
  28. */
  29. protected $repository;
  30. /**
  31. * @var CourseValidator
  32. */
  33. protected $validator;
  34. /**
  35. * CoursesController constructor.
  36. *
  37. * @param CourseRepository $repository
  38. * @param CourseValidator $validator
  39. */
  40. public function __construct(CourseRepository $repository, CourseValidator $validator)
  41. {
  42. $this->repository = $repository;
  43. $this->validator = $validator;
  44. }
  45. public function index()
  46. {
  47. $this->repository->pushCriteria(CourseCriteria::class);
  48. $courses = $this->repository->paginate(request('per_page', self::PAGE_NUM));
  49. return Response::success($courses);
  50. }
  51. public function store(Request $request)
  52. {
  53. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_CREATE));
  54. try {
  55. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_CREATE)));
  56. $data['type'] = CourseTypeEnum::RECORDED;
  57. $data['admin_id'] = login_admin_id();
  58. $data['slug'] = arr2str(Pinyin::permalink($data['title']), '_');
  59. if (!in_array('published_at', $data) || empty($data['published_at'])) {
  60. $data['published_at'] = Carbon::now();
  61. }
  62. $course = $this->repository->create($data);
  63. return Response::success($course);
  64. } catch (\Exception $e) {
  65. return $this->errorStore($e);
  66. }
  67. }
  68. public function show($id)
  69. {
  70. $course = $this->repository->find($id);
  71. return Response::success($course);
  72. }
  73. public function update(Request $request, $id)
  74. {
  75. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_UPDATE));
  76. try {
  77. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_UPDATE)));
  78. if (in_array('title', $data)) {
  79. $data['slug'] = arr2str(Pinyin::permalink($data['title']), '_');
  80. }
  81. if (!in_array('published_at', $data) || empty($data['published_at'])) {
  82. $data['published_at'] = Carbon::now();
  83. }
  84. $course = $this->repository->update($data, $id);
  85. return Response::success($course);
  86. } catch (\Exception $e) {
  87. $this->errorStore($e);
  88. }
  89. }
  90. public function destroy($id)
  91. {
  92. try {
  93. $this->repository->delete($id);
  94. return Response::success(null, T('successfully delete.'));
  95. } catch (\Exception $exception) {
  96. return Response::fail(T('Delete failed.'), ResponseCodeEnum::SERVICE_UPDATE_DATA_ERROR);
  97. }
  98. }
  99. public function lists(Request $request)
  100. {
  101. $this->repository->pushCriteria(CourseCriteria::class);
  102. $courses = $this->repository->where('status', ModelStatusEnum::OK)->where('published_at', '<', Carbon::now())->paginate($request->get('per_page', self::PAGE_NUM));
  103. $courses = $this->repository->parserResult($courses);
  104. return Response::success($courses);
  105. }
  106. /**
  107. * Author: Mead
  108. */
  109. public function viewShow($id)
  110. {
  111. $course = $this->repository->where('id', $id)->first();
  112. $directory = [];
  113. $data = Chapter::query()->where('course_id', $course->id)->where('status', ModelStatusEnum::OK)->orderByDesc('sort')->get();
  114. foreach ($data as $d) {
  115. $directory[] = [
  116. 'id' => $d['id'],
  117. 'title' => $d['title'],
  118. 'children' => $d->videos()->where('status', ModelStatusEnum::OK)->where('published_at', '<', Carbon::now())->orderByDesc('sort')->get(['id', 'title', 'duration', 'short_description'])->append(['duration_text', "progress"])
  119. ];
  120. }
  121. $comments = $course->comments()->with(['user'])->limit(self::PAGE_NUM)->orderByDesc('id')->get();
  122. $attaches = $course->attaches()->with(['path_resource'])->where('status', ModelStatusEnum::OK)->get(['name', 'id', 'path', 'download_times']);
  123. $subscribe = $course->subscribe()->where('user_id', login_admin_id())->first();
  124. $course = $this->repository->parserResult($course);
  125. $watch_record_video_id = UserVideoWatchRecord::query()->where('user_id', login_admin_id())->where('course_id', $id)->orderByDesc('watched_at')->value('video_id');
  126. return Response::success(compact('course', 'directory', 'comments', 'attaches', 'subscribe', 'watch_record_video_id'));
  127. }
  128. /**
  129. * 订阅课程
  130. * @param Request $request
  131. * Author: Mead
  132. */
  133. public function subscribe(Request $request)
  134. {
  135. $this->validate($request, ['course_id' => 'required|integer']);
  136. $course_id = $request->get('course_id');
  137. $user_id = login_admin_id();
  138. if (UserRecord::query()->where('course_id', $course_id)->where('user_id', $user_id)->exists()) {
  139. return Response::success(null);
  140. }
  141. UserRecord::query()->create(['course_id' => $course_id, 'user_id' => $user_id]);
  142. Course::query()->where('id', $course_id)->increment('user_count');
  143. return Response::success(null);
  144. }
  145. }