ShareController.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  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. if(isset($_GET["limit"])){
  66. $offset = 0;
  67. if(isset($_GET["offset"])){
  68. $offset = $_GET["offset"];
  69. }
  70. $table = $table->skip($offset)->take($_GET["limit"]);
  71. }
  72. $result = $table->get();
  73. //TODO 获取当前用户的身份
  74. if($result){
  75. return $this->ok(["rows"=>ShareResource::collection($result),"count"=>$count,'role'=>$role]);
  76. }else{
  77. return $this->error("没有查询到数据");
  78. }
  79. }
  80. /**
  81. * Store a newly created resource in storage.
  82. *
  83. * @param \Illuminate\Http\Request $request
  84. * @return \Illuminate\Http\Response
  85. */
  86. public function store(Request $request)
  87. {
  88. //
  89. foreach ($request->get('user_id') as $key => $value) {
  90. # code...
  91. $row = Share::where('cooperator_id',$value)
  92. ->where('res_id',$request->get('res_id'))->first();
  93. if(!$row){
  94. $row = new Share();
  95. $row->id = app('snowflake')->id();
  96. $row->cooperator_id = $value;
  97. $row->res_id = $request->get('res_id');
  98. $row->res_type = $request->get('res_type');
  99. $row->create_time = time()*1000;
  100. }
  101. $c_type=['user'=>0,'group'=>1];
  102. $row->cooperator_type = $c_type[$request->get('user_type')];
  103. switch ($request->get('role')) {
  104. case 'manager':
  105. case 'editor':
  106. $row->power = 20;
  107. break;
  108. case 'reader':
  109. $row->power = 10;
  110. break;
  111. }
  112. $row->modify_time = time()*1000;
  113. $row->save();
  114. }
  115. return $this->ok(count($request->get('user_id')));
  116. }
  117. /**
  118. * Display the specified resource.
  119. *
  120. * @param \App\Models\Share $share
  121. * @return \Illuminate\Http\Response
  122. */
  123. public function show(Share $share)
  124. {
  125. //
  126. }
  127. /**
  128. * Update the specified resource in storage.
  129. *
  130. * @param \Illuminate\Http\Request $request
  131. * @param \App\Models\Share $share
  132. * @return \Illuminate\Http\Response
  133. */
  134. public function update(Request $request, Share $share)
  135. {
  136. //查询权限
  137. $currUser = AuthApi::current($request);
  138. if(!$currUser){
  139. return $this->error(__('auth.failed'));
  140. }
  141. $power = ShareApi::getResPower($currUser['user_uid'],$share->res_id,$share->res_type);
  142. if(!$power || $power <= 20){
  143. //普通成员没有删除权限
  144. return $this->error(__('auth.failed'));
  145. }
  146. switch ($request->get('role')) {
  147. case 'manager':
  148. case 'editor':
  149. $share->power = 20;
  150. break;
  151. case 'reader':
  152. $share->power = 10;
  153. break;
  154. }
  155. $share->modify_time = time()*1000;
  156. $share->save();
  157. return $this->ok($share);
  158. }
  159. /**
  160. * Remove the specified resource from storage.
  161. *
  162. * @param \Illuminate\Http\Request $request
  163. * @param \App\Models\Share $share
  164. * @return \Illuminate\Http\Response
  165. */
  166. public function destroy(Request $request, Share $share)
  167. {
  168. //查询权限
  169. $currUser = AuthApi::current($request);
  170. if(!$currUser){
  171. return $this->error(__('auth.failed'));
  172. }
  173. $power = ShareApi::getResPower($currUser['user_uid'],$share->res_id,$share->res_type);
  174. if(!$power || $power <= 20){
  175. //普通成员没有删除权限
  176. return $this->error(__('auth.failed'));
  177. }
  178. $delete = $share->delete();
  179. return $this->ok($delete);
  180. }
  181. }