ShareController.php 5.9 KB

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