HEX
Server: nginx/1.28.1
System: Linux 10-41-63-61 6.8.0-31-generic #31-Ubuntu SMP PREEMPT_DYNAMIC Sat Apr 20 00:40:06 UTC 2024 x86_64
User: www (1001)
PHP: 7.4.33
Disabled: passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: /www/wwwroot/douyin.sbufb.com/application/admin/controller/Groups.php
<?php
// +----------------------------------------------------------------------
// | Description: 用户组
// +----------------------------------------------------------------------
// | Author:  Michael_xu | gengxiaoxu@5kcrm.com 
// +----------------------------------------------------------------------

namespace app\admin\controller;

use think\Hook;
use think\Request;

class Groups extends ApiCommon
{
    /**
     * 用于判断权限
     * @permission 无限制
     * @allow 登录用户可访问
     * @other 其他根据系统设置
    **/    
    public function _initialize()
    {
        $action = [
            'permission'=>[''],
            'allow'=>['index','enables','copy','typelist','save','update','delete']
        ];
        Hook::listen('check_auth',$action);
        $request = Request::instance();
        $a = strtolower($request->action());        
        if (!in_array($a, $action['permission'])) {
            parent::_initialize();
        } 
        //权限判断
        $unAction = ['index','typelist'];
        if (!in_array($a, $unAction) && !checkPerByAction('admin', 'groups', 'update')) {
            header('Content-Type:application/json; charset=utf-8');
            exit(json_encode(['code'=>102,'error'=>'无权操作']));
        }                        
    }        

    /**
     * 角色列表
     * @author Michael_xu
     * @param 
     * @return                            
     */     
    public function index()
    {         
        $groupModel = model('Group');
        $param = $this->param;
        $data = $groupModel->getDataList($param);
        return resultArray(['data' => $data]);
    }

    /**
     * 角色详情
     * @author Michael_xu
     * @param 
     * @return                            
     */    
    public function read()
    {   
        $groupModel = model('Group');
        $param = $this->param;
        $data = $groupModel->getDataById($param['id']);
        if (!$data) {
            return resultArray(['error' => $groupModel->getError()]);
        } 
        return resultArray(['data' => $data]);
    }

    /**
     * 角色添加
     * @author Michael_xu
     * @param 
     * @return                            
     */    
    public function save()
    {        
        $groupModel = model('Group');
        $param = $this->param;
		$param['rules'] = arrayToString($param['rules']);
        $data = $groupModel->createData($param);
        if (!$data) {
            return resultArray(['error' => $groupModel->getError()]);
        } 
        return resultArray(['data' => $data]);
    }

    /**
     * 角色编辑
     * @author Michael_xu
     * @param 
     * @return                            
     */     
    public function update()
    {        
        $groupModel = model('Group');
        $param = $this->param;
        $dataInfo = $groupModel->getDataById($param['id']);
        if (!$dataInfo) {
            return resultArray(['error' => '参数错误']);
        }
        // if ($dataInfo['types']) {
        //     return resultArray(['error' => '系统角色,不能编辑']);
        // }
        $param['rules'] = arrayToString($param['rules']);
        $data = $groupModel->updateDataById($param, $param['id']);
        return resultArray(['data' => '编辑成功']);
    }

    /**
     * 角色删除
     * @author Michael_xu
     * @param 
     * @return                            
     */     
    public function delete()
    {            
        $groupModel = model('Group');
        $param = $this->param;
        $dataInfo = $groupModel->getDataById($param['id']);
        if (!$dataInfo) {
            return resultArray(['error' => '参数错误']);
        }
        if ($dataInfo['types']) {
            return resultArray(['error' => '系统角色,不能删除']);
        }        
        $data = $groupModel->delGroupById($param['id']);      
        if (!$data) {
            return resultArray(['error' => $groupModel->getError()]);
        } 
        return resultArray(['data' => '删除成功']);    
    }

    /**
     * 角色启用、禁用
     * @author Michael_xu
     * @param 
     * @return                            
     */   
    public function enables()
    {        
        $groupModel = model('Group');
        $param = $this->param;
        $dataInfo = $groupModel->getDataById($param['id']);
        if (!$dataInfo) {
            return resultArray(['error' => '参数错误']);
        }
        if ($dataInfo['types']) {
            return resultArray(['error' => '系统角色,不能删除']);
        }         
        $data = $groupModel->enableDatas($param['id'], $param['status'], true);  
        if (!$data) {
            return resultArray(['error' => $groupModel->getError()]);
        } 
        return resultArray(['data' => '操作成功']);         
    }

    /**
     * 角色复制
     * @author Michael_xu
     * @param 
     * @return                            
     */   
    public function copy()
    {        
        $groupModel = model('Group');
        $param = $this->param;
        $dataInfo = $groupModel->getDataById($param['id']);
        if (!$dataInfo) {
            return resultArray(['error' => '参数错误']);
        }
        $dataInfo = json_decode($dataInfo, true);
        unset($dataInfo['id']);
        $titleCount = db('admin_group')->where(['title' => $dataInfo['title']])->count();
        $dataInfo['title'] = $dataInfo['title'].'('.$titleCount.')';
        $data = $groupModel->createData($dataInfo);
        if (!$data) {
            return resultArray(['error' => $groupModel->getError()]);
        }
        return resultArray(['data' => '操作成功']);         
    }

    /**
     * 角色分类列表
     * @author Michael_xu
     * @param 
     * @return                            
     */     
    public function typeList()
    {         
        $groupModel = model('Group');
        $param = $this->param;
        $data = $groupModel->getTypeList($param);
        return resultArray(['data' => $data]);
    }        
}