You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
flyapps/fir_ser/xsign/models.py

329 lines
17 KiB

from django.db import models
from api.models import Apps, UserInfo
from common.base.daobase import AESCharField
from common.constants import DeviceStatus, AppleDeveloperStatus, SignStatus, DeviceClass
class AppIOSDeveloperInfo(models.Model):
"""
苹果开发者信息
"""
user_id = models.ForeignKey(to=UserInfo, verbose_name="用户ID", on_delete=models.CASCADE)
issuer_id = models.CharField(max_length=64, null=False, verbose_name="标识创建认证令牌的发放者")
private_key_id = models.CharField(max_length=64, null=False, verbose_name="密钥 ID")
p8key = AESCharField(max_length=512, null=False, verbose_name="p8key")
certid = models.CharField(max_length=64, blank=True, verbose_name="超级签名自动创建证书ID", null=True)
usable_number = models.IntegerField(verbose_name="可使用设备数", default=100)
app_limit_number = models.IntegerField(verbose_name="可分配应用数,最大160", default=100)
created_time = models.DateTimeField(auto_now_add=True, verbose_name="创建时间")
updated_time = models.DateTimeField(auto_now=True, verbose_name="更新时间")
cert_expire_time = models.DateTimeField(blank=True, null=True, verbose_name="证书过期时间")
description = models.TextField('备注', blank=True, null=True, default='')
auth_type_choices = ((0, 'p8key认证'),)
auth_type = models.SmallIntegerField(choices=auth_type_choices, default=0, verbose_name="认证类型")
# 协议待同意和维护中:代表只读,不可创建和注册新设备号
status_choices = ((AppleDeveloperStatus.BAN, '疑似被封'), (AppleDeveloperStatus.INACTIVATED, '未激活'),
(AppleDeveloperStatus.ACTIVATED, '已激活'),
(AppleDeveloperStatus.AGREEMENT_NOT_AGREED, '协议待同意'),
(AppleDeveloperStatus.MAINTENANCE, '维护中'),
(AppleDeveloperStatus.CERTIFICATE_EXPIRED, '证书过期'),
(AppleDeveloperStatus.CERTIFICATE_MISSING, '证书丢失'),
(AppleDeveloperStatus.DEVICE_ABNORMAL, '设备异常'),
(AppleDeveloperStatus.ABNORMAL_STATUS, '状态异常'))
status = models.SmallIntegerField(choices=status_choices, verbose_name="账户状态",
default=AppleDeveloperStatus.INACTIVATED)
clean_status = models.BooleanField(verbose_name="清理是否同时禁用设备ID", default=False)
auto_check = models.BooleanField(verbose_name="是否自动检测开发者状态", default=False)
abnormal_register = models.BooleanField(verbose_name="设备异常状态是否注册", default=True)
class Meta:
verbose_name = '苹果开发者账户'
verbose_name_plural = "苹果开发者账户"
unique_together = (('user_id', 'issuer_id'),)
def save(self, *args, **kwargs):
if self.usable_number > 100:
self.usable_number = 100
elif self.usable_number < 0:
self.usable_number = 0
if self.app_limit_number > 160:
self.app_limit_number = 160
elif self.app_limit_number < 0:
self.app_limit_number = 0
return super(AppIOSDeveloperInfo, self).save(*args, **kwargs)
def __str__(self):
return f"{self.user_id}-{self.issuer_id}-{self.get_status_display()}-{self.description}"
class UDIDsyncDeveloper(models.Model):
"""
开发者设备ID记录
"""
developerid = models.ForeignKey(to=AppIOSDeveloperInfo, on_delete=models.CASCADE, verbose_name="所使用苹果开发者账户")
udid = models.CharField(max_length=64, verbose_name="udid唯一标识", db_index=True)
product = models.CharField(max_length=64, verbose_name="产品", blank=True, null=True, )
serial = models.CharField(max_length=64, verbose_name="序列号", blank=True, null=True, )
version = models.CharField(max_length=64, verbose_name="型号", blank=True, null=True, )
created_time = models.DateTimeField(auto_now_add=True, verbose_name="创建时间") # django.utils.timezone.now()
status_choices = ((DeviceStatus.DISABLED, '禁用'), (DeviceStatus.ENABLED, '启用'),
(DeviceStatus.PROCESSING, '处理中'), (DeviceStatus.INELIGIBLE, '不合格'))
status = models.CharField(choices=status_choices, verbose_name="设备状态", default=DeviceStatus.DISABLED, max_length=16)
device_class_choices = ((DeviceClass.APPLE_WATCH, 'APPLE_WATCH'), (DeviceClass.IPAD, 'IPAD'),
(DeviceClass.IPHONE, 'IPHONE'), (DeviceClass.IPOD, 'IPOD'),
(DeviceClass.APPLE_TV, 'APPLE_TV'), (DeviceClass.MAC, 'MAC'))
device_class = models.CharField(choices=device_class_choices, verbose_name="设备类型", default=DeviceClass.IPHONE,
max_length=16)
class Meta:
verbose_name = 'iOS开发平台同步设备信息'
verbose_name_plural = "iOS开发平台同步设备信息"
unique_together = ('udid', 'developerid',)
def __str__(self):
return f"{self.product}-{self.udid}-{self.developerid}-{self.status}"
class AppUDID(models.Model):
"""
用户发送的设备记录信息
"""
app_id = models.ForeignKey(to=Apps, on_delete=models.CASCADE, verbose_name="属于哪个APP")
udid = models.ForeignKey(to=UDIDsyncDeveloper, verbose_name="udid唯一标识", on_delete=models.CASCADE)
product = models.CharField(max_length=64, verbose_name="产品", blank=True, null=True, )
serial = models.CharField(max_length=64, verbose_name="序列号", blank=True, null=True, )
version = models.CharField(max_length=64, verbose_name="型号", blank=True, null=True, )
imei = models.CharField(max_length=64, verbose_name="型号", blank=True, null=True, )
iccid = models.CharField(max_length=64, verbose_name="型号", blank=True, null=True, )
created_time = models.DateTimeField(auto_now_add=True, verbose_name="创建时间")
updated_time = models.DateTimeField(auto_now=True, verbose_name="更新时间")
sign_status_choices = ((SignStatus.SIGNATURE_PREPARE, '新设备入库准备'),
(SignStatus.DEVICE_REGISTRATION_COMPLETE, '设备ID已经注册'),
(SignStatus.APP_REGISTRATION_COMPLETE, 'bundelid已经注册'),
(SignStatus.PROFILE_DOWNLOAD_COMPLETE, '描述文件已经下载'),
(SignStatus.SIGNATURE_PACKAGE_COMPLETE, '已经完成签名打包'))
sign_status = models.SmallIntegerField(choices=sign_status_choices, default=SignStatus.SIGNATURE_PREPARE,
verbose_name="签名状态")
class Meta:
verbose_name = '设备详情'
verbose_name_plural = "设备详情"
unique_together = ('app_id', 'udid',)
def __str__(self):
return f"{self.app_id.name}-{self.udid}"
class APPSuperSignUsedInfo(models.Model):
"""
设备消耗统计
"""
user_id = models.ForeignKey(to=UserInfo, verbose_name="用户ID", on_delete=models.CASCADE)
app_id = models.ForeignKey(to=Apps, on_delete=models.CASCADE, verbose_name="属于哪个APP")
udid = models.ForeignKey(to=AppUDID, on_delete=models.CASCADE, verbose_name="所消耗的udid")
developerid = models.ForeignKey(to=AppIOSDeveloperInfo, on_delete=models.CASCADE, verbose_name="所使用苹果开发者账户")
created_time = models.DateTimeField(auto_now_add=True, verbose_name="创建时间")
updated_time = models.DateTimeField(auto_now=True, verbose_name="更新时间")
class Meta:
verbose_name = '设备使用统计'
verbose_name_plural = "设备使用统计"
def __str__(self):
return f"{self.user_id}-{self.app_id}-{self.udid}"
class APPToDeveloper(models.Model):
"""
签名完成之后,通过该表查询 签名包地址
"""
app_id = models.ForeignKey(to=Apps, on_delete=models.CASCADE, verbose_name="属于哪个APP")
developerid = models.ForeignKey(to=AppIOSDeveloperInfo, on_delete=models.CASCADE, verbose_name="所使用苹果开发者账户")
binary_file = models.CharField(max_length=128, blank=True, verbose_name="签名包名称", null=True, unique=True)
release_file = models.CharField(max_length=128, blank=True, verbose_name="源包名称", null=True)
updated_time = models.DateTimeField(auto_now=True, verbose_name="更新时间")
class Meta:
verbose_name = '应用开发者绑定'
verbose_name_plural = "应用开发者绑定"
def __str__(self):
return f"{self.developerid}-{self.app_id}-{self.binary_file}"
class DeveloperAppID(models.Model):
"""
苹果应用消耗某个开发者某个描述文件对应记录表,一个苹果应用对应一个苹果开发者和该开发者下面对应的描述文件
"""
aid = models.CharField(max_length=64, null=False) # ,apple APP 唯一标识
profile_id = models.CharField(max_length=64, null=True, blank=True) # ,profile_id 唯一标识
developerid = models.ForeignKey(to=AppIOSDeveloperInfo, on_delete=models.CASCADE, verbose_name="所使用苹果开发者账户")
app_id = models.ForeignKey(to=Apps, on_delete=models.CASCADE, verbose_name="属于哪个APP")
class Meta:
verbose_name = '超级签APP id'
verbose_name_plural = "超级签APP id"
unique_together = ('aid', 'developerid', 'app_id')
def __str__(self):
return f"{self.aid}-{self.app_id}-{self.developerid}"
class DeveloperDevicesID(models.Model):
"""
苹果应用消耗某个开发者某个设备对应记录表,有一个苹果应用可能有该开发者下面多个设备记录
"""
did = models.CharField(max_length=64, null=False) # ,apple 设备唯一标识
udid = models.ForeignKey(to=UDIDsyncDeveloper, on_delete=models.CASCADE, verbose_name="所消耗的udid")
developerid = models.ForeignKey(to=AppIOSDeveloperInfo, on_delete=models.CASCADE, verbose_name="所使用苹果开发者账户")
app_id = models.ForeignKey(to=Apps, on_delete=models.CASCADE, verbose_name="属于哪个APP")
class Meta:
verbose_name = '超级签Devices id'
verbose_name_plural = "超级签Devices id"
unique_together = ('did', 'developerid', 'app_id')
def __str__(self):
return f"{self.id}-{self.app_id}-{self.developerid}-{self.udid}"
class IosDeveloperPublicPoolBill(models.Model):
"""
苹果应用设备消费记录表
"""
user_id = models.ForeignKey(to=UserInfo, verbose_name="用户ID", on_delete=models.CASCADE)
number = models.IntegerField(verbose_name="消耗次数", default=1)
app_info = models.JSONField(max_length=256, verbose_name="属于哪个APP", null=True, blank=True)
udid = models.CharField(max_length=64, verbose_name="设备udid", null=True, blank=True)
product = models.CharField(max_length=64, verbose_name="设备udid", null=True, blank=True)
version = models.CharField(max_length=64, verbose_name="设备udid", null=True, blank=True)
developer_info = models.JSONField(max_length=256, verbose_name="开发者信息", null=True, blank=True)
udid_sync_info = models.ForeignKey(to=UDIDsyncDeveloper, on_delete=models.SET_NULL, verbose_name="关联同步设备信息",
null=True, blank=True)
app_id = models.ForeignKey(to=Apps, on_delete=models.SET_NULL, verbose_name="属于哪个APP", null=True, blank=True)
description = models.CharField(verbose_name="操作描述", max_length=128, default='', blank=True)
remote_addr = models.GenericIPAddressField(verbose_name="远程IP地址")
created_time = models.DateTimeField(auto_now_add=True, verbose_name="添加时间")
class Meta:
verbose_name = '设备消耗账单'
verbose_name_plural = "设备消耗账单"
def __str__(self):
return f"{self.user_id}-{self.description}"
class IosDeveloperBill(models.Model):
"""
用户共享设备数,可将该用户设备数共享给 其他用户使用
"""
user_id = models.ForeignKey(to=UserInfo, verbose_name="用户ID", on_delete=models.CASCADE,
related_name='org_user_id')
to_user_id = models.ForeignKey(to=UserInfo, verbose_name="用户ID", on_delete=models.CASCADE,
related_name='to_user_id', null=True, blank=True)
status_choices = ((0, '失效'), (1, '已撤回'), (2, '成功'))
status = models.SmallIntegerField(choices=status_choices, default=0, verbose_name="状态",
help_text="0 失效 1 撤回 2 转账")
number = models.IntegerField(verbose_name="设备数量", default=1)
description = models.CharField(verbose_name="操作描述", max_length=128, default='', blank=True)
remote_addr = models.GenericIPAddressField(verbose_name="远程IP地址")
created_time = models.DateTimeField(auto_now_add=True, verbose_name="添加时间")
updated_time = models.DateTimeField(auto_now=True, verbose_name="更新时间")
class Meta:
verbose_name = '设备划转账单'
verbose_name_plural = "设备划转账单"
def __str__(self):
return f"{self.user_id}-{self.to_user_id}{self.description}"
class AppleDeveloperToAppUse(models.Model):
"""
苹果应用专属开发者配置表
"""
app_id = models.ForeignKey(to=Apps, on_delete=models.CASCADE)
developerid = models.ForeignKey(to=AppIOSDeveloperInfo, on_delete=models.CASCADE)
usable_number = models.IntegerField(verbose_name="可使用设备数", default=100)
description = models.CharField(verbose_name="备注", max_length=256, default='', blank=True)
created_time = models.DateTimeField(auto_now_add=True, verbose_name="添加时间")
class Meta:
verbose_name = '开发者专属于应用'
verbose_name_plural = "开发者专属于应用"
unique_together = ('app_id', 'developerid')
def __str__(self):
return f"{self.app_id.name}-{self.developerid.issuer_id}"
class OperateMessageBase(models.Model):
"""
操作详细记录,一般为失败的记录
"""
user_id = models.ForeignKey(to=UserInfo, verbose_name="操作用户", on_delete=models.CASCADE)
title = models.CharField(verbose_name="操作功能", max_length=256, default='', blank=True)
status_choices = ((0, '失败'), (1, '成功'))
operate_status = models.SmallIntegerField(choices=status_choices, default=0, verbose_name="状态")
message = models.TextField(verbose_name="操作详细日志", default='', blank=True)
operate_time = models.DateTimeField(auto_now_add=True, verbose_name="操作时间")
class Meta:
abstract = True
class AppleSignMessage(OperateMessageBase):
app_id = models.ForeignKey(to=Apps, on_delete=models.CASCADE, null=True, blank=True)
developerid = models.ForeignKey(to=AppIOSDeveloperInfo, on_delete=models.CASCADE)
class Meta:
verbose_name = '应用签名操作记录'
verbose_name_plural = "应用签名操作记录"
def __str__(self):
return f"{self.app_id.name}-{self.developerid.issuer_id}-{self.title}"
class DeviceBlackUDID(models.Model):
"""
设备黑名单
"""
user_id = models.ForeignKey(to=UserInfo, verbose_name="操作用户", on_delete=models.CASCADE)
udid = models.CharField(max_length=64, verbose_name='手动添加设备udid', unique=True)
enable = models.BooleanField(verbose_name="是否生效", default=True)
description = models.CharField(verbose_name="备注", max_length=256, default='', blank=True)
created_time = models.DateTimeField(auto_now=True, verbose_name="添加时间")
class Meta:
verbose_name = '设备黑名单'
verbose_name_plural = "设备黑名单"
def __str__(self):
return f"{self.udid}-{self.description}-{self.created_time}"
class DeviceAbnormalUDID(models.Model):
"""
异常设备
系统根据 【异常状态等待】 判断是否等待,等待的数据将会插入该库,并在下次注册或者设备检测 根据是否自动移除进行操作
"""
user_id = models.ForeignKey(to=UserInfo, verbose_name="操作用户", on_delete=models.CASCADE)
udid = models.ForeignKey(to=UDIDsyncDeveloper, verbose_name="自动添加设备udid", on_delete=models.CASCADE)
auto_remove = models.BooleanField(verbose_name="是否自动移除", default=True)
description = models.CharField(verbose_name="备注", max_length=256, default='', blank=True)
created_time = models.DateTimeField(auto_now_add=True, verbose_name="添加时间")
class Meta:
verbose_name = '异常设备信息'
verbose_name_plural = "异常设备信息"
def __str__(self):
return f"{self.udid}-{self.description}-{self.created_time}"