Example #1
0
/**
 * 允许写入检查 - 角色和细粒度权限越权检查
 */
function allow_write($fields)
{
    global $_LANG, $_PRIV;
    /* 提交的管理员的角色信息 */
    $role_info = info_role(array('role_id' => $fields['role_id']));
    /* 无效的角色信息 */
    if (empty($role_info)) {
        sys_msg($_LANG['lawless_submit']);
    }
    /* 对提交的管理员的角色进行越权检查(当前管理员角色必须大于提交的角色) */
    $filter1 = array('info' => $_PRIV['role']);
    $filter2 = array('info' => $role_info);
    if (cmp_role($filter1, $filter2) != '>') {
        sys_msg($_LANG['lawless_submit']);
    }
    /* 对提交的管理员的细粒度权限进行越权检查(当前管理员细粒度权限必须大于等于提交的细粒度权限) */
    $filter1 = array('privilege_ids' => admin_privilege_ids());
    $filter2 = array('privilege_ids' => $_POST['privilege_ids']);
    $flag = cmp_privilege($filter1, $filter2);
    if ($flag == '<' || $flag == false) {
        sys_msg($_LANG['lawless_submit']);
    }
}
Example #2
0
/**
 * 允许获取权限表检查 - 角色越权检查
 */
function allow_privtable($info_p)
{
    global $_LANG, $_PRIV;
    /* 无效的父角色信息 */
    if (empty($info_p)) {
        sys_msg($_LANG['lawless_submit']);
    }
    /* 对申请的上级角色进行越权检查(当前管理员的角色必须大于等于申请的上级父角色) */
    $filter1 = array('info' => $_PRIV['role']);
    $filter2 = array('info' => $info_p);
    $flag = cmp_role($filter1, $filter2);
    if ($flag == '<' || $flag == false) {
        sys_msg($_LANG['lawless_submit']);
    }
}