160 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			160 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace app\admin\controller\auth\api;
 | 
						|
 | 
						|
use app\admin\model\AuthRule;
 | 
						|
use app\common\controller\Backend;
 | 
						|
use fast\Tree;
 | 
						|
use think\Cache;
 | 
						|
 | 
						|
/**
 | 
						|
 * 规则管理
 | 
						|
 *
 | 
						|
 * @icon   fa fa-list
 | 
						|
 * @remark 规则通常对应一个控制器的方法,同时左侧的菜单栏数据也从规则中体现,通常建议通过控制台进行生成规则节点
 | 
						|
 */
 | 
						|
class Rule extends Backend
 | 
						|
{
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \app\admin\model\AuthRule
 | 
						|
     */
 | 
						|
    protected $model = null;
 | 
						|
    protected $rulelist = [];
 | 
						|
    protected $multiFields = 'ismenu,status';
 | 
						|
 | 
						|
    public function _initialize()
 | 
						|
    {
 | 
						|
        parent::_initialize();
 | 
						|
        if (!$this->auth->isSuperAdmin()) {
 | 
						|
            $this->error(__('Access is allowed only to the super management group'));
 | 
						|
        }
 | 
						|
        $this->model = model('AuthRule');
 | 
						|
        // 必须将结果集转换为数组
 | 
						|
        $ruleList = \think\Db::name("auth_rule")->field('type,condition,remark,createtime,updatetime', true)->order('weigh DESC,id ASC')->select();
 | 
						|
        foreach ($ruleList as $k => &$v) {
 | 
						|
            $v['title'] = __($v['title']);
 | 
						|
        }
 | 
						|
        unset($v);
 | 
						|
        Tree::instance()->init($ruleList)->icon = ['    ', '    ', '    '];
 | 
						|
        $this->rulelist = Tree::instance()->getTreeList(Tree::instance()->getTreeArray(0), 'title');
 | 
						|
        $ruledata = [0 => __('None')];
 | 
						|
        foreach ($this->rulelist as $k => &$v) {
 | 
						|
            if (!$v['ismenu']) {
 | 
						|
                continue;
 | 
						|
            }
 | 
						|
            $ruledata[$v['id']] = $v['title'];
 | 
						|
            unset($v['spacer']);
 | 
						|
        }
 | 
						|
        unset($v);
 | 
						|
        $this->view->assign('ruledata', $ruledata);
 | 
						|
        $this->view->assign("menutypeList", $this->model->getMenutypeList());
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 查看
 | 
						|
     */
 | 
						|
    public function index()
 | 
						|
    {
 | 
						|
        if ($this->request->isAjax()) {
 | 
						|
            $list = $this->rulelist;
 | 
						|
            $total = count($this->rulelist);
 | 
						|
            $result = array("total" => $total, "rows" => $list);
 | 
						|
 | 
						|
            return json($result);
 | 
						|
        }
 | 
						|
        return $this->view->fetch();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 添加
 | 
						|
     */
 | 
						|
    public function add()
 | 
						|
    {
 | 
						|
        if ($this->request->isPost()) {
 | 
						|
            $this->token();
 | 
						|
            $params = $this->request->post("row/a", [], 'strip_tags');
 | 
						|
            if ($params) {
 | 
						|
                if (!$params['ismenu'] && !$params['pid']) {
 | 
						|
                    $this->error(__('The non-menu rule must have parent'));
 | 
						|
                }
 | 
						|
                $result = $this->model->validate()->save($params);
 | 
						|
                if ($result === false) {
 | 
						|
                    $this->error($this->model->getError());
 | 
						|
                }
 | 
						|
                Cache::rm('__menu__');
 | 
						|
                $this->success();
 | 
						|
            }
 | 
						|
            $this->error();
 | 
						|
        }
 | 
						|
        return $this->view->fetch();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 编辑
 | 
						|
     */
 | 
						|
    public function edit($ids = null)
 | 
						|
    {
 | 
						|
        $row = $this->model->get(['id' => $ids]);
 | 
						|
        if (!$row) {
 | 
						|
            $this->error(__('No Results were found'));
 | 
						|
        }
 | 
						|
        if ($this->request->isPost()) {
 | 
						|
            $this->token();
 | 
						|
            $params = $this->request->post("row/a", [], 'strip_tags');
 | 
						|
            if ($params) {
 | 
						|
                if (!$params['ismenu'] && !$params['pid']) {
 | 
						|
                    $this->error(__('The non-menu rule must have parent'));
 | 
						|
                }
 | 
						|
                if ($params['pid'] == $row['id']) {
 | 
						|
                    $this->error(__('Can not change the parent to self'));
 | 
						|
                }
 | 
						|
                if ($params['pid'] != $row['pid']) {
 | 
						|
                    $childrenIds = Tree::instance()->init(collection(AuthRule::select())->toArray())->getChildrenIds($row['id']);
 | 
						|
                    if (in_array($params['pid'], $childrenIds)) {
 | 
						|
                        $this->error(__('Can not change the parent to child'));
 | 
						|
                    }
 | 
						|
                }
 | 
						|
                //这里需要针对name做唯一验证
 | 
						|
                $ruleValidate = \think\Loader::validate('AuthRule');
 | 
						|
                $ruleValidate->rule([
 | 
						|
                    'name' => 'require|unique:AuthRule,name,' . $row->id,
 | 
						|
                ]);
 | 
						|
                $result = $row->validate()->save($params);
 | 
						|
                if ($result === false) {
 | 
						|
                    $this->error($row->getError());
 | 
						|
                }
 | 
						|
                Cache::rm('__menu__');
 | 
						|
                $this->success();
 | 
						|
            }
 | 
						|
            $this->error();
 | 
						|
        }
 | 
						|
        $this->view->assign("row", $row);
 | 
						|
        return $this->view->fetch();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 删除
 | 
						|
     */
 | 
						|
    public function del($ids = "")
 | 
						|
    {
 | 
						|
        if (!$this->request->isPost()) {
 | 
						|
            $this->error(__("Invalid parameters"));
 | 
						|
        }
 | 
						|
        $ids = $ids ? $ids : $this->request->post("ids");
 | 
						|
        if ($ids) {
 | 
						|
            $delIds = [];
 | 
						|
            foreach (explode(',', $ids) as $k => $v) {
 | 
						|
                $delIds = array_merge($delIds, Tree::instance()->getChildrenIds($v, true));
 | 
						|
            }
 | 
						|
            $delIds = array_unique($delIds);
 | 
						|
            $count = $this->model->where('id', 'in', $delIds)->delete();
 | 
						|
            if ($count) {
 | 
						|
                Cache::rm('__menu__');
 | 
						|
                $this->success();
 | 
						|
            }
 | 
						|
        }
 | 
						|
        $this->error();
 | 
						|
    }
 | 
						|
}
 |