123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282 |
- <?php
- namespace App\Http\Controllers\Api\Course;
- use App\Http\Controllers\Controller;
- use App\Repositories\Criteria\Course\CourseCriteria;
- use App\Repositories\Enums\CourseTypeEnum;
- use App\Repositories\Enums\ModelStatusEnum;
- use App\Repositories\Enums\ResponseCodeEnum;
- use App\Repositories\Models\Course\Chapter;
- use App\Repositories\Models\Course\Collection;
- use App\Repositories\Models\Course\Course;
- use App\Repositories\Models\Course\UserRecord;
- use Carbon\Carbon;
- use Illuminate\Http\Request;
- use Illuminate\Support\Str;
- use Jiannei\Response\Laravel\Support\Facades\Response;
- use Prettus\Validator\Contracts\ValidatorInterface;
- use App\Contracts\Repositories\Course\CourseRepository;
- use App\Repositories\Validators\Course\CourseValidator;
- /**
- * Class CoursesController.
- *
- * @package namespace App\Http\Controllers;
- */
- class CourseController extends Controller
- {
- /**
- * @var CourseRepository
- */
- protected $repository;
- /**
- * @var CourseValidator
- */
- protected $validator;
- /**
- * CoursesController constructor.
- *
- * @param CourseRepository $repository
- * @param CourseValidator $validator
- */
- public function __construct(CourseRepository $repository, CourseValidator $validator)
- {
- $this->repository = $repository;
- $this->validator = $validator;
- }
- /**
- * 课程列表
- * @param Request $request
- * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
- * Author: Mead
- */
- public function index(Request $request)
- {
- $this->repository->pushCriteria(CourseCriteria::class);
- $courses = $this->repository->paginate($request->get('per_page', self::PAGE_NUM));
- // $courses = $this->repository->parserResult($courses);
- return Response::success($courses);
- }
- /**
- * 添加课程
- * @param Request $request
- * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource|void
- * @throws \Illuminate\Validation\ValidationException
- * Author: Mead
- */
- public function store(Request $request)
- {
- $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_CREATE));
- try {
- $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_CREATE)));
- $data['type'] = CourseTypeEnum::RECORDED;
- $data['user_id'] = login_user_id();
- $data['slug'] = Str::random();
- if (!in_array('published_at', $data) || empty($data['published_at'])) {
- $data['published_at'] = Carbon::now();
- }
- $course = $this->repository->create($data);
- return Response::success($course);
- } catch (\Exception $e) {
- return $this->errorStore($e);
- }
- }
- /**
- * 修改课程
- * @param Request $request
- * @param $id
- * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
- * @throws \Illuminate\Validation\ValidationException
- * Author: Mead
- */
- public function update(Request $request, $id)
- {
- $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_UPDATE));
- if (!Course::query()->where('user_id', login_user_id())->where('id', $id)->exists()) {
- return $this->error('您暂无编辑权限!');
- }
- try {
- $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_UPDATE)));
- if (!in_array('published_at', $data) || empty($data['published_at'])) {
- $data['published_at'] = Carbon::now();
- }
- $course = $this->repository->update($data, $id);
- return Response::success($course);
- } catch (\Exception $e) {
- $this->errorStore($e);
- }
- }
- /**
- * 删除课程
- * @param $id
- * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
- * Author: Mead
- */
- public function destroy($id)
- {
- if (!Course::query()->where('user_id', login_user_id())->where('id', $id)->exists()) {
- return $this->error('您暂无删除权限!');
- }
- try {
- $this->repository->delete($id);
- return Response::success(null, T('successfully delete.'));
- } catch (\Exception $exception) {
- return Response::fail(T('Delete failed.'), ResponseCodeEnum::SERVICE_UPDATE_DATA_ERROR);
- }
- }
- /**
- * 课程详情
- * Author: Mead
- */
- public function show($slug)
- {
- $courseVideo = $this->repository->where('slug', $slug)->first();
- if (!$courseVideo) {
- return $this->error('找不到资源');
- }
- $courseVideo = $this->repository->parserResult($courseVideo);
- return Response::success($courseVideo);
- }
- /**
- * 课程详情【学生】
- * @param Request $request
- * @param $slug
- * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
- * Author: Mead
- */
- public function detail(Request $request, $slug)
- {
- // $id = $request->get('id');
- $course = $this->repository->where('slug', $slug)->first();
- if (!$course) {
- return Response::fail(T('not find Model'));
- }
- $directory = [];
- $data = Chapter::query()->where('course_id', $course->id)->where('status', ModelStatusEnum::OK)->orderByDesc('sort')->get();
- foreach ($data as $d) {
- $directory[] = [
- 'id' => $d['id'],
- 'title' => $d['title'],
- 'children' => $d->videos()->where('status', ModelStatusEnum::OK)->where('published_at', '<', Carbon::now())->orderByDesc('sort')->get(['id', 'title', 'duration', 'slug'])->append(['duration_text', "progress"])
- ];
- }
- $comments = [];
- // $comments = $course->comments()->with(['user'])->limit(self::PAGE_NUM)->orderByDesc('id')->get();
- $attaches = $course->attaches()->with(['path_resource'])->where('status', ModelStatusEnum::OK)->get(['name', 'id', 'path', 'download_times']);
- $subscribe = [];
- // $subscribe = $course->subscribe()->where('user_id', login_user_id())->first();
- $course = $this->repository->parserResult($course);
- $watch_record_video_id = [];
- // $watch_record_video_id = UserVideoWatchRecord::query()->where('user_id', login_user_id())->where('course_id', $id)->orderByDesc('watched_at')->value('video_id');
- return Response::success(compact('course', 'directory', 'comments', 'attaches', 'subscribe', 'watch_record_video_id'));
- }
- /**
- * 订阅课程
- * @param Request $request
- * Author: Mead
- */
- public function subscribe(Request $request)
- {
- $this->validate($request, ['course_id' => 'required|integer']);
- $course_id = $request->get('course_id');
- $user_id = login_user_id();
- if (UserRecord::query()->where('course_id', $course_id)->where('user_id', $user_id)->exists()) {
- return Response::success(null);
- }
- UserRecord::query()->create(['course_id' => $course_id, 'user_id' => $user_id]);
- Course::query()->where('id', $course_id)->increment('user_count');
- return Response::success(null);
- }
- /**
- * 观看记录
- * @param Request $request
- * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
- * Author: Mead
- */
- public function lookCourses(Request $request)
- {
- $user_id = login_user_id();
- $courses = Course::query()->select('c.*')->from('course_courses as c')->withoutGlobalScope('language')->withTrashed()->where('r.user_id', $user_id)
- ->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));
- $courses = $this->repository->parserResult($courses);
- return Response::success($courses);
- }
- /**
- * 选项
- * @param Request $request
- * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
- * Author: Mead
- */
- public function selectOptions(Request $request)
- {
- $lists = $this->repository->select(['id', 'title'])->paginate($request->get('per_page', self::PAGE_NUM));
- return Response::success($lists);
- }
- /**
- * 收藏课程
- * @param Request $request
- * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
- * @throws \Illuminate\Validation\ValidationException
- * Author: Mead
- */
- public function collection(Request $request)
- {
- $this->validate($request, ['course_id' => 'required|integer']);
- $course_id = $request->get('course_id');
- $user_id = login_user_id();
- $is_collection = Collection::query()->where('course_id', $course_id)->where('user_id', $user_id)->exists();
- if ($is_collection) {
- Collection::query()->where('course_id', $course_id)->where('user_id', $user_id)->delete();
- return Response::success(null, '取消收藏成功');
- }
- Collection::query()->create([
- 'course_id' => $course_id,
- 'user_id' => $user_id,
- ]);
- return Response::success(null, '收藏成功');
- }
- /**
- * 随机课程
- * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
- * Author: Mead
- */
- public function random()
- {
- $courses = Course::query()->where('status', ModelStatusEnum::OK)->where('published_at', '<', Carbon::now())->inRandomOrder()->take(5)->get();
- $courses = $this->repository->parserResult($courses);
- return Response::success($courses);
- }
- }
|