| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380 | 
							- <?php
 
- // +—————————————————————————————————————————————————————————————————————
 
- // | Created by Yunbao
 
- // +—————————————————————————————————————————————————————————————————————
 
- // | Copyright (c) 2013~2022 http://www.yunbaokj.com All rights reserved.
 
- // +—————————————————————————————————————————————————————————————————————
 
- // | Author: https://gitee.com/yunbaokeji
 
- // +—————————————————————————————————————————————————————————————————————
 
- // | Date: 2022-04-30
 
- // +—————————————————————————————————————————————————————————————————————
 
- namespace app\admin\controller;
 
- use cmf\controller\AdminBaseController;
 
- use think\Db;
 
- use think\facade\Cache;
 
- use tree\Tree;
 
- use app\admin\model\AdminMenuModel;
 
- class RbacController extends AdminBaseController
 
- {
 
-     /**
 
-      * 角色管理列表
 
-      * @adminMenu(
 
-      *     'name'   => '角色管理',
 
-      *     'parent' => 'admin/User/default',
 
-      *     'display'=> true,
 
-      *     'hasView'=> true,
 
-      *     'order'  => 10000,
 
-      *     'icon'   => '',
 
-      *     'remark' => '角色管理',
 
-      *     'param'  => ''
 
-      * )
 
-      * @return mixed
 
-      * @throws \think\db\exception\DataNotFoundException
 
-      * @throws \think\db\exception\ModelNotFoundException
 
-      * @throws \think\exception\DbException
 
-      */
 
-     public function index()
 
-     {
 
-         $content = hook_one('admin_rbac_index_view');
 
-         if (!empty($content)) {
 
-             return $content;
 
-         }
 
-         $data = Db::name('role')->order(["list_order" => "ASC", "id" => "DESC"])->select();
 
-         $this->assign("roles", $data);
 
-         return $this->fetch();
 
-     }
 
-     /**
 
-      * 添加角色
 
-      * @adminMenu(
 
-      *     'name'   => '添加角色',
 
-      *     'parent' => 'index',
 
-      *     'display'=> false,
 
-      *     'hasView'=> true,
 
-      *     'order'  => 10000,
 
-      *     'icon'   => '',
 
-      *     'remark' => '添加角色',
 
-      *     'param'  => ''
 
-      * )
 
-      * @return mixed
 
-      */
 
-     public function roleAdd()
 
-     {
 
-         $content = hook_one('admin_rbac_role_add_view');
 
-         if (!empty($content)) {
 
-             return $content;
 
-         }
 
-         return $this->fetch();
 
-     }
 
-     /**
 
-      * 添加角色提交
 
-      * @adminMenu(
 
-      *     'name'   => '添加角色提交',
 
-      *     'parent' => 'index',
 
-      *     'display'=> false,
 
-      *     'hasView'=> false,
 
-      *     'order'  => 10000,
 
-      *     'icon'   => '',
 
-      *     'remark' => '添加角色提交',
 
-      *     'param'  => ''
 
-      * )
 
-      */
 
-     public function roleAddPost()
 
-     {
 
-         if ($this->request->isPost()) {
 
-             $data   = $this->request->param();
 
-             $result = $this->validate($data, 'role');
 
-             if ($result !== true) {
 
-                 // 验证失败 输出错误信息
 
-                 $this->error($result);
 
-             } else {
 
-                 $result = Db::name('role')->insert($data);
 
-                 if ($result) {
 
-                     $this->success("添加角色成功", url("rbac/index"));
 
-                 } else {
 
-                     $this->error("添加角色失败");
 
-                 }
 
-             }
 
-         }
 
-     }
 
-     /**
 
-      * 编辑角色
 
-      * @adminMenu(
 
-      *     'name'   => '编辑角色',
 
-      *     'parent' => 'index',
 
-      *     'display'=> false,
 
-      *     'hasView'=> true,
 
-      *     'order'  => 10000,
 
-      *     'icon'   => '',
 
-      *     'remark' => '编辑角色',
 
-      *     'param'  => ''
 
-      * )
 
-      * @return mixed
 
-      * @throws \think\db\exception\DataNotFoundException
 
-      * @throws \think\db\exception\ModelNotFoundException
 
-      * @throws \think\exception\DbException
 
-      */
 
-     public function roleEdit()
 
-     {
 
-         $content = hook_one('admin_rbac_role_edit_view');
 
-         if (!empty($content)) {
 
-             return $content;
 
-         }
 
-         $id = $this->request->param("id", 0, 'intval');
 
-         if ($id == 1) {
 
-             $this->error("超级管理员角色不能被修改!");
 
-         }
 
-         $data = Db::name('role')->where("id", $id)->find();
 
-         if (!$data) {
 
-             $this->error("该角色不存在!");
 
-         }
 
-         $this->assign("data", $data);
 
-         return $this->fetch();
 
-     }
 
-     /**
 
-      * 编辑角色提交
 
-      * @adminMenu(
 
-      *     'name'   => '编辑角色提交',
 
-      *     'parent' => 'index',
 
-      *     'display'=> false,
 
-      *     'hasView'=> false,
 
-      *     'order'  => 10000,
 
-      *     'icon'   => '',
 
-      *     'remark' => '编辑角色提交',
 
-      *     'param'  => ''
 
-      * )
 
-      * @throws \think\Exception
 
-      * @throws \think\exception\PDOException
 
-      */
 
-     public function roleEditPost()
 
-     {
 
-         $id = $this->request->param("id", 0, 'intval');
 
-         if ($id == 1) {
 
-             $this->error("超级管理员角色不能被修改!");
 
-         }
 
-         if ($this->request->isPost()) {
 
-             $data   = $this->request->param();
 
-             $result = $this->validate($data, 'role');
 
-             if ($result !== true) {
 
-                 // 验证失败 输出错误信息
 
-                 $this->error($result);
 
-             } else {
 
-                 if (Db::name('role')->update($data) !== false) {
 
-                     $this->success("保存成功!", url('rbac/index'));
 
-                 } else {
 
-                     $this->error("保存失败!");
 
-                 }
 
-             }
 
-         }
 
-     }
 
-     /**
 
-      * 删除角色
 
-      * @adminMenu(
 
-      *     'name'   => '删除角色',
 
-      *     'parent' => 'index',
 
-      *     'display'=> false,
 
-      *     'hasView'=> false,
 
-      *     'order'  => 10000,
 
-      *     'icon'   => '',
 
-      *     'remark' => '删除角色',
 
-      *     'param'  => ''
 
-      * )
 
-      * @throws \think\Exception
 
-      * @throws \think\exception\PDOException
 
-      */
 
-     public function roleDelete()
 
-     {
 
-         $id = $this->request->param("id", 0, 'intval');
 
-         if ($id == 1) {
 
-             $this->error("超级管理员角色不能被删除!");
 
-         }
 
-         $count = Db::name('RoleUser')->where('role_id', $id)->count();
 
-         if ($count > 0) {
 
-             $this->error("该角色已经有用户!");
 
-         } else {
 
-             $status = Db::name('role')->delete($id);
 
-             if (!empty($status)) {
 
-                 $this->success("删除成功!", url('rbac/index'));
 
-             } else {
 
-                 $this->error("删除失败!");
 
-             }
 
-         }
 
-     }
 
-     /**
 
-      * 设置角色权限
 
-      * @adminMenu(
 
-      *     'name'   => '设置角色权限',
 
-      *     'parent' => 'index',
 
-      *     'display'=> false,
 
-      *     'hasView'=> true,
 
-      *     'order'  => 10000,
 
-      *     'icon'   => '',
 
-      *     'remark' => '设置角色权限',
 
-      *     'param'  => ''
 
-      * )
 
-      * @return mixed
 
-      */
 
-     public function authorize()
 
-     {
 
-         $content = hook_one('admin_rbac_authorize_view');
 
-         if (!empty($content)) {
 
-             return $content;
 
-         }
 
-         $AuthAccess     = Db::name("AuthAccess");
 
-         $adminMenuModel = new AdminMenuModel();
 
-         //角色ID
 
-         $roleId = $this->request->param("id", 0, 'intval');
 
-         if (empty($roleId)) {
 
-             $this->error("参数错误!");
 
-         }
 
-         $tree       = new Tree();
 
-         $tree->icon = ['│ ', '├─ ', '└─ '];
 
-         $tree->nbsp = '   ';
 
-         $result = $adminMenuModel->menuCache();
 
-         $newMenus      = [];
 
-         $privilegeData = $AuthAccess->where("role_id", $roleId)->column("rule_name");//获取权限表数据
 
-         foreach ($result as $m) {
 
-             $newMenus[$m['id']] = $m;
 
-         }
 
-         foreach ($result as $n => $t) {
 
-             $result[$n]['checked']      = ($this->_isChecked($t, $privilegeData)) ? ' checked' : '';
 
-             $result[$n]['level']        = $this->_getLevel($t['id'], $newMenus);
 
-             $result[$n]['style']        = empty($t['parent_id']) ? '' : 'display:none;';
 
-             $result[$n]['parentIdNode'] = ($t['parent_id']) ? ' class="child-of-node-' . $t['parent_id'] . '"' : '';
 
-         }
 
-         $str = "<tr id='node-\$id'\$parentIdNode  style='\$style'>
 
-                    <td style='padding-left:30px;'>\$spacer<input type='checkbox' name='menuId[]' value='\$id' level='\$level' \$checked onclick='javascript:checknode(this);'> \$name</td>
 
-     			</tr>";
 
-         $tree->init($result);
 
-         $category = $tree->getTree(0, $str);
 
-         $this->assign("category", $category);
 
-         $this->assign("roleId", $roleId);
 
-         return $this->fetch();
 
-     }
 
-     /**
 
-      * 角色授权提交
 
-      * @adminMenu(
 
-      *     'name'   => '角色授权提交',
 
-      *     'parent' => 'index',
 
-      *     'display'=> false,
 
-      *     'hasView'=> false,
 
-      *     'order'  => 10000,
 
-      *     'icon'   => '',
 
-      *     'remark' => '角色授权提交',
 
-      *     'param'  => ''
 
-      * )
 
-      * @throws \think\Exception
 
-      * @throws \think\db\exception\DataNotFoundException
 
-      * @throws \think\db\exception\ModelNotFoundException
 
-      * @throws \think\exception\DbException
 
-      * @throws \think\exception\PDOException
 
-      */
 
-     public function authorizePost()
 
-     {
 
-         if ($this->request->isPost()) {
 
-             $roleId = $this->request->param("roleId", 0, 'intval');
 
-             if (!$roleId) {
 
-                 $this->error("需要授权的角色不存在!");
 
-             }
 
-             if (is_array($this->request->param('menuId/a')) && count($this->request->param('menuId/a')) > 0) {
 
-                 Db::name("authAccess")->where(["role_id" => $roleId, 'type' => 'admin_url'])->delete();
 
-                 foreach ($_POST['menuId'] as $menuId) {
 
-                     $menu = Db::name("adminMenu")->where("id", $menuId)->field("app,controller,action")->find();
 
-                     if ($menu) {
 
-                         $app    = $menu['app'];
 
-                         $model  = $menu['controller'];
 
-                         $action = $menu['action'];
 
-                         $name   = strtolower("$app/$model/$action");
 
-                         Db::name("authAccess")->insert(["role_id" => $roleId, "rule_name" => $name, 'type' => 'admin_url']);
 
-                     }
 
-                 }
 
-                 Cache::clear('admin_menus');// 删除后台菜单缓存
 
-                 $this->success("授权成功!");
 
-             } else {
 
-                 //当没有数据时,清除当前角色授权
 
-                 Db::name("authAccess")->where("role_id", $roleId)->delete();
 
-                 $this->error("没有接收到数据,执行清除授权成功!");
 
-             }
 
-         }
 
-     }
 
-     /**
 
-      * 检查指定菜单是否有权限
 
-      * @param array $menu menu表中数组
 
-      * @param       $privData
 
-      * @return bool
 
-      */
 
-     private function _isChecked($menu, $privData)
 
-     {
 
-         $app    = $menu['app'];
 
-         $model  = $menu['controller'];
 
-         $action = $menu['action'];
 
-         $name   = strtolower("$app/$model/$action");
 
-         if ($privData) {
 
-             if (in_array($name, $privData)) {
 
-                 return true;
 
-             } else {
 
-                 return false;
 
-             }
 
-         } else {
 
-             return false;
 
-         }
 
-     }
 
-     /**
 
-      * 获取菜单深度
 
-      * @param       $id
 
-      * @param array $array
 
-      * @param int   $i
 
-      * @return int
 
-      */
 
-     protected function _getLevel($id, $array = [], $i = 0)
 
-     {
 
-         if ($array[$id]['parent_id'] == 0 || empty($array[$array[$id]['parent_id']]) || $array[$id]['parent_id'] == $id) {
 
-             return $i;
 
-         } else {
 
-             $i++;
 
-             return $this->_getLevel($array[$id]['parent_id'], $array, $i);
 
-         }
 
-     }
 
-     //角色成员管理
 
-     public function member()
 
-     {
 
-         //TODO 添加角色成员管理
 
-     }
 
- }
 
 
  |