TransferController.php 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\Transfer;
  4. use App\Models\Channel;
  5. use App\Models\Article;
  6. use Illuminate\Http\Request;
  7. use App\Http\Api\AuthApi;
  8. use App\Http\Api\StudioApi;
  9. use App\Http\Api\UserApi;
  10. use App\Http\Resources\TransferResource;
  11. use Illuminate\Support\Facades\DB;
  12. use Illuminate\Support\Facades\Log;
  13. class TransferController extends Controller
  14. {
  15. /**
  16. * Display a listing of the resource.
  17. *
  18. * @return \Illuminate\Http\Response
  19. */
  20. public function index(Request $request)
  21. {
  22. switch ($request->input('view')) {
  23. case 'studio':
  24. # 获取studio内所有channel
  25. $user = AuthApi::current($request);
  26. if (!$user) {
  27. return $this->error(__('auth.failed'));
  28. }
  29. //判断当前用户是否有指定的studio的管理权限
  30. $studioId = StudioApi::getIdByName($request->input('name'));
  31. if ($user['user_uid'] !== $studioId) {
  32. return $this->error(__('auth.failed'));
  33. }
  34. switch ($request->input('view2')) {
  35. case 'in':
  36. $table = Transfer::where('new_owner', $studioId);
  37. break;
  38. case 'out':
  39. $table = Transfer::where('origin_owner', $studioId);
  40. break;
  41. default:
  42. return $this->error('no view2');
  43. break;
  44. }
  45. $outNumber = Transfer::where('origin_owner', $studioId)
  46. ->where('status', 'transferred')
  47. ->count();
  48. $inNumber = Transfer::where('new_owner', $studioId)
  49. ->where('status', 'transferred')
  50. ->count();
  51. break;
  52. }
  53. if (!empty($search)) {
  54. $table->where('title', 'like', $search . "%");
  55. }
  56. $table->orderBy(
  57. $request->input('order', 'updated_at'),
  58. $request->input('dir', 'desc')
  59. );
  60. $count = $table->count();
  61. $table->skip($request->input("offset", 0))
  62. ->take($request->input('limit', 100));
  63. $result = $table->get();
  64. return $this->ok([
  65. "rows" => TransferResource::collection($result),
  66. "count" => $count,
  67. 'out' => $outNumber,
  68. 'in' => $inNumber,
  69. ]);
  70. }
  71. /**
  72. * Store a newly created resource in storage.
  73. *
  74. * @param \Illuminate\Http\Request $request
  75. * @return \Illuminate\Http\Response
  76. */
  77. public function store(Request $request)
  78. {
  79. $user = AuthApi::current($request);
  80. if (!$user) {
  81. return $this->error(__('auth.failed'));
  82. }
  83. //
  84. // validate
  85. // read more on validation at http://laravel.com/docs/validation
  86. $rules = array(
  87. 'res_id' => 'required',
  88. 'res_type' => 'required',
  89. 'new_owner' => 'required',
  90. );
  91. $validated = $request->validate($rules);
  92. $resId = $request->input('res_id');
  93. foreach ($resId as $id) {
  94. $transfer = new Transfer;
  95. //查看权限
  96. switch ($request->input('res_type')) {
  97. case 'channel':
  98. $oldRes = Channel::find($id);
  99. if ($oldRes->owner_uid !== $user['user_uid']) {
  100. return $this->error(__('auth.failed'), [403], 403);
  101. }
  102. $transfer->origin_owner = $oldRes->owner_uid;
  103. break;
  104. case 'article':
  105. $oldRes = Article::find($id);
  106. if ($oldRes->owner !== $user['user_uid']) {
  107. return $this->error(__('auth.failed'), [403], 403);
  108. }
  109. $transfer->origin_owner = $oldRes->owner;
  110. break;
  111. default:
  112. # code...
  113. break;
  114. }
  115. //查重
  116. if (Transfer::where('res_id', $id)
  117. ->where('res_type', $request->input('res_type'))
  118. ->where('status', 'transferred')
  119. ->exists()
  120. ) {
  121. return $this->error('该资源已经进入转让流程', [200], 200);
  122. }
  123. $transfer->res_id = $id;
  124. $transfer->res_type = $request->input('res_type');
  125. $transfer->transferor_id = $user['user_uid'];
  126. $transfer->new_owner = $request->input('new_owner');
  127. $transfer->save();
  128. }
  129. return $this->ok(count($resId));
  130. }
  131. /**
  132. * Display the specified resource.
  133. *
  134. * @param \App\Models\Transfer $transfer
  135. * @return \Illuminate\Http\Response
  136. */
  137. public function show(Transfer $transfer)
  138. {
  139. //
  140. return $this->ok(new TransferResource($discussion));
  141. }
  142. /**
  143. * Update the specified resource in storage.
  144. *
  145. * @param \Illuminate\Http\Request $request
  146. * @param \App\Models\Transfer $transfer
  147. * @return \Illuminate\Http\Response
  148. */
  149. public function update(Request $request, Transfer $transfer)
  150. {
  151. $user = AuthApi::current($request);
  152. if (!$user) {
  153. return $this->error(__('auth.failed'), [403], 403);
  154. }
  155. //权限
  156. switch ($request->input('status')) {
  157. case 'accept':
  158. case 'refuse':
  159. if ($transfer->new_owner !== $user['user_uid']) {
  160. return $this->error(__('auth.failed'), [403], 403);
  161. }
  162. $transfer->status = $request->input('status');
  163. break;
  164. case 'cancel':
  165. if ($transfer->origin_owner !== $user['user_uid']) {
  166. return $this->error(__('auth.failed'), [403], 403);
  167. }
  168. $transfer->status = 'cancel';
  169. break;
  170. default:
  171. return $this->error(__('auth.failed'), [404], 404);
  172. break;
  173. }
  174. try {
  175. DB::transaction(function () use ($transfer, $request, $user) {
  176. $transfer->editor_id = $user['user_uid'];
  177. $transfer->save();
  178. if ($request->input('status') === 'accept') {
  179. $newOwner = UserApi::getByUuid($transfer->new_owner);
  180. $isBasic = false;
  181. if (isset($newOwner['roles']) && is_array($newOwner['roles'])) {
  182. $isBasic = in_array('basic', $newOwner['roles']);
  183. }
  184. switch ($transfer->res_type) {
  185. case 'channel':
  186. $newData = ['owner_uid' => $transfer->new_owner];
  187. if ($isBasic) {
  188. $newData['status'] = 5;
  189. }
  190. Channel::where('uid', $transfer->res_id)
  191. ->update($newData);
  192. break;
  193. case 'article':
  194. $userId = UserApi::getIdByUuid($transfer->new_owner);
  195. $newData = ['owner' => $transfer->new_owner, 'owner_id' => $userId];
  196. if ($isBasic) {
  197. $newData['status'] = 10;
  198. }
  199. Article::where('uid', $transfer->res_id)
  200. ->update($newData);
  201. break;
  202. default:
  203. # code...
  204. break;
  205. }
  206. }
  207. });
  208. } catch (\Exception $e) {
  209. Log::error('update.fail', ['error' => $e]);
  210. return $this->error('update.fail', ['message' => $e], 500);
  211. }
  212. return $this->ok(new TransferResource($transfer));
  213. }
  214. /**
  215. * Remove the specified resource from storage.
  216. *
  217. * @param \App\Models\Transfer $transfer
  218. * @return \Illuminate\Http\Response
  219. */
  220. public function destroy(Transfer $transfer)
  221. {
  222. //
  223. }
  224. }