GroupController.php 6.6 KB

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