Server : nginx/1.20.1
System : Linux iZ2ze9ojcl78uluczwag69Z 4.18.0-240.22.1.el8_3.x86_64 #1 SMP Thu Apr 8 19:01:30 UTC 2021 x86_64
User : www ( 1000)
PHP Version : 7.3.28
Disable Function : passthru,exec,system,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
Directory :  /www/wwwroot/0531yanglao.com/app/admin/controller/
Upload File :
Current Directory [ Writeable ] Root Directory [ Writeable ]


Current File : /www/wwwroot/0531yanglao.com/app/admin/controller/AdminRole.php
<?php
/*
 * @Description  : 角色管理
 * @Author       : https://github.com/skyselang
 * @Date         : 2020-03-30
 * @LastEditTime : 2020-12-25
 */

namespace app\admin\controller;

use think\facade\Request;
use app\admin\validate\AdminRoleValidate;
use app\admin\validate\AdminUserValidate;
use app\admin\service\AdminRoleService;

class AdminRole
{
    /**
     * 角色列表
     *
     * @method GET
     * 
     * @return json
     */
    public function roleList()
    {
        $page       = Request::param('page/d', 1);
        $limit      = Request::param('limit/d', 10);
        $sort_field = Request::param('sort_field/s', '');
        $sort_type  = Request::param('sort_type/s', '');
        $role_name  = Request::param('role_name/s', '');
        $role_desc  = Request::param('role_desc/s', '');

        $where = [];
        if ($role_name) {
            $where[] = ['role_name', 'like', '%' . $role_name . '%'];
        }
        if ($role_desc) {
            $where[] = ['role_desc', 'like', '%' . $role_desc . '%'];
        }

        $order = [];
        if ($sort_field && $sort_type) {
            $order = [$sort_field => $sort_type];
        }

        $data = AdminRoleService::list($where, $page, $limit, $order);

        return success($data);
    }

    /**
     * 角色信息
     *
     * @method GET
     * 
     * @return json
     */
    public function roleInfo()
    {
        $param['admin_role_id'] = Request::param('admin_role_id/d', '');

        validate(AdminRoleValidate::class)->scene('role_id')->check($param);

        $data = AdminRoleService::info($param['admin_role_id']);

        if ($data['is_delete'] == 1) {
            exception('角色已被删除:' . $param['admin_role_id']);
        }

        return success($data);
    }

    /**
     * 角色添加
     *
     * @method POST
     * 
     * @return json
     */
    public function roleAdd()
    {
        if (Request::isGet()) {
            $data = AdminRoleService::add();
        } else {
            $param['role_name']      = Request::param('role_name/s', '');
            $param['role_desc']      = Request::param('role_desc/s', '');
            $param['role_sort']      = Request::param('role_sort/d', 200);
            $param['admin_menu_ids'] = Request::param('admin_menu_ids/a', []);

            validate(AdminRoleValidate::class)->scene('role_add')->check($param);

            $data = AdminRoleService::add($param, 'post');
        }

        return success($data);
    }

    /**
     * 角色修改
     *
     * @method GET|POST
     * 
     * @return json
     */
    public function roleEdit()
    {
        $param['admin_role_id'] = Request::param('admin_role_id/d', '');

        if (Request::isGet()) {
            validate(AdminRoleValidate::class)->scene('role_id')->check($param);

            $data = AdminRoleService::edit($param);

            if ($data['admin_role']['is_delete'] == 1) {
                exception('角色已被删除:' . $param['admin_role_id']);
            }
        } else {
            $param['role_name']      = Request::param('role_name/s', '');
            $param['role_desc']      = Request::param('role_desc/s', '');
            $param['role_sort']      = Request::param('role_sort/d', 200);
            $param['admin_menu_ids'] = Request::param('admin_menu_ids/a', []);

            validate(AdminRoleValidate::class)->scene('role_edit')->check($param);

            $data = AdminRoleService::edit($param, 'post');
        }

        return success($data);
    }

    /**
     * 角色删除
     *
     * @method POST
     * 
     * @return json
     */
    public function roleDele()
    {
        $param['admin_role_id'] = Request::param('admin_role_id/d', '');

        validate(AdminRoleValidate::class)->scene('role_dele')->check($param);

        $data = AdminRoleService::dele($param['admin_role_id']);

        return success($data);
    }

    /**
     * 角色禁用
     *
     * @method POST
     * 
     * @return json
     */
    public function roleDisable()
    {
        $param['admin_role_id'] = Request::param('admin_role_id/d', '');
        $param['is_disable']    = Request::param('is_disable/d', 0);

        validate(AdminRoleValidate::class)->scene('role_id')->check($param);

        $data = AdminRoleService::disable($param);

        return success($data);
    }

    /**
     * 角色管理员
     *
     * @method GET
     *
     * @return json
     */
    public function roleUser()
    {
        $page          = Request::param('page/d', 1);
        $limit         = Request::param('limit/d', 10);
        $sort_field    = Request::param('sort_field/s ', '');
        $sort_type     = Request::param('sort_type/s', '');
        $admin_role_id = Request::param('admin_role_id/s', '');

        validate(AdminRoleValidate::class)->scene('role_id')->check(['admin_role_id' => $admin_role_id]);

        $where0 = [['admin_role_ids', 'like', $admin_role_id], ['is_delete', '=', 0]];
        $where1 = [['admin_role_ids', 'like', $admin_role_id . ',%'], ['is_delete', '=', 0]];
        $where2 = [['admin_role_ids', 'like', '%,' . $admin_role_id . ',%'], ['is_delete', '=', 0]];
        $where3 = [['admin_role_ids', 'like', '%,' . $admin_role_id], ['is_delete', '=', 0]];
        $where  = [$where0, $where1, $where2, $where3];
        $whereOr = true;

        $order = [];
        if ($sort_field && $sort_type) {
            $order = [$sort_field => $sort_type];
        }

        $field = '';

        $data = AdminRoleService::user($where, $page, $limit, $order, $field, $whereOr);

        return success($data);
    }

    /**
     * 角色管理员解除
     *
     * @method POST
     *
     * @return json
     */
    public function roleUserRemove()
    {
        $param['admin_role_id'] = Request::param('admin_role_id/d', '');
        $param['admin_user_id'] = Request::param('admin_user_id/d', '');

        validate(AdminRoleValidate::class)->scene('role_id')->check($param);
        validate(AdminUserValidate::class)->scene('user_id')->check($param);

        $data = AdminRoleService::userRemove($param);

        return success($data);
    }
}