mirror of https://github.com/jumpserver/jumpserver
153 lines
4.9 KiB
Python
153 lines
4.9 KiB
Python
from django.utils.translation import ugettext_noop
|
|
|
|
from .const import Scope, system_exclude_permissions, org_exclude_permissions
|
|
|
|
# Todo: 获取应该区分 系统用户,和组织用户的权限
|
|
# 工作台也区分组织后再考虑
|
|
user_perms = (
|
|
('rbac', 'menupermission', 'view', 'workspace'),
|
|
('rbac', 'menupermission', 'view', 'webterminal'),
|
|
('rbac', 'menupermission', 'view', 'filemanager'),
|
|
('perms', 'permedasset', 'view,connect', 'myassets'),
|
|
('perms', 'permedapplication', 'view,connect', 'myapps'),
|
|
('assets', 'asset', 'match', 'asset'),
|
|
('assets', 'systemuser', 'match', 'systemuser'),
|
|
('assets', 'node', 'match', 'node'),
|
|
('applications', 'application', 'match', 'application'),
|
|
('ops', 'commandexecution', 'add', 'commandexecution'),
|
|
('authentication', 'connectiontoken', 'add', 'connectiontoken'),
|
|
('tickets', 'ticket', 'view', 'ticket'),
|
|
)
|
|
|
|
auditor_perms = user_perms + (
|
|
('rbac', 'menupermission', 'view', 'audit'),
|
|
('audits', '*', '*', '*'),
|
|
('terminal', 'commandstorage', 'view', 'commandstorage'),
|
|
('terminal', 'sessionreplay', 'view,download', 'sessionreplay'),
|
|
('terminal', 'session', '*', '*'),
|
|
('terminal', 'command', '*', '*'),
|
|
('ops', 'commandexecution', 'view', 'commandexecution')
|
|
)
|
|
|
|
app_exclude_perms = [
|
|
('users', 'user', 'add,delete', 'user'),
|
|
('orgs', 'org', 'add,delete,change', 'org'),
|
|
('rbac', '*', '*', '*'),
|
|
]
|
|
|
|
need_check = [
|
|
*auditor_perms, *user_perms, *app_exclude_perms,
|
|
*system_exclude_permissions, *org_exclude_permissions
|
|
]
|
|
defines_errors = [d for d in need_check if len(d) != 4]
|
|
if len(defines_errors) != 0:
|
|
raise ValueError('Perms define error: {}'.format(defines_errors))
|
|
|
|
|
|
class PredefineRole:
|
|
id_prefix = '00000000-0000-0000-0000-00000000000'
|
|
|
|
def __init__(self, index, name, scope, perms, perms_type='include'):
|
|
self.id = self.id_prefix + index
|
|
self.name = name
|
|
self.scope = scope
|
|
self.perms = perms
|
|
self.perms_type = perms_type
|
|
|
|
def get_role(self):
|
|
from rbac.models import Role
|
|
return Role.objects.get(id=self.id)
|
|
|
|
@property
|
|
def default_perms(self):
|
|
from rbac.models import Permission
|
|
q = Permission.get_define_permissions_q(self.perms)
|
|
permissions = Permission.get_permissions(self.scope)
|
|
|
|
if not q:
|
|
permissions = permissions.none()
|
|
elif self.perms_type == 'include':
|
|
permissions = permissions.filter(q)
|
|
else:
|
|
permissions = permissions.exclude(q)
|
|
|
|
perms = permissions.values_list('id', flat=True)
|
|
return perms
|
|
|
|
def _get_defaults(self):
|
|
perms = self.default_perms
|
|
defaults = {
|
|
'id': self.id, 'name': self.name, 'scope': self.scope,
|
|
'builtin': True, 'permissions': perms
|
|
}
|
|
return defaults
|
|
|
|
def update_or_create_role(self):
|
|
from rbac.models import Role
|
|
defaults = self._get_defaults()
|
|
permissions = defaults.pop('permissions', [])
|
|
role, created = Role.objects.update_or_create(defaults, id=self.id)
|
|
role.permissions.set(permissions)
|
|
return role, created
|
|
|
|
|
|
class BuiltinRole:
|
|
system_admin = PredefineRole(
|
|
'1', ugettext_noop('SystemAdmin'), Scope.system, []
|
|
)
|
|
system_auditor = PredefineRole(
|
|
'2', ugettext_noop('SystemAuditor'), Scope.system, auditor_perms
|
|
)
|
|
system_component = PredefineRole(
|
|
'4', ugettext_noop('SystemComponent'), Scope.system, app_exclude_perms, 'exclude'
|
|
)
|
|
system_user = PredefineRole(
|
|
'3', ugettext_noop('User'), Scope.system, user_perms
|
|
)
|
|
org_admin = PredefineRole(
|
|
'5', ugettext_noop('OrgAdmin'), Scope.org, []
|
|
)
|
|
org_auditor = PredefineRole(
|
|
'6', ugettext_noop('OrgAuditor'), Scope.org, auditor_perms
|
|
)
|
|
org_user = PredefineRole(
|
|
'7', ugettext_noop('OrgUser'), Scope.org, user_perms
|
|
)
|
|
|
|
@classmethod
|
|
def get_roles(cls):
|
|
roles = {
|
|
k: v
|
|
for k, v in cls.__dict__.items()
|
|
if isinstance(v, PredefineRole)
|
|
}
|
|
return roles
|
|
|
|
@classmethod
|
|
def get_system_role_by_old_name(cls, name):
|
|
mapper = {
|
|
'App': cls.system_component,
|
|
'Admin': cls.system_admin,
|
|
'User': cls.system_user,
|
|
'Auditor': cls.system_auditor
|
|
}
|
|
return mapper[name].get_role()
|
|
|
|
@classmethod
|
|
def get_org_role_by_old_name(cls, name):
|
|
mapper = {
|
|
'Admin': cls.org_admin,
|
|
'User': cls.org_user,
|
|
'Auditor': cls.org_auditor,
|
|
}
|
|
return mapper[name].get_role()
|
|
|
|
@classmethod
|
|
def sync_to_db(cls, show_msg=False):
|
|
roles = cls.get_roles()
|
|
|
|
for pre_role in roles.values():
|
|
role, created = pre_role.update_or_create_role()
|
|
if show_msg:
|
|
print("Update builtin Role: {} - {}".format(role.name, created))
|