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/validate/
Upload File :
Current Directory [ Writeable ] Root Directory [ Writeable ]


Current File : /www/wwwroot/0531yanglao.com/app/admin/validate/AdminRoleValidate.php
<?php
/*
 * @Description  : 角色验证器
 * @Author       : https://github.com/skyselang
 * @Date         : 2020-05-05
 * @LastEditTime : 2021-03-20
 */

namespace app\admin\validate;

use think\Validate;
use think\facade\Db;
use app\admin\service\AdminRoleService;

class AdminRoleValidate extends Validate
{
    // 验证规则
    protected $rule = [
        'admin_role_id' => ['require', 'checkAdminRuleId'],
        'role_name'     => ['require', 'checkAdminRule'],
    ];

    // 错误信息
    protected $message = [
        'admin_role_id.require' => '缺少参数:角色id',
        'role_name.require'     => '请输入角色名称',
    ];

    // 验证场景
    protected $scene = [
        'role_id'   => ['admin_role_id'],
        'role_add'  => ['role_name'],
        'role_edit' => ['admin_role_id', 'role_name'],
        'role_dele' => ['admin_role_id'],
    ];

    // 验证场景定义:删除
    protected function scenerole_dele()
    {
        return $this->only(['admin_role_id'])
            ->append('admin_role_id', 'checkAdminRoleMenuUser');
    }

    // 自定义验证规则:角色是否存在
    protected function checkAdminRuleId($value, $rule, $data = [])
    {
        $admin_role_id = $value;

        $admin_role = AdminRoleService::info($admin_role_id);

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

        return true;
    }

    // 自定义验证规则:角色是否已存在
    protected function checkAdminRule($value, $rule, $data = [])
    {
        $admin_role_id = isset($data['admin_role_id']) ? $data['admin_role_id'] : '';

        if ($admin_role_id) {
            $where[] = ['admin_role_id', '<>', $admin_role_id];
        }
        $where[] = ['role_name', '=', $data['role_name']];
        $where[] = ['is_delete', '=', 0];

        $admin_role = Db::name('admin_role')
            ->field('admin_role_id')
            ->where($where)
            ->find();

        if ($admin_role) {
            return '角色已存在:' . $data['role_name'];
        }

        return true;
    }

    // 自定义验证规则:角色是否有菜单或管理员
    protected function checkAdminRoleMenuUser($value, $rule, $data = [])
    {
        $admin_role_id = $value;

        $admin_role = AdminRoleService::info($admin_role_id);

        if ($admin_role['admin_menu_ids']) {
            return '请在[修改]中取消所有菜单后再删除';
        }

        $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]];
        $whereOr = [$where0, $where1, $where2, $where3];

        $admin_user = Db::name('admin_user')
            ->field('admin_user_id')
            ->whereOr($whereOr)
            ->find();

        if ($admin_user) {
            return '请在[管理员]中解除所有管理员后再删除';
        }

        return true;
    }
}