183 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			183 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			PHP
		
	
	
| 
								 | 
							
								<?php
							 | 
						|||
| 
								 | 
							
								namespace app\controller\manager;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								use app\model\{AuthRule, AuthGroup, Log};
							 | 
						|||
| 
								 | 
							
								use app\validate\AuthRule as VAuthRule;
							 | 
						|||
| 
								 | 
							
								use Exception;
							 | 
						|||
| 
								 | 
							
								use think\exception\ValidateException;
							 | 
						|||
| 
								 | 
							
								use think\response\Json;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								class Rule extends Base
							 | 
						|||
| 
								 | 
							
								{
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 权限排序
							 | 
						|||
| 
								 | 
							
								     * 暂不允许父级变更
							 | 
						|||
| 
								 | 
							
								     *
							 | 
						|||
| 
								 | 
							
								     * @return Json
							 | 
						|||
| 
								 | 
							
								     * @throws Exception
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function sort()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        if ($this->request->isAjax()) {
							 | 
						|||
| 
								 | 
							
								            $id = input('post.id');
							 | 
						|||
| 
								 | 
							
								            $sort = input('post.sort');
							 | 
						|||
| 
								 | 
							
								            $num = input('post.num/d', 1);
							 | 
						|||
| 
								 | 
							
								            if($num <= 0){
							 | 
						|||
| 
								 | 
							
								                $num = 1;
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            if(!in_array($sort, ['up', 'down'], true)){
							 | 
						|||
| 
								 | 
							
								                return $this->json(2, '参数错误');
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            $item = AuthRule::getById($id);
							 | 
						|||
| 
								 | 
							
								            if(empty($item)){
							 | 
						|||
| 
								 | 
							
								                return $this->json(3, '权限不存在');
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            if($sort == 'up'){
							 | 
						|||
| 
								 | 
							
								                $where = "parent_id = {$item['parent_id']} and sort < {$item['sort']}";
							 | 
						|||
| 
								 | 
							
								                $order = "sort desc";
							 | 
						|||
| 
								 | 
							
								            }else{
							 | 
						|||
| 
								 | 
							
								                $where = "parent_id = {$item['parent_id']} and sort > {$item['sort']}";
							 | 
						|||
| 
								 | 
							
								                $order = "sort asc";
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            $forSortItems = AuthRule::getListByWhereAndOrder($where, $order, $num);
							 | 
						|||
| 
								 | 
							
								            if(!empty($forSortItems)){
							 | 
						|||
| 
								 | 
							
								                $updateData = [];
							 | 
						|||
| 
								 | 
							
								                $forSortCount = count($forSortItems);
							 | 
						|||
| 
								 | 
							
								                for($i = 0; $i < $forSortCount; $i++){
							 | 
						|||
| 
								 | 
							
								                    if($i == 0){
							 | 
						|||
| 
								 | 
							
								                        $updateData[] = [
							 | 
						|||
| 
								 | 
							
								                            'id' => $forSortItems[$i]['id'],
							 | 
						|||
| 
								 | 
							
								                            'sort' => $item['sort']
							 | 
						|||
| 
								 | 
							
								                        ];
							 | 
						|||
| 
								 | 
							
								                    }else{
							 | 
						|||
| 
								 | 
							
								                        $updateData[] = [
							 | 
						|||
| 
								 | 
							
								                            'id' => $forSortItems[$i]['id'],
							 | 
						|||
| 
								 | 
							
								                            'sort' => $forSortItems[$i - 1]['sort']
							 | 
						|||
| 
								 | 
							
								                        ];
							 | 
						|||
| 
								 | 
							
								                    }
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								                $updateData[] = [
							 | 
						|||
| 
								 | 
							
								                    'id' => $item['id'],
							 | 
						|||
| 
								 | 
							
								                    'sort' => $forSortItems[$i - 1]['sort']
							 | 
						|||
| 
								 | 
							
								                ];
							 | 
						|||
| 
								 | 
							
								                if(!empty($updateData)){
							 | 
						|||
| 
								 | 
							
								                    $model = new AuthRule();
							 | 
						|||
| 
								 | 
							
								                    $model->saveAll($updateData);
							 | 
						|||
| 
								 | 
							
								                    $sortStr = $sort == 'up' ? '上移' : '下调';
							 | 
						|||
| 
								 | 
							
								                    Log::write('rule', 'sort', "权限排序,ID:{$id} ,标题:{$item['title']},{$sortStr}了{$num}位");
							 | 
						|||
| 
								 | 
							
								                    return $this->json();
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            return $this->json(4, '无须调整排序!');
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        return $this->json(1, '非法请求!');
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 权限删除
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function del()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        if ($this->request->isAjax()) {
							 | 
						|||
| 
								 | 
							
								            $ids = input('post.ids/a');
							 | 
						|||
| 
								 | 
							
								            $items = AuthRule::where('id', 'in', $ids)->select();
							 | 
						|||
| 
								 | 
							
								            if(!$items){
							 | 
						|||
| 
								 | 
							
								                return $this->json(1, '无此权限');
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            if(AuthRule::where('parent_id', 'in', $ids)->count()){
							 | 
						|||
| 
								 | 
							
								                return $this->json(2, '当前权限有下级权限,不可删除');
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            AuthRule::destroy($ids);
							 | 
						|||
| 
								 | 
							
								            AuthGroup::resetGroupRulesCache();
							 | 
						|||
| 
								 | 
							
								            $ids = implode(',', $ids);
							 | 
						|||
| 
								 | 
							
								            Log::write('rule', 'del', "权限删除,ID:{$ids}");
							 | 
						|||
| 
								 | 
							
								            return $this->json();
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        return $this->json(1, '非法请求!');
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 权限修改
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function edit()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        if($this->request->isPost()){
							 | 
						|||
| 
								 | 
							
								            $item = input('post.item/a');
							 | 
						|||
| 
								 | 
							
								            $id = input('post.id');
							 | 
						|||
| 
								 | 
							
								            $rule = AuthRule::getById($id);
							 | 
						|||
| 
								 | 
							
								            if(empty($rule)){
							 | 
						|||
| 
								 | 
							
								                return $this->json(1, '请选择正确的权限');
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            $rule2 = AuthRule::getByName($item['name']);
							 | 
						|||
| 
								 | 
							
								            if(!empty($rule2) && $rule2['id'] != $id){
							 | 
						|||
| 
								 | 
							
								                return $this->json(2, '已存在相同权限['.$item['name'].']');
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            try {
							 | 
						|||
| 
								 | 
							
								                validate(VAuthRule::class)->check($item);
							 | 
						|||
| 
								 | 
							
								                AuthRule::updateById($id, $item);
							 | 
						|||
| 
								 | 
							
								                AuthGroup::resetGroupRulesCache();
							 | 
						|||
| 
								 | 
							
								                Log::write('rule', 'edit', "权限编辑,ID:{$id}, 标题:{$item['title']}");
							 | 
						|||
| 
								 | 
							
								                return $this->json();
							 | 
						|||
| 
								 | 
							
								            } catch (ValidateException $e) {
							 | 
						|||
| 
								 | 
							
								                return $this->json(3, $e->getError());
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        $id = input('param.id/d');
							 | 
						|||
| 
								 | 
							
								        $rule = AuthRule::getById($id);
							 | 
						|||
| 
								 | 
							
								        if(empty($rule)){
							 | 
						|||
| 
								 | 
							
								            return $this->json(1,'无此权限信息,请核对之后再操作!');
							 | 
						|||
| 
								 | 
							
								        }else{
							 | 
						|||
| 
								 | 
							
								            $this->data['item'] = $rule;
							 | 
						|||
| 
								 | 
							
								            if($rule['parent_id'] > 0){
							 | 
						|||
| 
								 | 
							
								                $parent = AuthRule::getById($rule['parent_id']);
							 | 
						|||
| 
								 | 
							
								                $this->data['parent'] = $parent;
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            return $this->view();
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 权限添加
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function add()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        if($this->request->isPost()){
							 | 
						|||
| 
								 | 
							
								            $item = input('post.item/a');
							 | 
						|||
| 
								 | 
							
								            try {
							 | 
						|||
| 
								 | 
							
								                validate(VAuthRule::class)->check($item);
							 | 
						|||
| 
								 | 
							
								                $rule = AuthRule::getByName($item['name']);
							 | 
						|||
| 
								 | 
							
								                if(!empty($rule)){
							 | 
						|||
| 
								 | 
							
								                    return $this->json(1, '已存在相同权限');
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								                $rule = AuthRule::create($item);
							 | 
						|||
| 
								 | 
							
								                //基本权限的话需要重置所有已有角色权限缓存
							 | 
						|||
| 
								 | 
							
								                if ($item['is_base'] > 0) {
							 | 
						|||
| 
								 | 
							
								                    AuthGroup::resetGroupRulesCache();
							 | 
						|||
| 
								 | 
							
								                } else {
							 | 
						|||
| 
								 | 
							
								                    AuthGroup::resetGroupRulesCache(1);
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								                Log::write('rule', 'add', "权限新增,ID:{$rule->id}, 标题:{$item['title']}");
							 | 
						|||
| 
								 | 
							
								                return $this->json();
							 | 
						|||
| 
								 | 
							
								            } catch (ValidateException $e) {
							 | 
						|||
| 
								 | 
							
								                return $this->json(2, $e->getError());
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        $parentId = input('param.parent_id/d',0);
							 | 
						|||
| 
								 | 
							
								        if($parentId > 0){
							 | 
						|||
| 
								 | 
							
								            $parent = AuthRule::getById($parentId);
							 | 
						|||
| 
								 | 
							
								            $this->data['parent'] = $parent;
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        $this->data['parentId'] = $parentId;
							 | 
						|||
| 
								 | 
							
								        return $this->view();
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 权限列表(全部)
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function index()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        $list = AuthRule::getListTree();
							 | 
						|||
| 
								 | 
							
								        $this->data['items'] = $list;
							 | 
						|||
| 
								 | 
							
								        return $this->view();
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								}
							 |