ShareController.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\Share;
  4. use App\Models\GroupInfo;
  5. use App\Models\Article;
  6. use App\Models\Collection;
  7. use Illuminate\Http\Request;
  8. use App\Http\Resources\ShareResource;
  9. use App\Http\Api\AuthApi;
  10. use App\Http\Api\ShareApi;
  11. class ShareController extends Controller
  12. {
  13. /**
  14. * Display a listing of the resource.
  15. *
  16. * @return \Illuminate\Http\Response
  17. */
  18. public function index(Request $request)
  19. {
  20. //
  21. $user = AuthApi::current($request);
  22. $result=false;
  23. $role = "member";
  24. $indexCol = ['id','res_id','res_type','power','updated_at','created_at'];
  25. switch ($request->get('view')) {
  26. case 'res':
  27. if(!$user){
  28. return $this->error(__('auth.failed'));
  29. }
  30. $table = Share::where('res_id',$request->get('id'));
  31. $power = ShareApi::getResPower($user['user_uid'],$request->get('id'),$table->value('res_type'));
  32. switch ($power) {
  33. case 10:
  34. $role = "member";
  35. break;
  36. case 20:
  37. $role = "editor";
  38. break;
  39. case 30:
  40. $role = "owner";
  41. break;
  42. }
  43. break;
  44. case 'group':
  45. if(!$user){
  46. return $this->error(__('auth.failed'));
  47. }
  48. //TODO 判断当前用户是否有指定的 group 的权限
  49. if(GroupInfo::where('uid',$request->get('id'))->where('owner',$user['user_uid'])->exists()){
  50. $role = "owner";
  51. }
  52. $table = Share::where('cooperator_id', $request->get('id'));
  53. break;
  54. }
  55. if(isset($_GET["search"])){
  56. //TODO 搜索资源标题
  57. $table = $table->where('title', 'like', $_GET["search"]."%");
  58. }
  59. $count = $table->count();
  60. if(isset($_GET["order"]) && isset($_GET["dir"])){
  61. $table = $table->orderBy($_GET["order"],$_GET["dir"]);
  62. }else{
  63. $table = $table->orderBy('updated_at','desc');
  64. }
  65. $table->skip($request->get('offset',0))
  66. ->take($request->get('limit',1000));
  67. $result = $table->get();
  68. //TODO 获取当前用户的身份
  69. if($result){
  70. return $this->ok(["rows"=>ShareResource::collection($result),"count"=>$count,'role'=>$role]);
  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. foreach ($request->get('user_id') as $key => $value) {
  85. # code...
  86. $row = Share::where('cooperator_id',$value)
  87. ->where('res_id',$request->get('res_id'))->first();
  88. if(!$row){
  89. $row = new Share();
  90. $row->id = app('snowflake')->id();
  91. $row->cooperator_id = $value;
  92. $row->res_id = $request->get('res_id');
  93. $row->res_type = $request->get('res_type');
  94. $row->create_time = time()*1000;
  95. }
  96. $c_type=['user'=>0,'group'=>1];
  97. $row->cooperator_type = $c_type[$request->get('user_type')];
  98. switch ($request->get('role')) {
  99. case 'manager':
  100. case 'editor':
  101. $row->power = 20;
  102. break;
  103. case 'reader':
  104. $row->power = 10;
  105. break;
  106. }
  107. $row->modify_time = time()*1000;
  108. $row->save();
  109. }
  110. return $this->ok(count($request->get('user_id')));
  111. }
  112. /**
  113. * Display the specified resource.
  114. *
  115. * @param \App\Models\Share $share
  116. * @return \Illuminate\Http\Response
  117. */
  118. public function show(Share $share)
  119. {
  120. //
  121. }
  122. /**
  123. * Update the specified resource in storage.
  124. *
  125. * @param \Illuminate\Http\Request $request
  126. * @param \App\Models\Share $share
  127. * @return \Illuminate\Http\Response
  128. */
  129. public function update(Request $request, Share $share)
  130. {
  131. //查询权限
  132. $currUser = AuthApi::current($request);
  133. if(!$currUser){
  134. return $this->error(__('auth.failed'));
  135. }
  136. $power = ShareApi::getResPower($currUser['user_uid'],$share->res_id,$share->res_type);
  137. if(!$power || $power <= 20){
  138. //普通成员没有删除权限
  139. return $this->error(__('auth.failed'));
  140. }
  141. switch ($request->get('role')) {
  142. case 'manager':
  143. case 'editor':
  144. $share->power = 20;
  145. break;
  146. case 'reader':
  147. $share->power = 10;
  148. break;
  149. }
  150. $share->modify_time = time()*1000;
  151. $share->save();
  152. return $this->ok($share);
  153. }
  154. /**
  155. * Remove the specified resource from storage.
  156. *
  157. * @param \Illuminate\Http\Request $request
  158. * @param \App\Models\Share $share
  159. * @return \Illuminate\Http\Response
  160. */
  161. public function destroy(Request $request, Share $share)
  162. {
  163. //查询权限
  164. $currUser = AuthApi::current($request);
  165. if(!$currUser){
  166. return $this->error(__('auth.failed'));
  167. }
  168. $power = ShareApi::getResPower($currUser['user_uid'],$share->res_id,$share->res_type);
  169. if(!$power || $power <= 20){
  170. //普通成员没有删除权限
  171. return $this->error(__('auth.failed'));
  172. }
  173. $delete = $share->delete();
  174. return $this->ok($delete);
  175. }
  176. }