CourseController.php 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace App\Http\Controllers\Api\Course;
  3. use App\Http\Controllers\Controller;
  4. use App\Repositories\Enums\ResponseCodeEnum;
  5. use App\Repositories\Models\Course\Course;
  6. use App\Repositories\Models\Course\Subscribe;
  7. use App\Services\Course\CourseService;
  8. use Illuminate\Http\Request;
  9. use Jiannei\Response\Laravel\Support\Facades\Response;
  10. use App\Contracts\Repositories\Course\CourseRepository;
  11. use App\Repositories\Validators\Course\CourseValidator;
  12. /**
  13. * 课程管理
  14. * @package namespace App\Http\Controllers;
  15. */
  16. class CourseController extends Controller
  17. {
  18. protected $service;
  19. /**
  20. * CoursesController constructor.
  21. *
  22. * @param CourseRepository $repository
  23. * @param CourseValidator $validator
  24. */
  25. public function __construct(CourseService $service)
  26. {
  27. parent::__construct();
  28. $this->service = $service;
  29. }
  30. public function index(Request $request)
  31. {
  32. $courses = $this->service->handleList($request);
  33. return Response::success($courses);
  34. }
  35. /**
  36. * 详情
  37. * Author: Mead
  38. */
  39. public function show(Request $request)
  40. {
  41. $this->validateData($request, [
  42. 'id' => 'required|integer'
  43. ]);
  44. $id = $request->get('id');
  45. $course = $this->service->handleProfile($id);
  46. // $directory = [];
  47. // $data = Chapter::query()->where('course_id', $course['id'])->where('status', ModelStatusEnum::OK)->orderByDesc('sort')->get();
  48. // foreach ($data as $d) {
  49. // $directory[] = [
  50. // 'id' => $d['id'],
  51. // 'title' => $d['title'],
  52. // 'children' => $d->videos()->where('status', ModelStatusEnum::OK)->where('published_at', '<', Carbon::now())->orderByDesc('sort')->get(['id', 'title', 'duration', 'short_description'])->append(['duration_text', "progress"])
  53. // ];
  54. // }
  55. // $comments = $course->comments()->with(['user'])->limit(self::PAGE_NUM)->orderByDesc('id')->get();
  56. //
  57. // $attaches = $course->attaches()->with(['path_resource'])->where('status', ModelStatusEnum::OK)->get(['name', 'id', 'path', 'download_times']);
  58. //
  59. // $subscribe = $course->subscribe()->where('user_id', login_user_id())->first();
  60. // $course = $this->repository->parserResult($course);
  61. // $watch_record_video_id = UserVideoWatchRecord::query()->where('user_id', login_user_id())->where('course_id', $id)->orderByDesc('watched_at')->value('video_id');
  62. return $this->response->success($course);
  63. }
  64. /**
  65. * 订阅课程
  66. * @param Request $request
  67. * Author: Mead
  68. */
  69. public function subscribe(Request $request)
  70. {
  71. $this->validateData($request, [
  72. 'course_id' => 'required|integer'
  73. ], [
  74. 'course_id' => '课程id'
  75. ]);
  76. $course_id = $request->get('course_id');
  77. $user_id = login_user_id();
  78. if (Subscribe::query()->where('course_id', $course_id)->where('user_id', $user_id)->exists()) {
  79. abort(ResponseCodeEnum::SERVICE_OPERATION_ERROR, '请勿重复操作');
  80. }
  81. Subscribe::query()->create(['course_id' => $course_id, 'user_id' => $user_id]);
  82. Course::query()->where('id', $course_id)->increment('user_count');
  83. return $this->response->ok('订阅成功');
  84. }
  85. }