ovirt笔记:基于ovirt4.0的虚拟资源管理的权限分析

news/2024/7/5 23:36:38

前言

虚拟资源管理平台是在ovirt4.0的基础上开发的,从原有的一个admin用户扩展成三个管理员用户和普通用户,下面简单分析一下其实现权限管理的原理。

数据库表

主要包括三张表:roles(角色表)、roles_group(角色与操作组关系表)、permissions(权限表)
角色RoleType有五种:SystemAdmin、SecurityAdmin、AuditAdmin、UserRole、QuotaConsumer

  • roles

clipboard.png

  • roles_group角色与操作组关系表(操作组id就是actionGroup中的id,也就是动作组的id,)

clipboard.png

  • permissions权限信息表(也相当于角色和用户的关联表,表示某个用户拥有对某个操作对象的权限,操作对香指存储,虚拟机,模板等对象)

clipboard.png

定义操作:

通过VdcActionType进行操作自定义,通过枚举设置操作与操作组的从属关系,而ActionGroup是定义操作组(或者说动作组)
比如瘦客thinClient作为一个操作组,则其包括好多种操作,比如登录VdcLogin和退出VdcLogout等等

// VdcLogin
    VdcLogin(5003, ActionGroup.THINCLIENT, QuotaDependency.NONE),
    VdcLogout(5004, ActionGroup.THINCLIENT, QuotaDependency.NONE),

clipboard.png

  • 通过00500_insert_roles.sql初始化角色权限

clipboard.png

  • 权限验证事务:系统中所有操作Command都提供getPermissionCheckSubjects方法,用来定义执行操作的权限列表

clipboard.png
permissionList权限列表中,包含权限对象PermissionSubject,权限对象的属性如下:

clipboard.png

  • 在系统的各种command的执行时,会检测权限,每个操作Command执行,必须定义操作权限列表,否则会直接提示没有操作权限:

clipboard.png

  • 最终通过存储过程进行权限查询get_entity_permissions

clipboard.png
clipboard.png

clipboard.png

满足权限的条件判断(1,2必须满足,3,4,5满足其中一个)

  1. 系统登录用户系统登录用户(user_id) 所属的 角色(role),必须与 操作组(action_group_id) 在 roles_groups 表中有对应关系

role_id IN( SELECT role_id FROM roles_groups WHERE action_group_id = v_action_group_id)
2.必须拥有需要删除的虚拟机的权限( 或者 所属群集、数据中心的权限。有待探讨)
AND (object_id IN(SELECT id FROM fn_get_entity_parents(v_object_id,v_object_type_id)))
3.功能分配了everyone权限
v_everyone_object_id := getGlobalIds('everyone');
ad_element_id = v_everyone_object_id
4.功能分配了该登录用户的权限
ad_element_id = v_user_id
5.功能分配了该登录用户所属用户组的权限
ad_element_id IN(SELECT * FROM getUserAndGroupsById(v_user_id)

权限的增加和删除:

通过 AddPermissionCommand操作添加权限
clipboard.png
通过RemovePermissionCommand的paramPermission操作删除权限,根据权限ID删除
getDbFacade().getPermissionDao().remove(perms.getId());


http://www.niftyadmin.cn/n/2145635.html

相关文章

linux预留的系统调用号,armlinux系统调用号和系统调用实现函数位置

armlinux系统调用号和系统调用实现函数位置系统调用序号:linux/include/asm-arm/unistd.h系统调用函数:arch/arm/kernel/calls.S对应了的文件:kernel/include/asm-generic/unistd.h可以查找关键字SYSCALL_DEFINE因为kernel/include/linux/sys…

jdbc中首次了解DAO及其子类

DAO: data(base) access object用于与数据库进行交互 1.实体类Customer.java package loey.java1.bean;import java.sql.Date;/** ORM编程思想 (object relational mapping)* 一个数据表对应一个java类* 表中的一条记录对应java类的一个对象* 表中的一…

nginx安装与部署

1:安装工具包 wget、vim和gcc yum install -y wget yum install -y vim-enhanced yum install -y make cmake gcc gcc-c 2:下载nginx安装包 wget http://nginx.org/download/nginx-1.6.2.tar.gz3:安装依赖包 yum install -y pcre pcre-devel yum install -y zlib zlib-devel …

linux运行速度慢怎么解决,Linux运行速度太慢的关键原因全都在这了

导读我们在搞清楚如何加速Linux计算机之前,需要知道哪些方法可以帮助我们找到引导时启动的服务、以更高或更低优先级运行的进程、CPU运行状况、内存是否塞满了过多数据,还要检查交换内存区是否已满。最后,我们还要检查硬盘是否运行正常。可能…

jdbc中的数据库连接池

1.传统连接的问题: 如何解决传统开发中的数据库连接问题:使用数据库连接池 2.使用数据库连接池的好处 资源重用 由于数据库连接得以重用,避免了频繁创建,释放连接引起的大量性能开销。在减少系统消耗 的基础上,另一方面也增加了…

用pm2管理hexo进程

2019独角兽企业重金招聘Python工程师标准>>> 一、在博客根目录下加如下js //run const { exec } require(child_process) exec(hexo server -p 80 & ,(error, stdout, stderr) > {if(error){console.log(exec error: ${error})return}console.log(stdout: $…

linux分配权限根据附加组吗,Linux用户、组和权限管理(一)

Linux是一个Multi-tasks(多任务)、 Multi-Users(多用户)的系统每一个登陆者或使用者都有用户标识、密码(所谓3A)所谓的3A:Authentication(验证机制)Authorization(授权机制)Audition(审计)组的概念:用户组,用户容器;是为了便于用户…

MVVM模式与第一个Vue程序

1.什么是MVVM模式? MVVM(Model-View-ViewModel)是一种软件架构设计模式,由微软 WPF(用于替代 WinForm,以 前就是用这个技术开发桌面应用程序的)和 Silverlight(类似于 Java Applet&…