mirror of
https://github.com/ProxyPanel/ProxyPanel.git
synced 2026-04-05 03:58:39 +00:00
使用数据库5.7版本JSON特性, 并使用laravel特性做存储修改
This commit is contained in:
@@ -8,107 +8,73 @@ use App\Models\User;
|
||||
use App\Models\UserGroup;
|
||||
use Exception;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Redirect;
|
||||
use Response;
|
||||
use Validator;
|
||||
|
||||
class UserGroupController extends Controller {
|
||||
public function userGroupList(Request $request): \Illuminate\Http\Response {
|
||||
$view['list'] = UserGroup::query()->paginate(15)->appends($request->except('page'));
|
||||
return Response::view('admin.group.groupList', $view);
|
||||
public function index(): \Illuminate\Http\Response {
|
||||
$view['list'] = UserGroup::query()->paginate(15);
|
||||
return Response::view('admin.user.group.index', $view);
|
||||
}
|
||||
|
||||
// 添加用户分组页面
|
||||
public function create(): \Illuminate\Http\Response {
|
||||
$view['nodeList'] = Node::query()->whereStatus(1)->get();
|
||||
return Response::view('admin.user.group.info', $view);
|
||||
}
|
||||
|
||||
// 添加用户分组
|
||||
public function addUserGroup(Request $request) {
|
||||
if($request->isMethod('POST')){
|
||||
$validator = Validator::make($request->all(), [
|
||||
'name' => 'required',
|
||||
'nodes' => 'required',
|
||||
]);
|
||||
public function store(Request $request): RedirectResponse {
|
||||
$validator = Validator::make($request->all(), [
|
||||
'name' => 'required',
|
||||
'nodes' => 'required',
|
||||
]);
|
||||
|
||||
if($validator->fails()){
|
||||
return Redirect::back()->withInput()->withErrors($validator->errors());
|
||||
}
|
||||
|
||||
$ret = UserGroup::query()->insert([
|
||||
'name' => $request->input('name'),
|
||||
'nodes' => implode(',', $request->input('nodes'))
|
||||
]);
|
||||
|
||||
if($ret){
|
||||
return Redirect::back()->with('successMsg', '操作成功');
|
||||
}
|
||||
return Redirect::back()->withInput()->withErrors('操作失败');
|
||||
if($validator->fails()){
|
||||
return Redirect::back()->withInput()->withErrors($validator->errors());
|
||||
}
|
||||
|
||||
$obj = new UserGroup();
|
||||
$obj->name = $request->input('name');
|
||||
$obj->nodes = $request->input('nodes');
|
||||
$obj->save();
|
||||
|
||||
if($obj->id){
|
||||
return Redirect::back()->with('successMsg', '操作成功');
|
||||
}
|
||||
return Redirect::back()->withInput()->withErrors('操作失败');
|
||||
}
|
||||
|
||||
// 编辑用户分组页面
|
||||
public function edit($id): \Illuminate\Http\Response {
|
||||
$view['userGroup'] = UserGroup::findOrFail($id);
|
||||
$view['nodeList'] = Node::query()->whereStatus(1)->get();
|
||||
return Response::view('admin.group.groupInfo', $view);
|
||||
|
||||
return Response::view('admin.user.group.info', $view);
|
||||
}
|
||||
|
||||
// 编辑用户分组
|
||||
public function editUserGroup(Request $request) {
|
||||
$id = $request->input('id');
|
||||
if($request->isMethod('POST')){
|
||||
$validator = Validator::make($request->all(), [
|
||||
'id' => 'required',
|
||||
'name' => 'required',
|
||||
]);
|
||||
|
||||
if($validator->fails()){
|
||||
return Redirect::back()->withInput()->withErrors($validator->errors());
|
||||
}
|
||||
$name = $request->input('name');
|
||||
$nodes = $request->input('nodes');
|
||||
$userGroup = UserGroup::find($id);
|
||||
if(!$userGroup){
|
||||
return Redirect::back()->withInput()->withErrors('未找到需要编辑的用户分组!');
|
||||
}
|
||||
|
||||
$data = [];
|
||||
if($userGroup->name != $name){
|
||||
$data['name'] = $name;
|
||||
}
|
||||
|
||||
if($nodes){
|
||||
$nodeStr = implode(',', $nodes);
|
||||
if($userGroup->nodes != $nodeStr){
|
||||
$data['nodes'] = $nodeStr;
|
||||
}elseif($data == []){
|
||||
return Redirect::back()->with('successMsg', '检测为未修改,无变动!');
|
||||
}
|
||||
}elseif(isset($userGroup->nodes)){
|
||||
$data['nodes'] = $nodes;
|
||||
}
|
||||
$ret = UserGroup::query()->whereId($id)->update($data);
|
||||
if($ret){
|
||||
return Redirect::back()->with('successMsg', '操作成功');
|
||||
}
|
||||
return Redirect::back()->withInput()->withErrors('操作失败');
|
||||
public function update(Request $request, $id) {
|
||||
$userGroup = UserGroup::findOrFail($id);
|
||||
$userGroup->name = $request->input('name');
|
||||
$userGroup->nodes = $request->input('nodes');
|
||||
if($userGroup->save()){
|
||||
return Redirect::back()->with('successMsg', '操作成功');
|
||||
}
|
||||
|
||||
$userGroup = UserGroup::find($id);
|
||||
if(!$userGroup){
|
||||
return Redirect::back();
|
||||
}
|
||||
$view['nodeList'] = Node::query()->whereStatus(1)->get();
|
||||
|
||||
return view('admin.group.groupInfo', $view)->with(compact('userGroup'));
|
||||
return Redirect::back()->withInput()->withErrors('操作失败');
|
||||
}
|
||||
|
||||
// 删除用户分组
|
||||
public function delUserGroup(Request $request): JsonResponse {
|
||||
$id = $request->input('id');
|
||||
public function destroy($id): JsonResponse {
|
||||
// 校验该分组下是否存在关联账号
|
||||
$userCount = User::query()->whereGroupId($id)->count();
|
||||
if($userCount){
|
||||
if(User::query()->whereGroupId($id)->count()){
|
||||
return Response::json(['status' => 'fail', 'message' => '该分组下存在关联账号,请先取消关联!']);
|
||||
}
|
||||
|
||||
$userGroup = UserGroup::find($id);
|
||||
if(!$userGroup){
|
||||
return Response::json(['status' => 'fail', 'message' => '删除失败,未找到用户分组']);
|
||||
}
|
||||
|
||||
try{
|
||||
UserGroup::query()->whereId($id)->delete();
|
||||
}catch(Exception $e){
|
||||
|
||||
Reference in New Issue
Block a user