get(); foreach ($plans as $k => $v) { $plans[$k]->count = 0; foreach ($counts as $kk => $vv) { if ($plans[$k]->id === $counts[$kk]->plan_id) $plans[$k]->count = $counts[$kk]->count; } } return response([ 'data' => $plans ]); } public function save(PlanSave $request) { $params = $request->validated(); if ($request->input('id')) { $plan = Plan::find($request->input('id')); if (!$plan) { throw new ApiException(500, '该订阅不存在'); } DB::beginTransaction(); // update user group id and transfer try { if ($request->input('force_update')) { User::where('plan_id', $plan->id)->update([ 'group_id' => $params['group_id'], 'transfer_enable' => $params['transfer_enable'] * 1073741824, 'speed_limit' => $params['speed_limit'] ]); } $plan->update($params); } catch (\Exception $e) { DB::rollBack(); throw new ApiException(500, '保存失败'); } DB::commit(); return response([ 'data' => true ]); } if (!Plan::create($params)) { throw new ApiException(500, '创建失败'); } return response([ 'data' => true ]); } public function drop(Request $request) { if (Order::where('plan_id', $request->input('id'))->first()) { throw new ApiException(500, '该订阅下存在订单无法删除'); } if (User::where('plan_id', $request->input('id'))->first()) { throw new ApiException(500, '该订阅下存在用户无法删除'); } if ($request->input('id')) { $plan = Plan::find($request->input('id')); if (!$plan) { throw new ApiException(500, '该订阅ID不存在'); } } return response([ 'data' => $plan->delete() ]); } public function update(PlanUpdate $request) { $updateData = $request->only([ 'show', 'renew' ]); $plan = Plan::find($request->input('id')); if (!$plan) { throw new ApiException(500, '该订阅不存在'); } try { $plan->update($updateData); } catch (\Exception $e) { throw new ApiException(500, '保存失败'); } return response([ 'data' => true ]); } public function sort(PlanSort $request) { DB::beginTransaction(); foreach ($request->input('plan_ids') as $k => $v) { if (!Plan::find($v)->update(['sort' => $k + 1])) { DB::rollBack(); throw new ApiException(500, '保存失败'); } } DB::commit(); return response([ 'data' => true ]); } }