使用数据库5.7版本JSON特性, 并使用laravel特性做存储修改

This commit is contained in:
兔姬桑
2020-08-05 15:09:45 +08:00
parent 3adf8774d1
commit 76cf653ef5
25 changed files with 393 additions and 385 deletions

View File

@@ -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){