CourseController.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\Course;
  4. use App\Models\CourseMember;
  5. use Illuminate\Http\Request;
  6. use App\Http\Api\AuthApi;
  7. use App\Http\Api\StudioApi;
  8. class CourseController extends Controller
  9. {
  10. /**
  11. * Display a listing of the resource.
  12. *
  13. * @return \Illuminate\Http\Response
  14. */
  15. public function index(Request $request)
  16. {
  17. //
  18. $result=false;
  19. $indexCol = ['id','title','subtitle','cover','content','content_type','teacher','start_at','end_at','updated_at','created_at'];
  20. switch ($request->get('view')) {
  21. case 'create':
  22. # 获取 studio 建立的所有 course
  23. $user = AuthApi::current($request);
  24. if(!$user){
  25. return $this->error(__('auth.failed'));
  26. }
  27. //判断当前用户是否有指定的studio的权限
  28. if($user['user_uid'] !== StudioApi::getIdByName($request->get('name'))){
  29. return $this->error(__('auth.failed'));
  30. }
  31. $table = Course::where('studio_id', $user["user_uid"]);
  32. break;
  33. case 'study':
  34. //我学习的课程
  35. $course = CourseMember::where('user_id',$user["user_uid"])
  36. ->where('role','member')
  37. ->select('course_id')
  38. ->get();
  39. $courseId = [];
  40. foreach ($course as $key => $value) {
  41. # code...
  42. $courseId[] = $value->course_id;
  43. }
  44. $table = Course::whereIn('id', $courseId);
  45. break;
  46. }
  47. $table = $table->select($indexCol);
  48. if(isset($_GET["search"])){
  49. $table = $table->where('title', 'like', $_GET["search"]."%");
  50. }
  51. $count = $table->count();
  52. if(isset($_GET["order"]) && isset($_GET["dir"])){
  53. $table = $table->orderBy($_GET["order"],$_GET["dir"]);
  54. }else{
  55. if($request->get('view') === 'studio_list'){
  56. $table = $table->orderBy('count','desc');
  57. }else{
  58. $table = $table->orderBy('updated_at','desc');
  59. }
  60. }
  61. if(isset($_GET["limit"])){
  62. $offset = 0;
  63. if(isset($_GET["offset"])){
  64. $offset = $_GET["offset"];
  65. }
  66. $table = $table->skip($offset)->take($_GET["limit"]);
  67. }
  68. $result = $table->get();
  69. if($result){
  70. return $this->ok(["rows"=>$result,"count"=>$count]);
  71. }else{
  72. return $this->error("没有查询到数据");
  73. }
  74. }
  75. /**
  76. * Store a newly created resource in storage.
  77. *
  78. * @param \Illuminate\Http\Request $request
  79. * @return \Illuminate\Http\Response
  80. */
  81. public function store(Request $request)
  82. {
  83. //
  84. $user = AuthApi::current($request);
  85. if(!$user){
  86. return $this->error(__('auth.failed'));
  87. }
  88. //判断当前用户是否有指定的studio的权限
  89. if($user['user_uid'] !== StudioApi::getIdByName($request->get('studio'))){
  90. return $this->error(__('auth.failed'));
  91. }
  92. //查询是否重复
  93. if(Course::where('title',$request->get('title'))->where('studio_id',$user['user_uid'])->exists()){
  94. return $this->error(__('validation.exists',['name']));
  95. }
  96. $course = new Course;
  97. $course->title = $request->get('title');
  98. $course->studio_id = $user['user_uid'];
  99. $course->save();
  100. return $this->ok($course);
  101. }
  102. /**
  103. * Display the specified resource.
  104. *
  105. * @param \App\Models\Course $course
  106. * @return \Illuminate\Http\Response
  107. */
  108. public function show(Course $course)
  109. {
  110. //
  111. return $this->ok($course);
  112. }
  113. /**
  114. * Update the specified resource in storage.
  115. *
  116. * @param \Illuminate\Http\Request $request
  117. * @param \App\Models\Course $course
  118. * @return \Illuminate\Http\Response
  119. */
  120. public function update(Request $request, Course $course)
  121. {
  122. //
  123. $user = AuthApi::current($request);
  124. if(!$user){
  125. return $this->error(__('auth.failed'));
  126. }
  127. //判断当前用户是否有指定的studio的权限
  128. if($user['user_uid'] !== StudioApi::getIdByName($request->get('studio'))){
  129. return $this->error(__('auth.failed'));
  130. }
  131. //查询标题是否重复
  132. if(Course::where('title',$request->get('title'))->where('studio_id',$user['user_uid'])->exists()){
  133. return $this->error(__('validation.exists',['name']));
  134. }
  135. $course->title = $request->get('title');
  136. $course->subtitle = $request->get('subtitle');
  137. $course->cover = $request->get('cover');
  138. $course->content = $request->get('content');
  139. $course->teacher = $request->get('teacher');
  140. $course->start_at = $request->get('start_at');
  141. $course->end_at = $request->get('end_at');
  142. $course->save();
  143. return $this->ok($course);
  144. }
  145. /**
  146. * Remove the specified resource from storage.
  147. *
  148. * @param \App\Models\Course $course
  149. * @return \Illuminate\Http\Response
  150. */
  151. public function destroy(Course $course)
  152. {
  153. //
  154. $user = AuthApi::current($request);
  155. if(!$user){
  156. return $this->error(__('auth.failed'));
  157. }
  158. //判断当前用户是否有指定的studio的权限
  159. if($user['user_uid'] !== StudioApi::getIdByName($request->get('studio'))){
  160. return $this->error(__('auth.failed'));
  161. }
  162. $delete = 0;
  163. DB::transaction(function() use($delete){
  164. //删除group member
  165. $memberDelete = CourseMember::where('course_id',$course->id)->delete();
  166. $delete = $course->delete();
  167. });
  168. $this->ok($delete);
  169. }
  170. }