GroupController.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  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. require_once __DIR__.'/../../../public/app/ucenter/function.php';
  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. $userinfo = new \UserInfo();
  23. $result=false;
  24. $indexCol = ['uid','name','description','owner','updated_at','created_at'];
  25. switch ($request->get('view')) {
  26. case 'studio':
  27. # 获取studio内所有group
  28. $user = AuthApi::current($request);
  29. if(!$user){
  30. return $this->error(__('auth.failed'));
  31. }
  32. //判断当前用户是否有指定的studio的权限
  33. if($user['user_uid'] !== StudioApi::getIdByName($request->get('name'))){
  34. return $this->error(__('auth.failed'));
  35. }
  36. $table = GroupInfo::select($indexCol)->where('owner', $user["user_uid"]);
  37. break;
  38. case 'key':
  39. $table = GroupInfo::select($indexCol)->where('name','like', $request->get('key')."%");
  40. break;
  41. }
  42. if(isset($_GET["search"])){
  43. $table = $table->where('title', 'like', $_GET["search"]."%");
  44. }
  45. $count = $table->count();
  46. if(isset($_GET["order"]) && isset($_GET["dir"])){
  47. $table = $table->orderBy($_GET["order"],$_GET["dir"]);
  48. }else{
  49. if($request->get('view') === 'studio_list'){
  50. $table = $table->orderBy('count','desc');
  51. }else{
  52. $table = $table->orderBy('updated_at','desc');
  53. }
  54. }
  55. if(isset($_GET["limit"])){
  56. $offset = 0;
  57. if(isset($_GET["offset"])){
  58. $offset = $_GET["offset"];
  59. }
  60. $table = $table->skip($offset)->take($_GET["limit"]);
  61. }
  62. $result = $table->get();
  63. if($result){
  64. foreach ($result as $key => $value) {
  65. # code...
  66. $value->role = 'owner';
  67. $value->studio = [
  68. 'id'=>$value->owner,
  69. 'nickName'=>$userinfo->getName($value->owner)['nickname'],
  70. 'studioName'=>$userinfo->getName($value->owner)['username'],
  71. 'avastar'=>'',
  72. 'owner' => [
  73. 'id'=>$value->owner,
  74. 'nickName'=>$userinfo->getName($value->owner)['nickname'],
  75. 'userName'=>$userinfo->getName($value->owner)['username'],
  76. 'avastar'=>'',
  77. ]
  78. ];
  79. }
  80. return $this->ok(["rows"=>$result,"count"=>$count]);
  81. }else{
  82. return $this->error("没有查询到数据");
  83. }
  84. }
  85. /**
  86. * Store a newly created resource in storage.
  87. *
  88. * @param \Illuminate\Http\Request $request
  89. * @return \Illuminate\Http\Response
  90. */
  91. public function store(Request $request)
  92. {
  93. //
  94. $user = AuthApi::current($request);
  95. if(!$user){
  96. return $this->error(__('auth.failed'));
  97. }
  98. //判断当前用户是否有指定的studio的权限
  99. if($user['user_uid'] !== StudioApi::getIdByName($request->get('studio_name'))){
  100. return $this->error(__('auth.failed'));
  101. }
  102. //查询是否重复
  103. if(GroupInfo::where('name',$request->get('name'))->where('owner',$user['user_uid'])->exists()){
  104. return $this->error(__('validation.exists',['name']));
  105. }
  106. $group = new GroupInfo;
  107. $group->id = app('snowflake')->id();
  108. $group->uid = Str::uuid();
  109. $group->name = $request->get('name');
  110. $group->owner = $user['user_uid'];
  111. $group->create_time = time()*1000;
  112. $group->modify_time = time()*1000;
  113. $group->save();
  114. return $this->ok($group);
  115. }
  116. /**
  117. * Display the specified resource.
  118. *
  119. * @param string $id
  120. * @return \Illuminate\Http\Response
  121. */
  122. public function show(Request $request,$id)
  123. {
  124. //
  125. $indexCol = ['uid','name','description','owner','updated_at','created_at'];
  126. $result = GroupInfo::select($indexCol)->where('uid', $id)->first();
  127. if(!$result){
  128. return $this->error("没有查询到数据");
  129. }
  130. if($result->status<30){
  131. //私有,判断权限
  132. $user = AuthApi::current($request);
  133. if(!$user){
  134. return $this->error(__('auth.failed'));
  135. }
  136. //判断当前用户是否有指定的studio的权限
  137. if($user['user_uid'] !== $result->owner){
  138. //非所有者
  139. //TODO 判断是否协作
  140. return $this->error(__('auth.failed'));
  141. }
  142. }
  143. return $this->ok($result);
  144. }
  145. /**
  146. * Update the specified resource in storage.
  147. *
  148. * @param \Illuminate\Http\Request $request
  149. * @param \App\Models\GroupInfo $group
  150. * @return \Illuminate\Http\Response
  151. */
  152. public function update(Request $request, GroupInfo $group)
  153. {
  154. //
  155. $user = AuthApi::current($request);
  156. if(!$user){
  157. return $this->error(__('auth.failed'));
  158. }
  159. //判断当前用户是否有修改权限
  160. if($user['user_uid'] !== $group->owner){
  161. return $this->error(__('auth.failed'));
  162. }
  163. $group->name = $request->get('name');
  164. $group->description = $request->get('description');
  165. if($request->has('status')) { $group->status = $request->get('status'); }
  166. $group->create_time = time()*1000;
  167. $group->modify_time = time()*1000;
  168. $group->save();
  169. return $this->ok($group);
  170. }
  171. /**
  172. * Remove the specified resource from storage.
  173. * @param \Illuminate\Http\Request $request
  174. * @param \App\Models\GroupInfo $group
  175. * @return \Illuminate\Http\Response
  176. */
  177. public function destroy(Request $request,GroupInfo $group)
  178. {
  179. //
  180. $user = AuthApi::current($request);
  181. if(!$user){
  182. return $this->error(__('auth.failed'));
  183. }
  184. //判断当前用户是否有指定的 group 的删除权限
  185. if($user['user_uid'] !== $group->owner){
  186. return $this->error(__('auth.failed'));
  187. }
  188. $delete = 0;
  189. DB::transaction(function() use($group,$delete){
  190. //删除group member
  191. $memberDelete = GroupMember::where('group_id',$group->uid)->delete();
  192. $delete = $group->delete();
  193. });
  194. return $this->ok($delete);
  195. }
  196. }