| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 |
- <?php
- namespace App\Http\Controllers;
- use App\Models\Transfer;
- use App\Models\Channel;
- use App\Models\Article;
- use Illuminate\Http\Request;
- use App\Http\Api\AuthApi;
- use App\Http\Api\StudioApi;
- use App\Http\Api\UserApi;
- use App\Http\Resources\TransferResource;
- use Illuminate\Support\Facades\DB;
- use Illuminate\Support\Facades\Log;
- class TransferController extends Controller
- {
- /**
- * Display a listing of the resource.
- *
- * @return \Illuminate\Http\Response
- */
- public function index(Request $request)
- {
- switch ($request->input('view')) {
- case 'studio':
- # 获取studio内所有channel
- $user = AuthApi::current($request);
- if (!$user) {
- return $this->error(__('auth.failed'));
- }
- //判断当前用户是否有指定的studio的管理权限
- $studioId = StudioApi::getIdByName($request->input('name'));
- if ($user['user_uid'] !== $studioId) {
- return $this->error(__('auth.failed'));
- }
- switch ($request->input('view2')) {
- case 'in':
- $table = Transfer::where('new_owner', $studioId);
- break;
- case 'out':
- $table = Transfer::where('origin_owner', $studioId);
- break;
- default:
- return $this->error('no view2');
- break;
- }
- $outNumber = Transfer::where('origin_owner', $studioId)
- ->where('status', 'transferred')
- ->count();
- $inNumber = Transfer::where('new_owner', $studioId)
- ->where('status', 'transferred')
- ->count();
- break;
- }
- if (!empty($search)) {
- $table->where('title', 'like', $search . "%");
- }
- $table->orderBy(
- $request->input('order', 'updated_at'),
- $request->input('dir', 'desc')
- );
- $count = $table->count();
- $table->skip($request->input("offset", 0))
- ->take($request->input('limit', 100));
- $result = $table->get();
- return $this->ok([
- "rows" => TransferResource::collection($result),
- "count" => $count,
- 'out' => $outNumber,
- 'in' => $inNumber,
- ]);
- }
- /**
- * Store a newly created resource in storage.
- *
- * @param \Illuminate\Http\Request $request
- * @return \Illuminate\Http\Response
- */
- public function store(Request $request)
- {
- $user = AuthApi::current($request);
- if (!$user) {
- return $this->error(__('auth.failed'));
- }
- //
- // validate
- // read more on validation at http://laravel.com/docs/validation
- $rules = array(
- 'res_id' => 'required',
- 'res_type' => 'required',
- 'new_owner' => 'required',
- );
- $validated = $request->validate($rules);
- $resId = $request->input('res_id');
- foreach ($resId as $id) {
- $transfer = new Transfer;
- //查看权限
- switch ($request->input('res_type')) {
- case 'channel':
- $oldRes = Channel::find($id);
- if ($oldRes->owner_uid !== $user['user_uid']) {
- return $this->error(__('auth.failed'), [403], 403);
- }
- $transfer->origin_owner = $oldRes->owner_uid;
- break;
- case 'article':
- $oldRes = Article::find($id);
- if ($oldRes->owner !== $user['user_uid']) {
- return $this->error(__('auth.failed'), [403], 403);
- }
- $transfer->origin_owner = $oldRes->owner;
- break;
- default:
- # code...
- break;
- }
- //查重
- if (Transfer::where('res_id', $id)
- ->where('res_type', $request->input('res_type'))
- ->where('status', 'transferred')
- ->exists()
- ) {
- return $this->error('该资源已经进入转让流程', [200], 200);
- }
- $transfer->res_id = $id;
- $transfer->res_type = $request->input('res_type');
- $transfer->transferor_id = $user['user_uid'];
- $transfer->new_owner = $request->input('new_owner');
- $transfer->save();
- }
- return $this->ok(count($resId));
- }
- /**
- * Display the specified resource.
- *
- * @param \App\Models\Transfer $transfer
- * @return \Illuminate\Http\Response
- */
- public function show(Transfer $transfer)
- {
- //
- return $this->ok(new TransferResource($discussion));
- }
- /**
- * Update the specified resource in storage.
- *
- * @param \Illuminate\Http\Request $request
- * @param \App\Models\Transfer $transfer
- * @return \Illuminate\Http\Response
- */
- public function update(Request $request, Transfer $transfer)
- {
- $user = AuthApi::current($request);
- if (!$user) {
- return $this->error(__('auth.failed'), [403], 403);
- }
- //权限
- switch ($request->input('status')) {
- case 'accept':
- case 'refuse':
- if ($transfer->new_owner !== $user['user_uid']) {
- return $this->error(__('auth.failed'), [403], 403);
- }
- $transfer->status = $request->input('status');
- break;
- case 'cancel':
- if ($transfer->origin_owner !== $user['user_uid']) {
- return $this->error(__('auth.failed'), [403], 403);
- }
- $transfer->status = 'cancel';
- break;
- default:
- return $this->error(__('auth.failed'), [404], 404);
- break;
- }
- try {
- DB::transaction(function () use ($transfer, $request, $user) {
- $transfer->editor_id = $user['user_uid'];
- $transfer->save();
- if ($request->input('status') === 'accept') {
- $newOwner = UserApi::getByUuid($transfer->new_owner);
- $isBasic = false;
- if (isset($newOwner['roles']) && is_array($newOwner['roles'])) {
- $isBasic = in_array('basic', $newOwner['roles']);
- }
- switch ($transfer->res_type) {
- case 'channel':
- $newData = ['owner_uid' => $transfer->new_owner];
- if ($isBasic) {
- $newData['status'] = 5;
- }
- Channel::where('uid', $transfer->res_id)
- ->update($newData);
- break;
- case 'article':
- $userId = UserApi::getIdByUuid($transfer->new_owner);
- $newData = ['owner' => $transfer->new_owner, 'owner_id' => $userId];
- if ($isBasic) {
- $newData['status'] = 10;
- }
- Article::where('uid', $transfer->res_id)
- ->update($newData);
- break;
- default:
- # code...
- break;
- }
- }
- });
- } catch (\Exception $e) {
- Log::error('update.fail', ['error' => $e]);
- return $this->error('update.fail', ['message' => $e], 500);
- }
- return $this->ok(new TransferResource($transfer));
- }
- /**
- * Remove the specified resource from storage.
- *
- * @param \App\Models\Transfer $transfer
- * @return \Illuminate\Http\Response
- */
- public function destroy(Transfer $transfer)
- {
- //
- }
- }
|