GroupController.php 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\GroupInfo;
  4. use App\Models\GroupMember;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Str;
  7. use Illuminate\Support\Facades\Log;
  8. use Illuminate\Support\Facades\DB;
  9. use App\Http\Api\AuthApi;
  10. use App\Http\Api\StudioApi;
  11. use App\Http\Resources\GroupResource;
  12. class GroupController extends Controller
  13. {
  14. /**
  15. * Display a listing of the resource.
  16. *
  17. * @return \Illuminate\Http\Response
  18. */
  19. public function index(Request $request)
  20. {
  21. //
  22. $result=false;
  23. $indexCol = ['uid','name','description','owner','updated_at','created_at'];
  24. switch ($request->get('view')) {
  25. case 'studio':
  26. # 获取studio内所有group
  27. $user = AuthApi::current($request);
  28. if(!$user){
  29. return $this->error(__('auth.failed'));
  30. }
  31. //判断当前用户是否有指定的studio的权限
  32. $studioId = StudioApi::getIdByName($request->get('name'));
  33. if($user['user_uid'] !== $studioId){
  34. return $this->error(__('auth.failed'));
  35. }
  36. $table = GroupInfo::select($indexCol);
  37. if($request->get('view2','my')==='my'){
  38. $table = $table->where('owner', $studioId);
  39. }else{
  40. //我参加的group
  41. $groupId = GroupMember::where('user_id',$studioId)
  42. ->groupBy('group_id')
  43. ->select('group_id')
  44. ->get();
  45. $table = $table->whereIn('uid', $groupId);
  46. $table = $table->where('owner','<>', $studioId);
  47. }
  48. break;
  49. case 'key':
  50. $table = GroupInfo::select($indexCol)->where('name','like', $request->get('key')."%");
  51. break;
  52. }
  53. if($request->has("search")){
  54. $table = $table->where('name', 'like', "%" . $request->get("search")."%");
  55. }
  56. $count = $table->count();
  57. if(isset($_GET["order"]) && isset($_GET["dir"])){
  58. $table = $table->orderBy($_GET["order"],$_GET["dir"]);
  59. }else{
  60. if($request->get('view') === 'studio_list'){
  61. $table = $table->orderBy('count','desc');
  62. }else{
  63. $table = $table->orderBy('updated_at','desc');
  64. }
  65. }
  66. if(isset($_GET["limit"])){
  67. $offset = 0;
  68. if(isset($_GET["offset"])){
  69. $offset = $_GET["offset"];
  70. }
  71. $table = $table->skip($offset)->take($_GET["limit"]);
  72. }
  73. $result = $table->get();
  74. if($result){
  75. return $this->ok(["rows"=>GroupResource::collection($result),"count"=>$count]);
  76. }else{
  77. return $this->error("没有查询到数据");
  78. }
  79. }
  80. /**
  81. * 获取我的,和协作channel数量
  82. *
  83. * @return \Illuminate\Http\Response
  84. */
  85. public function showMyNumber(Request $request){
  86. $user = AuthApi::current($request);
  87. if(!$user){
  88. return $this->error(__('auth.failed'));
  89. }
  90. //判断当前用户是否有指定的studio的权限
  91. $studioId = StudioApi::getIdByName($request->get('studio'));
  92. if($user['user_uid'] !== $studioId){
  93. return $this->error(__('auth.failed'));
  94. }
  95. //我的
  96. $my = GroupMember::where('user_id', $studioId)->where('power',0)->count();
  97. //协作
  98. $collaboration = GroupMember::where('user_id', $studioId)->where('power','<>',0)->count();
  99. return $this->ok(['my'=>$my,'collaboration'=>$collaboration]);
  100. }
  101. /**
  102. * Store a newly created resource in storage.
  103. *
  104. * @param \Illuminate\Http\Request $request
  105. * @return \Illuminate\Http\Response
  106. */
  107. public function store(Request $request)
  108. {
  109. //
  110. $user = AuthApi::current($request);
  111. if(!$user){
  112. return $this->error(__('auth.failed'));
  113. }
  114. //判断当前用户是否有指定的studio的权限
  115. if($user['user_uid'] !== StudioApi::getIdByName($request->get('studio_name'))){
  116. return $this->error(__('auth.failed'));
  117. }
  118. //查询是否重复
  119. if(GroupInfo::where('name',$request->get('name'))->where('owner',$user['user_uid'])->exists()){
  120. return $this->error(__('validation.exists',['name']));
  121. }
  122. $studioId = StudioApi::getIdByName($request->get('studio_name'));
  123. $group = new GroupInfo;
  124. DB::transaction(function() use($group,$request,$user,$studioId){
  125. $group->id = app('snowflake')->id();
  126. $group->uid = Str::uuid();
  127. $group->name = $request->get('name');
  128. $group->owner = $studioId;
  129. $group->create_time = time()*1000;
  130. $group->modify_time = time()*1000;
  131. $group->save();
  132. $newMember = new GroupMember();
  133. $newMember->id=app('snowflake')->id();
  134. $newMember->user_id = $studioId;
  135. $newMember->group_id = $group->uid;
  136. $newMember->power = 0;
  137. $newMember->group_name = $request->get('name');
  138. $newMember->save();
  139. });
  140. return $this->ok($group);
  141. }
  142. /**
  143. * Display the specified resource.
  144. *
  145. * @param string $id
  146. * @return \Illuminate\Http\Response
  147. */
  148. public function show(Request $request,$id)
  149. {
  150. //
  151. $indexCol = ['uid','name','description','owner','updated_at','created_at'];
  152. $result = GroupInfo::select($indexCol)->where('uid', $id)->first();
  153. if(!$result){
  154. return $this->error("没有查询到数据");
  155. }
  156. if($result->status<30){
  157. //私有,判断权限
  158. $user = AuthApi::current($request);
  159. if(!$user){
  160. return $this->error(__('auth.failed'));
  161. }
  162. //判断当前用户是否有指定的studio的权限
  163. if($user['user_uid'] !== $result->owner){
  164. //非所有者
  165. //TODO 判断是否协作
  166. return $this->error(__('auth.failed'));
  167. }
  168. }
  169. return $this->ok(new GroupResource($result));
  170. }
  171. /**
  172. * Update the specified resource in storage.
  173. *
  174. * @param \Illuminate\Http\Request $request
  175. * @param \App\Models\GroupInfo $group
  176. * @return \Illuminate\Http\Response
  177. */
  178. public function update(Request $request, GroupInfo $group)
  179. {
  180. //
  181. $user = AuthApi::current($request);
  182. if(!$user){
  183. return $this->error(__('auth.failed'));
  184. }
  185. //判断当前用户是否有修改权限
  186. if($user['user_uid'] !== $group->owner){
  187. return $this->error(__('auth.failed'));
  188. }
  189. $group->name = $request->get('name');
  190. $group->description = $request->get('description');
  191. if($request->has('status')) { $group->status = $request->get('status'); }
  192. $group->create_time = time()*1000;
  193. $group->modify_time = time()*1000;
  194. $group->save();
  195. return $this->ok($group);
  196. }
  197. /**
  198. * Remove the specified resource from storage.
  199. * @param \Illuminate\Http\Request $request
  200. * @param \App\Models\GroupInfo $group
  201. * @return \Illuminate\Http\Response
  202. */
  203. public function destroy(Request $request,GroupInfo $group)
  204. {
  205. //
  206. $user = AuthApi::current($request);
  207. if(!$user){
  208. return $this->error(__('auth.failed'));
  209. }
  210. //判断当前用户是否有指定的 group 的删除权限
  211. if($user['user_uid'] !== $group->owner){
  212. return $this->error(__('auth.failed'));
  213. }
  214. $delete = 0;
  215. DB::transaction(function() use($group,$delete){
  216. //删除group member
  217. $memberDelete = GroupMember::where('group_id',$group->uid)->delete();
  218. $delete = $group->delete();
  219. });
  220. return $this->ok($delete);
  221. }
  222. }