CourseController.php 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. <?php
  2. namespace App\Http\Controllers\Api\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\Collection;
  10. use App\Repositories\Models\Course\Course;
  11. use App\Repositories\Models\Course\UserRecord;
  12. use Carbon\Carbon;
  13. use Illuminate\Http\Request;
  14. use Illuminate\Support\Str;
  15. use Jiannei\Response\Laravel\Support\Facades\Response;
  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. /**
  46. * 课程列表
  47. * @param Request $request
  48. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  49. * Author: Mead
  50. */
  51. public function index(Request $request)
  52. {
  53. $this->repository->pushCriteria(CourseCriteria::class);
  54. $courses = $this->repository->paginate($request->get('per_page', self::PAGE_NUM));
  55. // $courses = $this->repository->parserResult($courses);
  56. return Response::success($courses);
  57. }
  58. /**
  59. * 添加课程
  60. * @param Request $request
  61. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource|void
  62. * @throws \Illuminate\Validation\ValidationException
  63. * Author: Mead
  64. */
  65. public function store(Request $request)
  66. {
  67. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_CREATE));
  68. try {
  69. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_CREATE)));
  70. $data['type'] = CourseTypeEnum::RECORDED;
  71. $data['user_id'] = login_user_id();
  72. $data['slug'] = Str::random();
  73. if (!in_array('published_at', $data) || empty($data['published_at'])) {
  74. $data['published_at'] = Carbon::now();
  75. }
  76. $course = $this->repository->create($data);
  77. return Response::success($course);
  78. } catch (\Exception $e) {
  79. return $this->errorStore($e);
  80. }
  81. }
  82. /**
  83. * 修改课程
  84. * @param Request $request
  85. * @param $id
  86. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  87. * @throws \Illuminate\Validation\ValidationException
  88. * Author: Mead
  89. */
  90. public function update(Request $request, $id)
  91. {
  92. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_UPDATE));
  93. if (!Course::query()->where('user_id', login_user_id())->where('id', $id)->exists()) {
  94. return $this->error('您暂无编辑权限!');
  95. }
  96. try {
  97. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_UPDATE)));
  98. if (!in_array('published_at', $data) || empty($data['published_at'])) {
  99. $data['published_at'] = Carbon::now();
  100. }
  101. $course = $this->repository->update($data, $id);
  102. return Response::success($course);
  103. } catch (\Exception $e) {
  104. $this->errorStore($e);
  105. }
  106. }
  107. /**
  108. * 删除课程
  109. * @param $id
  110. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  111. * Author: Mead
  112. */
  113. public function destroy($id)
  114. {
  115. if (!Course::query()->where('user_id', login_user_id())->where('id', $id)->exists()) {
  116. return $this->error('您暂无删除权限!');
  117. }
  118. try {
  119. $this->repository->delete($id);
  120. return Response::success(null, T('successfully delete.'));
  121. } catch (\Exception $exception) {
  122. return Response::fail(T('Delete failed.'), ResponseCodeEnum::SERVICE_UPDATE_DATA_ERROR);
  123. }
  124. }
  125. /**
  126. * 课程详情
  127. * Author: Mead
  128. */
  129. public function show($slug)
  130. {
  131. $courseVideo = $this->repository->where('slug', $slug)->first();
  132. if (!$courseVideo) {
  133. return $this->error('找不到资源');
  134. }
  135. $courseVideo = $this->repository->parserResult($courseVideo);
  136. return Response::success($courseVideo);
  137. }
  138. /**
  139. * 课程详情【学生】
  140. * @param Request $request
  141. * @param $slug
  142. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  143. * Author: Mead
  144. */
  145. public function detail(Request $request, $slug)
  146. {
  147. // $id = $request->get('id');
  148. $course = $this->repository->where('slug', $slug)->first();
  149. if (!$course) {
  150. return Response::fail(T('not find Model'));
  151. }
  152. $directory = [];
  153. $data = Chapter::query()->where('course_id', $course->id)->where('status', ModelStatusEnum::OK)->orderByDesc('sort')->get();
  154. foreach ($data as $d) {
  155. $directory[] = [
  156. 'id' => $d['id'],
  157. 'title' => $d['title'],
  158. 'children' => $d->videos()->where('status', ModelStatusEnum::OK)->where('published_at', '<', Carbon::now())->orderByDesc('sort')->get(['id', 'title', 'duration', 'slug'])->append(['duration_text', "progress"])
  159. ];
  160. }
  161. $comments = [];
  162. // $comments = $course->comments()->with(['user'])->limit(self::PAGE_NUM)->orderByDesc('id')->get();
  163. $attaches = $course->attaches()->with(['path_resource'])->where('status', ModelStatusEnum::OK)->get(['name', 'id', 'path', 'download_times']);
  164. $subscribe = [];
  165. // $subscribe = $course->subscribe()->where('user_id', login_user_id())->first();
  166. $course = $this->repository->parserResult($course);
  167. $watch_record_video_id = [];
  168. // $watch_record_video_id = UserVideoWatchRecord::query()->where('user_id', login_user_id())->where('course_id', $id)->orderByDesc('watched_at')->value('video_id');
  169. return Response::success(compact('course', 'directory', 'comments', 'attaches', 'subscribe', 'watch_record_video_id'));
  170. }
  171. /**
  172. * 订阅课程
  173. * @param Request $request
  174. * Author: Mead
  175. */
  176. public function subscribe(Request $request)
  177. {
  178. $this->validate($request, ['course_id' => 'required|integer']);
  179. $course_id = $request->get('course_id');
  180. $user_id = login_user_id();
  181. if (UserRecord::query()->where('course_id', $course_id)->where('user_id', $user_id)->exists()) {
  182. return Response::success(null);
  183. }
  184. UserRecord::query()->create(['course_id' => $course_id, 'user_id' => $user_id]);
  185. Course::query()->where('id', $course_id)->increment('user_count');
  186. return Response::success(null);
  187. }
  188. /**
  189. * 观看记录
  190. * @param Request $request
  191. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  192. * Author: Mead
  193. */
  194. public function lookCourses(Request $request)
  195. {
  196. $user_id = login_user_id();
  197. $courses = Course::query()->select('c.*')->from('course_courses as c')->withoutGlobalScope('language')->withTrashed()->where('r.user_id', $user_id)
  198. ->leftJoin('course_user_records as r', 'r.course_id', '=', 'c.id')->where('status', ModelStatusEnum::OK)->where('c.deleted_at', '=', null)->where('r.deleted_at', '=', null)->orderByDesc('r.updated_at')->paginate($request->get('per_page', self::PAGE_NUM));
  199. $courses = $this->repository->parserResult($courses);
  200. return Response::success($courses);
  201. }
  202. /**
  203. * 选项
  204. * @param Request $request
  205. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  206. * Author: Mead
  207. */
  208. public function selectOptions(Request $request)
  209. {
  210. $lists = $this->repository->select(['id', 'title'])->paginate($request->get('per_page', self::PAGE_NUM));
  211. return Response::success($lists);
  212. }
  213. /**
  214. * 收藏课程
  215. * @param Request $request
  216. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  217. * @throws \Illuminate\Validation\ValidationException
  218. * Author: Mead
  219. */
  220. public function collection(Request $request)
  221. {
  222. $this->validate($request, ['course_id' => 'required|integer']);
  223. $course_id = $request->get('course_id');
  224. $user_id = login_user_id();
  225. $is_collection = Collection::query()->where('course_id', $course_id)->where('user_id', $user_id)->exists();
  226. if ($is_collection) {
  227. Collection::query()->where('course_id', $course_id)->where('user_id', $user_id)->delete();
  228. return Response::success(null, '取消收藏成功');
  229. }
  230. Collection::query()->create([
  231. 'course_id' => $course_id,
  232. 'user_id' => $user_id,
  233. ]);
  234. return Response::success(null, '收藏成功');
  235. }
  236. /**
  237. * 随机课程
  238. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  239. * Author: Mead
  240. */
  241. public function random()
  242. {
  243. $courses = Course::query()->where('status', ModelStatusEnum::OK)->where('published_at', '<', Carbon::now())->inRandomOrder()->take(5)->get();
  244. $courses = $this->repository->parserResult($courses);
  245. return Response::success($courses);
  246. }
  247. }