2015-12-19 09:26:34 +00:00
|
|
|
# coding: utf-8
|
|
|
|
|
2015-04-20 02:12:11 +00:00
|
|
|
import datetime
|
|
|
|
from django.db import models
|
2015-12-19 09:26:34 +00:00
|
|
|
from juser.models import User, UserGroup
|
2015-04-20 02:12:11 +00:00
|
|
|
|
2015-12-19 09:26:34 +00:00
|
|
|
ASSET_ENV = (
|
|
|
|
(1, U'生产环境'),
|
|
|
|
(2, U'测试环境')
|
|
|
|
)
|
2015-04-20 02:12:11 +00:00
|
|
|
|
2015-12-19 09:26:34 +00:00
|
|
|
ASSET_STATUS = (
|
|
|
|
(1, u"已使用"),
|
|
|
|
(2, u"未使用"),
|
|
|
|
(3, u"报废")
|
|
|
|
)
|
2015-04-20 02:12:11 +00:00
|
|
|
|
2015-12-19 09:26:34 +00:00
|
|
|
ASSET_TYPE = (
|
|
|
|
(1, u"物理机"),
|
|
|
|
(2, u"虚拟机"),
|
|
|
|
(3, u"交换机"),
|
|
|
|
(4, u"路由器"),
|
|
|
|
(5, u"防火墙"),
|
|
|
|
(6, u"Docker"),
|
|
|
|
(7, u"其他")
|
|
|
|
)
|
2015-04-20 02:12:11 +00:00
|
|
|
|
|
|
|
|
2015-12-19 09:26:34 +00:00
|
|
|
class AssetGroup(models.Model):
|
2015-04-20 02:12:11 +00:00
|
|
|
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
|
|
|
|
|
|
|
|
|
2015-12-19 09:26:34 +00:00
|
|
|
class IDC(models.Model):
|
|
|
|
name = models.CharField(max_length=32, verbose_name=u'机房名称')
|
|
|
|
bandwidth = models.CharField(max_length=32, blank=True, null=True, default='', verbose_name=u'机房带宽')
|
|
|
|
linkman = models.CharField(max_length=16, blank=True, null=True, default='', verbose_name=u'联系人')
|
|
|
|
phone = models.CharField(max_length=32, blank=True, null=True, default='', verbose_name=u'联系电话')
|
|
|
|
address = models.CharField(max_length=128, blank=True, null=True, default='', verbose_name=u"机房地址")
|
|
|
|
network = models.TextField(blank=True, null=True, default='', verbose_name=u"IP地址段")
|
|
|
|
date_added = models.DateField(auto_now=True, null=True)
|
|
|
|
operator = models.CharField(max_length=32, blank=True, default='', null=True, verbose_name=u"运营商")
|
|
|
|
comment = models.CharField(max_length=128, blank=True, default='', null=True, verbose_name=u"备注")
|
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
verbose_name = u"IDC机房"
|
|
|
|
verbose_name_plural = verbose_name
|
|
|
|
|
|
|
|
|
2015-04-20 02:12:11 +00:00
|
|
|
class Asset(models.Model):
|
2015-12-19 09:26:34 +00:00
|
|
|
"""
|
|
|
|
asset modle
|
|
|
|
"""
|
|
|
|
ip = models.CharField(max_length=32, blank=True, null=True, verbose_name=u"主机IP")
|
|
|
|
other_ip = models.CharField(max_length=255, blank=True, null=True, verbose_name=u"其他IP")
|
|
|
|
hostname = models.CharField(unique=True, max_length=128, verbose_name=u"主机名")
|
|
|
|
port = models.IntegerField(blank=True, null=True, verbose_name=u"端口号")
|
|
|
|
group = models.ManyToManyField(AssetGroup, blank=True, verbose_name=u"所属主机组")
|
|
|
|
username = models.CharField(max_length=16, blank=True, null=True, verbose_name=u"管理用户名")
|
|
|
|
password = models.CharField(max_length=64, blank=True, null=True, verbose_name=u"密码")
|
|
|
|
use_default_auth = models.BooleanField(default=True, verbose_name=u"使用默认管理账号")
|
|
|
|
idc = models.ForeignKey(IDC, blank=True, null=True, on_delete=models.SET_NULL, verbose_name=u'机房')
|
|
|
|
mac = models.CharField(max_length=20, blank=True, null=True, verbose_name=u"MAC地址")
|
|
|
|
remote_ip = models.CharField(max_length=16, blank=True, null=True, verbose_name=u'远控卡IP')
|
|
|
|
brand = models.CharField(max_length=64, blank=True, null=True, verbose_name=u'硬件厂商型号')
|
|
|
|
cpu = models.CharField(max_length=64, blank=True, null=True, verbose_name=u'CPU')
|
|
|
|
memory = models.CharField(max_length=128, blank=True, null=True, verbose_name=u'内存')
|
|
|
|
disk = models.CharField(max_length=128, blank=True, null=True, verbose_name=u'硬盘')
|
|
|
|
system_type = models.CharField(max_length=32, blank=True, null=True, verbose_name=u"系统类型")
|
|
|
|
system_version = models.CharField(max_length=8, blank=True, null=True, verbose_name=u"系统版本号")
|
|
|
|
system_arch = models.CharField(max_length=16, blank=True, null=True, verbose_name=u"系统平台")
|
|
|
|
cabinet = models.CharField(max_length=32, blank=True, null=True, verbose_name=u'机柜号')
|
|
|
|
position = models.IntegerField(blank=True, null=True, verbose_name=u'机器位置')
|
|
|
|
number = models.CharField(max_length=32, blank=True, null=True, verbose_name=u'资产编号')
|
|
|
|
status = models.IntegerField(choices=ASSET_STATUS, blank=True, null=True, default=1, verbose_name=u"机器状态")
|
|
|
|
asset_type = models.IntegerField(choices=ASSET_TYPE, blank=True, null=True, verbose_name=u"主机类型")
|
|
|
|
env = models.IntegerField(choices=ASSET_ENV, blank=True, null=True, verbose_name=u"运行环境")
|
|
|
|
sn = models.CharField(max_length=128, blank=True, null=True, verbose_name=u"SN编号")
|
|
|
|
date_added = models.DateTimeField(auto_now=True, null=True)
|
|
|
|
is_active = models.BooleanField(default=True, verbose_name=u"是否激活")
|
|
|
|
comment = models.CharField(max_length=128, blank=True, null=True, verbose_name=u"备注")
|
2015-04-20 02:12:11 +00:00
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return self.ip
|
|
|
|
|
|
|
|
|
2015-12-19 09:26:34 +00:00
|
|
|
class AssetRecord(models.Model):
|
|
|
|
asset = models.ForeignKey(Asset)
|
|
|
|
username = models.CharField(max_length=30, null=True)
|
|
|
|
alert_time = models.DateTimeField(auto_now_add=True)
|
|
|
|
content = models.TextField(null=True, blank=True)
|
|
|
|
comment = models.TextField(null=True, blank=True)
|
|
|
|
|
|
|
|
|
2015-04-20 02:12:11 +00:00
|
|
|
class AssetAlias(models.Model):
|
|
|
|
user = models.ForeignKey(User)
|
2015-12-19 09:26:34 +00:00
|
|
|
asset = models.ForeignKey(Asset)
|
2015-04-20 02:12:11 +00:00
|
|
|
alias = models.CharField(max_length=100, blank=True, null=True)
|
|
|
|
|
|
|
|
def __unicode__(self):
|
2015-12-19 09:26:34 +00:00
|
|
|
return self.alias
|