GroupController.php 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  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 'all':
  50. $table = GroupInfo::select($indexCol);
  51. break;
  52. }
  53. if ($request->has("search")) {
  54. $table = $table->where('name', 'like', "%" . $request->get("search") . "%");
  55. }
  56. $count = $table->count();
  57. if ($request->get('view') === 'studio_list') {
  58. $table = $table->orderBy('count', 'desc');
  59. } else {
  60. $table = $table->orderBy(
  61. $request->get('order', 'updated_at'),
  62. $request->get('dir', 'desc')
  63. );
  64. }
  65. $table->skip($request->get('offset', 0))
  66. ->take($request->get('limit', 1000));
  67. $result = $table->get();
  68. if ($result) {
  69. return $this->ok(["rows" => GroupResource::collection($result), "count" => $count]);
  70. } else {
  71. return $this->error("没有查询到数据");
  72. }
  73. }
  74. /**
  75. * 获取我的,和协作channel数量
  76. *
  77. * @return \Illuminate\Http\Response
  78. */
  79. public function showMyNumber(Request $request)
  80. {
  81. $user = AuthApi::current($request);
  82. if (!$user) {
  83. return $this->error(__('auth.failed'));
  84. }
  85. //判断当前用户是否有指定的studio的权限
  86. $studioId = StudioApi::getIdByName($request->get('studio'));
  87. if ($user['user_uid'] !== $studioId) {
  88. return $this->error(__('auth.failed'));
  89. }
  90. //我的
  91. $my = GroupMember::where('user_id', $studioId)->where('power', 0)->count();
  92. //协作
  93. $collaboration = GroupMember::where('user_id', $studioId)->where('power', '<>', 0)->count();
  94. return $this->ok(['my' => $my, 'collaboration' => $collaboration]);
  95. }
  96. /**
  97. * Store a newly created resource in storage.
  98. *
  99. * @param \Illuminate\Http\Request $request
  100. * @return \Illuminate\Http\Response
  101. */
  102. public function store(Request $request)
  103. {
  104. //
  105. $user = AuthApi::current($request);
  106. if (!$user) {
  107. return $this->error(__('auth.failed'));
  108. }
  109. //判断当前用户是否有指定的studio的权限
  110. if ($user['user_uid'] !== StudioApi::getIdByName($request->get('studio_name'))) {
  111. return $this->error(__('auth.failed'));
  112. }
  113. //查询是否重复
  114. if (GroupInfo::where('name', $request->get('name'))->where('owner', $user['user_uid'])->exists()) {
  115. return $this->error(__('validation.exists', ['name']));
  116. }
  117. $studioId = StudioApi::getIdByName($request->get('studio_name'));
  118. $group = new GroupInfo;
  119. DB::transaction(function () use ($group, $request, $user, $studioId) {
  120. $group->id = app('snowflake')->id();
  121. $group->uid = Str::uuid();
  122. $group->name = $request->get('name');
  123. $group->owner = $studioId;
  124. $group->create_time = time() * 1000;
  125. $group->modify_time = time() * 1000;
  126. $group->save();
  127. $newMember = new GroupMember();
  128. $newMember->id = app('snowflake')->id();
  129. $newMember->user_id = $studioId;
  130. $newMember->group_id = $group->uid;
  131. $newMember->power = 0;
  132. $newMember->group_name = $request->get('name');
  133. $newMember->save();
  134. });
  135. return $this->ok($group);
  136. }
  137. /**
  138. * Display the specified resource.
  139. *
  140. * @param string $id
  141. * @return \Illuminate\Http\Response
  142. */
  143. public function show(Request $request, $id)
  144. {
  145. //
  146. $indexCol = ['uid', 'name', 'description', 'owner', 'updated_at', 'created_at'];
  147. $result = GroupInfo::select($indexCol)->where('uid', $id)->first();
  148. if (!$result) {
  149. return $this->error("没有查询到数据");
  150. }
  151. if ($result->status < 30) {
  152. //私有,判断权限
  153. $user = AuthApi::current($request);
  154. if (!$user) {
  155. return $this->error(__('auth.failed'));
  156. }
  157. //判断当前用户是否有指定的group的权限
  158. if ($user['user_uid'] !== $result->owner) {
  159. //非所有者
  160. //判断是否协作
  161. $power = GroupMember::where('group_id', $id)
  162. ->where('user_id', $user['user_uid'])
  163. ->value('power');
  164. if ($power === null) {
  165. return $this->error(__('auth.failed'));
  166. }
  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')) {
  192. $group->status = $request->get('status');
  193. }
  194. $group->create_time = time() * 1000;
  195. $group->modify_time = time() * 1000;
  196. $group->save();
  197. return $this->ok($group);
  198. }
  199. /**
  200. * Remove the specified resource from storage.
  201. * @param \Illuminate\Http\Request $request
  202. * @param \App\Models\GroupInfo $group
  203. * @return \Illuminate\Http\Response
  204. */
  205. public function destroy(Request $request, GroupInfo $group)
  206. {
  207. //
  208. $user = AuthApi::current($request);
  209. if (!$user) {
  210. return $this->error(__('auth.failed'));
  211. }
  212. //判断当前用户是否有指定的 group 的删除权限
  213. if ($user['user_uid'] !== $group->owner) {
  214. return $this->error(__('auth.failed'));
  215. }
  216. $delete = 0;
  217. DB::transaction(function () use ($group, $delete) {
  218. //删除group member
  219. $memberDelete = GroupMember::where('group_id', $group->uid)->delete();
  220. $delete = $group->delete();
  221. });
  222. return $this->ok($delete);
  223. }
  224. }