jumpserver/apps/users/models/group.py

54 lines
1.7 KiB
Python
Raw Normal View History

2016-12-20 15:06:27 +00:00
# -*- coding: utf-8 -*-
2017-11-23 06:08:01 +00:00
import uuid
2016-12-20 16:43:52 +00:00
from django.db import models, IntegrityError
from django.utils.translation import ugettext_lazy as _
Dev beta (#3048) * [Update] 统一url地址 * [Update] 修改api * [Update] 使用规范的签名 * [Update] 修改url * [Update] 修改swagger * [Update] 添加serializer class避免报错 * [Update] 修改token * [Update] 支持api key * [Update] 支持生成api key * [Update] 修改api重定向 * [Update] 修改翻译 * [Update] 添加说明文档 * [Update] 修复浏览器关闭后session不失效的问题 * [Update] 修改一些内容 * [Update] 修改 jms脚本 * [Update] 修改重定向 * [Update] 修改搜索trim * [Update] 修改搜索trim * [Update] 添加sys log * [Bugfix] 修改登陆错误 * [Update] 优化User操作private_token的接口 (#3091) * [Update] 优化User操作private_token的接口 * [Update] 优化User操作private_token的接口 2 * [Bugfix] 解决授权了一个节点,当移动节点后,被移动的节点下的资产会放到未分组节点下的问题 * [Update] 升级jquery * [Update] 默认使用page * [Update] 修改使用Orgmodel view set * [Update] 支持 nv的硬盘 https://github.com/jumpserver/jumpserver/issues/1804 * [UPdate] 解决命令执行宽度问题 * [Update] 优化节点 * [Update] 修改nodes过多时创建比较麻烦 * [Update] 修改导入 * [Update] 节点获取更新 * [Update] 修改nodes * [Update] nodes显示full value * [Update] 统一使用nodes select2 函数 * [Update] 修改磁盘大小小数 * [Update] 修改 Node service * [Update] 优化授权节点 * [Update] 修改 node permission * [Update] 修改asset permission * [Stash] * [Update] 修改node assets api * [Update] 修改tree service,支持资产数量 * [Update] 修改暂时完成 * [Update] 修改一些bug
2019-08-21 12:27:21 +00:00
from orgs.mixins.models import OrgModelMixin
2018-07-13 16:47:21 +00:00
2016-12-20 16:43:52 +00:00
__all__ = ['UserGroup']
2018-07-13 16:47:21 +00:00
class UserGroup(OrgModelMixin):
2017-11-23 06:08:01 +00:00
id = models.UUIDField(default=uuid.uuid4, primary_key=True)
2018-07-16 06:47:06 +00:00
name = models.CharField(max_length=128, verbose_name=_('Name'))
2016-12-20 16:43:52 +00:00
comment = models.TextField(blank=True, verbose_name=_('Comment'))
2017-04-07 08:59:09 +00:00
date_created = models.DateTimeField(auto_now_add=True, null=True,
verbose_name=_('Date created'))
2018-01-25 04:17:26 +00:00
created_by = models.CharField(max_length=100, null=True, blank=True)
2016-12-20 16:43:52 +00:00
2017-12-04 12:15:47 +00:00
def __str__(self):
2016-12-20 16:43:52 +00:00
return self.name
class Meta:
ordering = ['name']
2018-08-16 08:32:49 +00:00
unique_together = [('org_id', 'name'),]
2018-03-05 04:59:14 +00:00
verbose_name = _("User group")
2016-12-20 16:43:52 +00:00
@classmethod
def initial(cls):
2017-03-04 08:38:26 +00:00
default_group = cls.objects.filter(name='Default')
if not default_group:
group = cls(name='Default', created_by='System', comment='Default user group')
group.save()
else:
group = default_group[0]
2016-12-20 16:43:52 +00:00
return group
@classmethod
def generate_fake(cls, count=100):
from random import seed, choice
import forgery_py
from . import User
seed()
for i in range(count):
group = cls(name=forgery_py.name.full_name(),
comment=forgery_py.lorem_ipsum.sentence(),
created_by=choice(User.objects.all()).username)
try:
group.save()
except IntegrityError:
print('Error continue')
continue