Files
ProxyPanel/app/Http/Controllers/Admin/UserGroupController.php
兔姬桑 2a4bf701f2 Add RBAC Module & More
1. 添加RBAC的权限&角色控制件;
2. 将用户‘is_admin’转换为角色;
3. 针对RBAC对管理页面进行定制化处理;
4. 加深layout分层处理;
5. 修改部分路由名称;
6. 分解路由文件至多文件;
2020-12-11 16:14:30 +08:00

95 lines
2.8 KiB
PHP

<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Models\Node;
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 index(Request $request)
{
$view['list'] = UserGroup::paginate(15)->appends($request->except('page'));
return view('admin.user.group.index', $view);
}
// 添加用户分组页面
public function create()
{
$nodes = Node::whereStatus(1)->pluck('name', 'id');
return view('admin.user.group.info', compact('nodes'));
}
// 添加用户分组
public function store(Request $request): RedirectResponse
{
$validator = Validator::make($request->all(), ['name' => 'required']);
if ($validator->fails()) {
return Redirect::back()->withInput()->withErrors($validator->errors());
}
$userGroup = UserGroup::create(['name' => $request->input('name'), 'nodes' => $request->input('nodes')]);
if ($userGroup) {
return Redirect::route('admin.user.group.edit', $userGroup)->with('successMsg', '操作成功');
}
return Redirect::back()->withInput()->withErrors('操作失败');
}
// 编辑用户分组页面
public function edit(UserGroup $group)
{
$nodes = Node::whereStatus(1)->pluck('name', 'id');
return view('admin.user.group.info', compact('group', 'nodes'));
}
// 编辑用户分组
public function update(Request $request, UserGroup $group)
{
$validator = Validator::make($request->all(), ['name' => 'required']);
if ($validator->fails()) {
return Redirect::back()->withInput()->withErrors($validator->errors());
}
$group->name = $request->input('name');
$group->nodes = $request->input('nodes');
if ($group->save()) {
return Redirect::back()->with('successMsg', '操作成功');
}
return Redirect::back()->withInput()->withErrors('操作失败');
}
// 删除用户分组
public function destroy(UserGroup $group): JsonResponse
{
// 校验该分组下是否存在关联账号
if (User::whereGroupId($group->id)->count()) {
return Response::json(['status' => 'fail', 'message' => '该分组下存在关联账号,请先取消关联!']);
}
try {
$group->delete();
} catch (Exception $e) {
return Response::json(['status' => 'fail', 'message' => '删除失败,'.$e->getMessage()]);
}
return Response::json(['status' => 'success', 'message' => '清理成功']);
}
}