# coding: utf-8 import datetime from django.db import models from juser.models import User, UserGroup class AssetGroup(models.Model): GROUP_TYPE = ( ('P', 'PRIVATE'), ('A', 'ASSET'), ) name = models.CharField(max_length=80, unique=True) comment = models.CharField(max_length=160, blank=True, null=True) def __unicode__(self): return self.name def get_asset(self): return self.asset_set.all() def get_asset_info(self, printable=False): assets = self.get_asset() ip_comment = {} for asset in assets: ip_comment[asset.ip] = asset.comment for ip in sorted(ip_comment): if ip_comment[ip]: print '%-15s -- %s' % (ip, ip_comment[ip]) else: print '%-15s' % ip print '' def get_asset_num(self): return len(self.get_asset()) def get_user_group(self): perm_list = self.perm_set.all() user_group_list = [] for perm in perm_list: user_group_list.append(perm.user_group) return user_group_list def get_user(self): user_list = [] user_group_list = self.get_user_group() for user_group in user_group_list: user_list.extend(user_group.user_set.all()) return user_list def is_permed(self, user=None, user_group=None): if user: if user in self.get_user(): return True if user_group: if user_group in self.get_user_group(): return True return False class IDC(models.Model): name = models.CharField(max_length=32, unique=True) bandwidth = models.CharField(max_length=32, blank=True, null=True) linkman = models.CharField(max_length=16, blank=True, null=True) phone = models.CharField(max_length=32, blank=True, null=True) address = models.CharField(max_length=128, blank=True, null=True) network = models.TextField(blank=True, null=True) date_added = models.DateField(auto_now=True, default=datetime.datetime.now()) operator = models.IntegerField(max_length=32, blank=True, null=True) comment = models.CharField(max_length=128, blank=True, null=True) def __unicode__(self): return self.name class Asset(models.Model): """ asset modle """ ENVIRONMENT = ( (0, U'生产环境'), (1, U'测试环境') ) SERVER_STATUS = ( (0, u"已使用"), (1, u"未使用"), (2, u"报废") ) ASSET_TYPE = ( (0, u"服务器"), (2, u"网络设备"), (3, u"其他") ) ip = models.IPAddressField(unique=True) second_ip = models.CharField(max_length=255, blank=True, null=True) hostname = models.CharField(max_length=64, blank=True, null=True) port = models.IntegerField(max_length=6) group = models.ManyToManyField(AssetGroup, blank=True, null=True) username = models.CharField(max_length=16, blank=True, null=True) password = models.CharField(max_length=64, blank=True, null=True) use_default_auth = models.BooleanField(default=True) idc = models.ForeignKey(IDC, blank=True, null=True, on_delete=models.SET_NULL) mac = models.CharField(max_length=20, blank=True, null=True) remote_ip = models.IPAddressField(unique=True, blank=True, null=True) brand = models.CharField(max_length=64, blank=True, null=True) cpu = models.CharField(max_length=64, blank=True, null=True) memory = models.CharField(max_length=128, blank=True, null=True) disk = models.CharField(max_length=128, blank=True, null=True) system_type = models.CharField(max_length=32, blank=True, null=True) system_version = models.CharField(max_length=8, blank=True, null=True) cabinet = models.CharField(max_length=32, blank=True, null=True) position = models.IntegerField(max_length=2, blank=True, null=True) number = models.CharField(max_length=32, blank=True, null=True) status = models.IntegerField(max_length=2, choices=SERVER_STATUS, default=1) asset_type = models.IntegerField(max_length=2, choices=ASSET_TYPE, blank=True, null=True) env = models.CharField(max_length=32, choices=ENVIRONMENT, blank=True, null=True) sn = models.CharField(max_length=32, blank=True, null=True) date_added = models.DateTimeField(auto_now=True, default=datetime.datetime.now()) is_active = models.BooleanField(default=True) comment = models.CharField(max_length=128, blank=True, null=True) def __unicode__(self): return self.ip def get_user(self): perm_list = [] asset_group_all = self.bis_group.all() for asset_group in asset_group_all: perm_list.extend(asset_group.perm_set.all()) user_group_list = [] for perm in perm_list: user_group_list.append(perm.user_group) user_permed_list = [] for user_group in user_group_list: user_permed_list.extend(user_group.user_set.all()) user_permed_list = list(set(user_permed_list)) return user_permed_list class AssetAlias(models.Model): user = models.ForeignKey(User) asset = models.ForeignKey(Asset) alias = models.CharField(max_length=100, null=True) def __unicode__(self): return self.alias