| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773 | 
							- #!/usr/bin/env python3
 
- # -*- coding: utf-8 -*-
 
- import json
 
- import operator
 
- import time
 
- from bisect import bisect_left
 
- import oss2
 
- from django.db import transaction
 
- from django.db.models import Q, F
 
- from django.views.generic.base import View
 
- from Ansjer.config import OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET, AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY, \
 
-     AWS_SES_ACCESS_REGION, UNUSED_SERIAL_REDIS_LIST
 
- from Model.models import Device_Info, UidSetModel, LogModel, UID_Bucket, Unused_Uid_Meal, Order_Model, StsCrdModel, \
 
-     VodHlsModel, ExperienceContextModel, DeviceTypeModel, Equipment_Info, UidUserModel, ExperienceAiModel, AiService, \
 
-     AppBundle, App_Info, AppDeviceType, DeviceNameLanguage, AppVersionNumber, UIDCompanySerialModel, UIDModel, \
 
-     CompanySerialModel
 
- from Object.AWS.AmazonS3Util import AmazonS3Util
 
- from Object.RedisObject import RedisObject
 
- from Object.ResponseObject import ResponseObject
 
- from Object.TokenObject import TokenObject
 
- from Service.CommonService import CommonService
 
- from Service.EquipmentInfoService import EquipmentInfoService
 
- from Service.ModelService import ModelService
 
- from Service.VodHlsService import SplitVodHlsObject
 
- class DeviceManagement(View):
 
-     def get(self, request, *args, **kwargs):
 
-         request.encoding = 'utf-8'
 
-         operation = kwargs.get('operation')
 
-         return self.validation(request.GET, request, operation)
 
-     def post(self, request, *args, **kwargs):
 
-         request.encoding = 'utf-8'
 
-         operation = kwargs.get('operation')
 
-         return self.validation(request.POST, request, operation)
 
-     def validation(self, request_dict, request, operation):
 
-         language = request_dict.get('language', 'en')
 
-         response = ResponseObject(language, 'pc')
 
-         if operation == 'addDeviceType':
 
-             return self.addDeviceType(request, request_dict, response)
 
-         elif operation == 'delDeviceData':  # 删除设备数据
 
-             return self.del_device_data(request_dict, response)
 
-         elif operation == 'getDeviceIcon':  # app获取设备图标
 
-             response = ResponseObject(language)
 
-             return self.get_device_icon(request_dict, response)
 
-         elif operation == 'addAppDeviceType':  # 添加app设备类型数据并上传图标
 
-             return self.add_app_device_type(request_dict, response, request)
 
-         else:
 
-             tko = TokenObject(
 
-                 request.META.get('HTTP_AUTHORIZATION'),
 
-                 returntpye='pc')
 
-             if tko.code != 0:
 
-                 return response.json(tko.code)
 
-             response.lang = tko.lang
 
-             userID = tko.userID
 
-             if not userID:
 
-                 return response.json(444, 'userID')
 
-             if operation == 'getDeviceInfoList':  # 获取设备信息数据
 
-                 return self.get_device_info_list(request_dict, response)
 
-             elif operation == 'deleteDevice':
 
-                 return self.deleteDevice(request_dict, response)
 
-             elif operation == 'resetVod':  # 重置云存
 
-                 return self.resetVod(request, request_dict, response)
 
-             elif operation == 'resetAi':  # 重置AI
 
-                 return self.reset_ai(request, request_dict, response)
 
-             elif operation == 'resetPrimaryUser':
 
-                 return self.resetPrimaryUser(request, request_dict, response)
 
-             elif operation == 'getDeviceTypeList':
 
-                 return self.getDeviceTypeList(request_dict, response)
 
-             elif operation == 'deleteDeviceType':
 
-                 return self.deleteDeviceType(request_dict, response)
 
-             elif operation == 'getAppDeviceTypeList':  # 获取app设备类型数据
 
-                 return self.get_app_device_type_list(request_dict, response)
 
-             elif operation == 'getAppBundleIdList':  # 获取app包id数据
 
-                 return self.get_app_bundle_id_list(response)
 
-             elif operation == 'editAppDeviceType':  # 编辑app设备类型数据
 
-                 return self.edit_app_device_type(request_dict, response)
 
-             elif operation == 'deleteAppDeviceType':  # 删除app设备类型数据
 
-                 return self.delete_app_device_type(request_dict, response)
 
-             elif operation == 'getAppBundle':  # 获取app版本包
 
-                 return self.get_app_bundle(response)
 
-             elif operation == 'resetAll':  # 重置设备主用户/云存/AI
 
-                 return self.reset_all(request, request_dict, response)
 
-             else:
 
-                 return response.json(444, 'operation')
 
-     @classmethod
 
-     def get_app_bundle(cls, response):
 
-         app_bundle_qs = AppBundle.objects.all().values('id', 'app_bundle_id')
 
-         if not app_bundle_qs.exists():
 
-             return response.json(444)
 
-         try:
 
-             app_bundle_list = []
 
-             for app_bundle in app_bundle_qs:
 
-                 app_bundle_qs.exists()
 
-                 app_bundle_list.append(app_bundle)
 
-             return response.json(0, app_bundle_list)
 
-         except Exception as e:
 
-             return response.json(500, e)
 
-     @staticmethod
 
-     def add_app_device_type(request_dict, response, request):
 
-         # 添加APP设备类型
 
-         app_bundle_name = request_dict.get(
 
-             'appbundleName', '')[
 
-                           1:-1].split(',')  # '[1,2]' -> ['1','2']
 
-         app_bundle_id = request_dict.get(
 
-             'app_bundle_id', '')[
 
-                         1:-1].split(',')  # '[1,2]' -> ['1','2']
 
-         # app_device_type表数据
 
-         model = request_dict.get('model', None)
 
-         type = request_dict.get('type', None)
 
-         # device_name_language表数据
 
-         lang = request_dict.get('lang', None)
 
-         name = request_dict.get('name', None)
 
-         sort = request_dict.get('sort', None)
 
-         # 上传图标
 
-         file = request.FILES.get('iconFile', None)
 
-         fileName = file.name
 
-         if not all([model, type, lang, name, sort]):
 
-             return response.json(444)
 
-         type = int(type)
 
-         try:
 
-             with transaction.atomic():
 
-                 # 判断包是否存在,并创建
 
-                 new_bundle_list = []
 
-                 for bundle_name in app_bundle_name:
 
-                     if not bundle_name == '':
 
-                         app_bundle_name_qs = AppBundle.objects.filter(app_bundle_id=bundle_name).values('id')
 
-                         if not app_bundle_name_qs.exists():
 
-                             app_bundle_name_qs.create(app_bundle_id=bundle_name)
 
-                         app_bundle_qs = AppBundle.objects.filter(app_bundle_id=bundle_name).values('id')
 
-                         id = app_bundle_qs[0]['id']
 
-                         new_bundle_list.append(id)
 
-                 for app_id in app_bundle_id:
 
-                     if not app_id == '':
 
-                         app_bundle_qs = AppBundle.objects.filter(id=app_id).values('id')
 
-                         if not app_bundle_qs.exists():
 
-                             AppBundle.objects.create(app_bundle_id=app_bundle_name, id=app_id)
 
-                 # 判断数据是否存在,是否上传
 
-                 # app_device_type_qs = AppDeviceType.objects.filter(type=type).values()
 
-                 # if app_device_type_qs.exists():
 
-                 #     return response.json(174)
 
-                 # S3下文件夹路径+文件名 组成对象key
 
-                 file_key = 'app/device_type_images/{}'.format(fileName)
 
-                 s3 = AmazonS3Util(AWS_ACCESS_KEY_ID[1], AWS_SECRET_ACCESS_KEY[1], AWS_SES_ACCESS_REGION)
 
-                 # 存储桶
 
-                 bucket = 'ansjerfilemanager'
 
-                 # 地址:https://ansjerfilemanager.s3.amazonaws.com/app/device_type_images/camera_c190.png
 
-                 s3.upload_file_obj(bucket, file_key, file,
 
-                                    {'ContentType': file.content_type, 'ACL': 'public-read'})
 
-                 response_url = 'https://ansjerfilemanager.s3.amazonaws.com/app/device_type_images/' + format(fileName)
 
-                 app_device_type_qs = AppDeviceType.objects.create(model=model, type=type, icon=response_url)
 
-                 DeviceNameLanguage.objects.create(lang=lang, name=name, sort=sort,
 
-                                                   app_device_type_id=app_device_type_qs.id)
 
-                 # 关联包
 
-                 for app_id in app_bundle_id:
 
-                     if app_id == '':
 
-                         for app_id in new_bundle_list:
 
-                             app_bundle_qs = AppBundle.objects.filter(id=app_id).values('id')
 
-                             app_bundle_qs = app_bundle_qs[0]['id']
 
-                             app_device_type_qs.appbundle_set.add(app_bundle_qs)
 
-                         return response.json(0)
 
-                     app_bundle_qs = AppBundle.objects.filter(id=app_id).values('id')
 
-                     app_bundle_qs = app_bundle_qs[0]['id']
 
-                     app_device_type_qs.appbundle_set.add(app_bundle_qs)
 
-                 return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     @staticmethod
 
-     def get_device_info_list(request_dict, response):
 
-         pageNo = request_dict.get('pageNo', None)
 
-         pageSize = request_dict.get('pageSize', None)
 
-         UID = request_dict.get('UID', None)
 
-         serialNumber = request_dict.get('serialNumber', None)
 
-         NickName = request_dict.get('NickName', None)
 
-         username = request_dict.get('username', None)
 
-         version = request_dict.get('version', None)
 
-         if not all([pageNo, pageSize]):
 
-             return response.json(444)
 
-         page = int(pageNo)
 
-         line = int(pageSize)
 
-         try:
 
-             if any([UID, serialNumber, NickName, username, version]):  # 条件查询
 
-                 if UID:
 
-                     device_info_qs = Device_Info.objects.filter(UID__icontains=UID)
 
-                 if serialNumber:
 
-                     device_info_qs = Device_Info.objects.filter(serial_number__icontains=serialNumber)
 
-                 if NickName:
 
-                     device_info_qs = Device_Info.objects.filter(NickName__icontains=NickName)
 
-                 if username:
 
-                     device_info_qs = Device_Info.objects.filter(Q(userID__username__icontains=username) |
 
-                                                                 Q(userID__userEmail__icontains=username) |
 
-                                                                 Q(userID__phone__icontains=username))
 
-                 if version:
 
-                     uid_list = UidSetModel.objects.filter(version__icontains=version).values_list('uid', flat=True)
 
-                     device_info_qs = Device_Info.objects.filter(UID__in=uid_list)
 
-                 total = device_info_qs.count()
 
-                 if not total:
 
-                     return response.json(0, {'list': {}, 'total': 0})
 
-                 device_info_qs = device_info_qs[(page - 1) * line:page * line]
 
-             else:  # 查询全部
 
-                 total = Device_Info.objects.filter().count()
 
-                 device_info_qs = Device_Info.objects.filter()[(page - 1) * line:page * line]
 
-                 if not device_info_qs.exists():
 
-                     return response.json(0, {'list': {}, 'total': 0})
 
-             device_info_list = CommonService.qs_to_dict(device_info_qs)
 
-             for k, v in enumerate(device_info_list["datas"]):
 
-                 for device_info in device_info_qs:
 
-                     if v['pk'] == device_info.id:
 
-                         # 设备的用户名和主用户
 
-                         username = ModelService.get_user_name(device_info_list["datas"][k]['fields']['userID'])
 
-                         device_info_list["datas"][k]['fields']['username'] = username
 
-                         device_info_list["datas"][k]['fields']['vodPrimaryMaster'] = \
 
-                             device_info_list["datas"][k]['fields']['vodPrimaryMaster']
 
-                         # 是否支持移动侦测
 
-                         iSNotification = '开' if device_info_list["datas"][k]['fields']['iSNotification'] == 1 else '关'
 
-                         device_info_list["datas"][k]['fields']['iSNotification'] = iSNotification
 
-                         # 设备类型,是否支持Alexa和ip
 
-                         type = device_info_list["datas"][k]['fields']['Type']
 
-                         device_type_qs = DeviceTypeModel.objects.filter(type=type).values('name')
 
-                         if device_type_qs.exists():
 
-                             device_info_list["datas"][k]['fields']['Type'] = device_type_qs[0]['name']
 
-                         uid_set_qs = UidSetModel.objects.filter(
 
-                             uid=device_info_list["datas"][k]['fields']['UID']).values('is_alexa', 'ip', 'version',
 
-                                                                                       'is_ai', 'is_human', 'cloud_vod')
 
-                         if uid_set_qs.exists():
 
-                             isAlexa = '是' if uid_set_qs[0]['is_alexa'] else '否'
 
-                             isHuman = '是' if uid_set_qs[0]['is_human'] else '否'
 
-                             if uid_set_qs[0]['cloud_vod'] == 2:
 
-                                 cloud_vod = '不支持'
 
-                             elif uid_set_qs[0]['cloud_vod'] == 1:
 
-                                 cloud_vod = '开启'
 
-                             else:
 
-                                 cloud_vod = '关闭'
 
-                             if uid_set_qs[0]['is_ai'] == 2:
 
-                                 isAI = '不支持'
 
-                             elif uid_set_qs[0]['is_ai'] == 1:
 
-                                 isAI = '开启'
 
-                             else:
 
-                                 isAI = '关闭'
 
-                             device_info_list["datas"][k]['fields']['isHuman'] = isHuman
 
-                             device_info_list["datas"][k]['fields']['isAI'] = isAI
 
-                             device_info_list["datas"][k]['fields']['isAlexa'] = isAlexa
 
-                             device_info_list["datas"][k]['fields']['cloudVod'] = cloud_vod
 
-                             device_info_list["datas"][k]['fields']['ip'] = uid_set_qs[0]['ip']
 
-                             device_info_list["datas"][k]['fields']['version'] = uid_set_qs[0]['version']
 
-             return response.json(0, {'list': device_info_list, 'total': total})
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     # 根据id删除设备
 
-     def deleteDevice(self, request_dict, response):
 
-         deviceID = request_dict.get('deviceID', None)
 
-         userID = request_dict.get('userID', None)
 
-         uid = request_dict.get('uid', None)
 
-         if not all([deviceID, userID, uid]):
 
-             return response.json(444)
 
-         try:
 
-             with transaction.atomic():
 
-                 Device_Info.objects.filter(id=deviceID).delete()
 
-                 # 删除推送消息
 
-                 for val in range(1, 8):
 
-                     EquipmentInfoService.get_equipment_info_model('', val). \
 
-                         filter(device_user_id=userID, device_uid=uid).delete()
 
-             return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     # 重置设备主用户
 
-     def resetPrimaryUser(self, request, request_dict, response):
 
-         uid = request_dict.get('uid', None)
 
-         if not uid:
 
-             return response.json(404)
 
-         try:
 
-             # 记录操作日志
 
-             ip = CommonService.get_ip_address(request)
 
-             content = json.loads(json.dumps(request_dict))
 
-             log = {
 
-                 'ip': ip,
 
-                 'user_id': 2,
 
-                 'status': 200,
 
-                 'time': int(time.time()),
 
-                 'url': 'deviceManagement/resetPrimaryUser',
 
-                 'content': json.dumps(content),
 
-                 'operation': '{}重置设备主用户'.format(uid),
 
-             }
 
-             LogModel.objects.create(**log)
 
-             Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
 
-             return response.json(0)
 
-         except Exception as e:
 
-             return response.json(500, repr(e))
 
-     # 重置设备云存
 
-     def resetVod(self, request, request_dict, response):
 
-         uid = request_dict.get('uid', None)
 
-         if not uid:
 
-             return response.json(444)
 
-         try:
 
-             # 记录操作日志
 
-             ip = CommonService.get_ip_address(request)
 
-             content = json.loads(json.dumps(request_dict))
 
-             log = {
 
-                 'ip': ip,
 
-                 'user_id': 2,
 
-                 'status': 200,
 
-                 'time': int(time.time()),
 
-                 'url': 'deviceManagement/resetVod',
 
-                 'content': json.dumps(content),
 
-                 'operation': '{}重置云存'.format(uid),
 
-             }
 
-             with transaction.atomic():
 
-                 LogModel.objects.create(**log)
 
-                 # 删除和更新设备云存相关数据
 
-                 UID_Bucket.objects.filter(uid=uid).delete()
 
-                 Unused_Uid_Meal.objects.filter(uid=uid).delete()
 
-                 Order_Model.objects.filter(UID=uid, order_type=0).delete()
 
-                 StsCrdModel.objects.filter(uid=uid).delete()
 
-                 VodHlsModel.objects.filter(uid=uid).delete()
 
-                 # 删除vod_hls分表数据
 
-                 split_vod_hls_obj = SplitVodHlsObject()
 
-                 split_vod_hls_obj.del_vod_hls_data(uid=uid)
 
-                 ExperienceContextModel.objects.filter(uid=uid).delete()
 
-                 Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
 
-             return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     @staticmethod
 
-     def reset_ai(request, request_dict, response):
 
-         uid = request_dict.get('uid', None)
 
-         if not uid:
 
-             return response.json(444)
 
-         try:
 
-             # 记录操作日志
 
-             ip = CommonService.get_ip_address(request)
 
-             content = json.loads(json.dumps(request_dict))
 
-             log = {
 
-                 'ip': ip,
 
-                 'user_id': 2,
 
-                 'status': 200,
 
-                 'time': int(time.time()),
 
-                 'url': 'deviceManagement/resetAi',
 
-                 'content': json.dumps(content),
 
-                 'operation': '{}重置AI'.format(uid),
 
-             }
 
-             with transaction.atomic():
 
-                 LogModel.objects.create(**log)
 
-                 # 删除和更新设备AI相关数据
 
-                 ExperienceAiModel.objects.filter(uid=uid).delete()
 
-                 AiService.objects.filter(uid=uid).delete()
 
-             return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     # 获取设备类型数据
 
-     def getDeviceTypeList(self, request_dict, response):
 
-         name = request_dict.get('name', None)
 
-         pageNo = request_dict.get('pageNo', None)
 
-         pageSize = request_dict.get('pageSize', None)
 
-         if not all([pageNo, pageSize]):
 
-             return response.json(444)
 
-         page = int(pageNo)
 
-         line = int(pageSize)
 
-         try:
 
-             if name:
 
-                 device_type_qs = DeviceTypeModel.objects.filter(name__contains=name).values()
 
-                 total = len(device_type_qs)
 
-             else:
 
-                 device_type_qs = DeviceTypeModel.objects.filter().values()[(page - 1) * line:page * line]
 
-                 total = DeviceTypeModel.objects.filter().count()
 
-             if not device_type_qs.exists():
 
-                 return response.json(173)
 
-             device_type_list = []
 
-             for device_type in device_type_qs:
 
-                 auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
 
-                 bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'ansjer-static-resources')
 
-                 icon = device_type['icon']
 
-                 url = 'device_type/' + icon
 
-                 device_type['icon'] = bucket.sign_url('GET', url, 3600)
 
-                 device_type_list.append(device_type)
 
-             return response.json(0, {'list': device_type_list, 'total': total})
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     # 删除设备类型
 
-     def deleteDeviceType(self, request_dict, response):
 
-         deviceTypeID = request_dict.get('deviceTypeID', None)
 
-         if not deviceTypeID:
 
-             return response.json(444)
 
-         try:
 
-             DeviceTypeModel.objects.filter(id=deviceTypeID).delete()
 
-             return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     # 添加设备类型
 
-     def addDeviceType(self, request, request_dict, response):
 
-         iconFile = request.FILES.get('iconFile', None)
 
-         name = request_dict.get('name', None)
 
-         model = request_dict.get('model', None)
 
-         type = request_dict.get('type', None)
 
-         ptz_type = request_dict.get('ptz_type', None)
 
-         if not all([iconFile, name, model, type, ptz_type]):
 
-             return response.json(444)
 
-         try:
 
-             model = int(model)
 
-             ptz_type = int(ptz_type)
 
-             icon = iconFile.name
 
-             now_time = int(time.time())
 
-             # 上传文件到阿里云OSS
 
-             auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
 
-             bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'ansjer-static-resources')
 
-             key = 'device_type/' + icon  # 图片文件存放于 device_type 目录下
 
-             # https://oss.console.aliyun.com/bucket/oss-cn-shenzhen/ansjer-static-resources/object?path=device_type%2F
 
-             bucket.put_object(key=key, data=iconFile)
 
-             DeviceTypeModel.objects.create(name=name, model=model, type=type, ptz_type=ptz_type, icon=icon,
 
-                                            add_time=now_time, update_time=now_time)
 
-             return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     @staticmethod
 
-     def del_device_data(request_dict, response):
 
-         uidList = request_dict.get('uidList', None)
 
-         delDataOptions = request_dict.get('delDataOptions', None)
 
-         serialNumberList = request_dict.get('serialNumberList', None)
 
-         if not all([uidList or serialNumberList, delDataOptions]):
 
-             return response.json(444)
 
-         try:
 
-             with transaction.atomic():
 
-                 if uidList:
 
-                     #  uid
 
-                     uidList = uidList.splitlines()  # 按行('\r', '\r\n', \n')切割字符串返回列表
 
-                 else:
 
-                     #  序列号
 
-                     serialNumberList = serialNumberList.splitlines()  # 按行('\r', '\r\n', \n')切割字符串返回列表
 
-                     serial_number_list = []
 
-                     for serial_number in serialNumberList:
 
-                         serial_number_list.append(serial_number[0:6])
 
-                     uid_company_serial_qs = UIDCompanySerialModel.objects.filter(
 
-                         company_serial__serial_number__in=serial_number_list).values('uid__uid')
 
-                     uidList = [item[key] for item in uid_company_serial_qs for key in item]
 
-                     # 解绑uid数据,重置序列号状态
 
-                     UIDModel.objects.filter(uid__in=uidList).update(status=0)
 
-                     UIDCompanySerialModel.objects.filter(uid__uid__in=uidList).delete()
 
-                     CompanySerialModel.objects.filter(serial_number__in=serial_number_list).update(status=1)
 
-                 # 根据删除项删除相关数据
 
-                 if '设备信息数据' in delDataOptions:
 
-                     Device_Info.objects.filter(UID__in=uidList).delete()
 
-                 if '设备配置数据' in delDataOptions:
 
-                     UidSetModel.objects.filter(uid__in=uidList).delete()
 
-                 if '设备推送数据' in delDataOptions:
 
-                     Equipment_Info.objects.filter(devUid__in=uidList).delete()
 
-                 if '设备AP信息数据' in delDataOptions:
 
-                     UidUserModel.objects.filter(UID__in=uidList).delete()
 
-                 if '设备AI数据' in delDataOptions:
 
-                     ExperienceAiModel.objects.filter(uid__in=uidList).delete()
 
-                     Order_Model.objects.filter(UID__in=uidList, order_type=1).delete()
 
-                 if '设备云存数据' in delDataOptions:
 
-                     UID_Bucket.objects.filter(uid__in=uidList).delete()
 
-                     StsCrdModel.objects.filter(uid__in=uidList).delete()
 
-                     VodHlsModel.objects.filter(uid__in=uidList).delete()
 
-                     # 删除vod_hls分表数据
 
-                     split_vod_hls_obj = SplitVodHlsObject()
 
-                     split_vod_hls_obj.del_vod_hls_data(uid__in=uidList)
 
-                     Unused_Uid_Meal.objects.filter(uid__in=uidList).delete()
 
-                     ExperienceContextModel.objects.filter(uid__in=uidList).delete()
 
-                     Order_Model.objects.filter(UID__in=uidList, order_type=0).delete()
 
-                     Device_Info.objects.filter(UID__in=uidList).update(vodPrimaryUserID='', vodPrimaryMaster='')
 
-                 # 序列号加入重置状态redis列表
 
-                 if serialNumberList is not None:
 
-                     redis_obj = RedisObject()
 
-                     for serial in serial_number_list:
 
-                         redis_obj.rpush(UNUSED_SERIAL_REDIS_LIST, serial)
 
-             return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     def get_device_icon(self, request_dict, response):
 
-         lang = request_dict.get('lang', 'en')
 
-         app_bundle_id = request_dict.get('appBundleId', None)
 
-         version_number = request_dict.get('versionNumber', None)
 
-         if not all([lang, app_bundle_id, version_number]):
 
-             return response.json(444)
 
-         if lang != 'cn' and lang != 'cn_tw':
 
-             lang = 'en'
 
-         if version_number >= '2.6.2.1':  # 判断是否低于2.6.2.1版本
 
-             return self.newAppVersion(response, app_bundle_id, lang, version_number)  # 获取2.6.2.1及以上版本设备信息图标
 
-         else:
 
-             version_number_qs = AppVersionNumber.objects.filter(app_bundle__app_bundle_id=app_bundle_id,
 
-                                                                 version_number=version_number)
 
-             if not version_number_qs.exists():
 
-                 version_number_qs = AppVersionNumber.objects.filter(app_bundle__app_bundle_id=app_bundle_id)
 
-                 if not version_number_qs.exists():
 
-                     return response.json(173)
 
-                 version_qs = version_number_qs.values('version_number')
 
-                 test_list = [item[key] for item in version_qs for key in item]  # 判断该版本最靠进已有版本号
 
-                 if version_number > test_list[-1] or version_number < test_list[0]:
 
-                     version_number_qs = version_number_qs.filter().values('id').order_by('id')
 
-                     total_list = [item[key] for item in version_number_qs for key in item]
 
-                     version_number_id = total_list[-1]
 
-                 else:
 
-                     pos = bisect_left(test_list, version_number)
 
-                     if pos == 0:
 
-                         return test_list[0]
 
-                     if pos == len(test_list):
 
-                         return test_list[-1]
 
-                     before = test_list[pos - 1]
 
-                     version_number_qs = AppVersionNumber.objects.filter(version_number=before).values('id')
 
-                     version_number_id = version_number_qs[0]['id']
 
-             else:
 
-                 version_number_qs = AppVersionNumber.objects.filter(version_number=version_number).values('id')
 
-                 version_number_id = version_number_qs[0]['id']
 
-             try:
 
-                 app_bundle_qs = AppBundle.objects.filter(app_bundle_id=app_bundle_id,
 
-                                                          app_device_type__devicenamelanguage__lang=lang,
 
-                                                          app_device_type__app_version_number_id=version_number_id). \
 
-                     annotate(
 
-                     model=F('app_device_type__model'), type=F('app_device_type__type'), icon=F('app_device_type__icon'),
 
-                     name=F('app_device_type__devicenamelanguage__name'),
 
-                     sort=F('app_device_type__devicenamelanguage__sort'),
 
-                     app_version_number_id=F('app_device_type__app_version_number_id')).values('model', 'type', 'icon',
 
-                                                                                               'name', 'sort',
 
-                                                                                               'app_device_type__app_version_number_id')
 
-                 dvr_list = [app_bundle for app_bundle in app_bundle_qs if app_bundle['model'] == 1]
 
-                 ipc_list = [app_bundle for app_bundle in app_bundle_qs if app_bundle['model'] == 2]
 
-                 print(dvr_list, ipc_list)
 
-                 res = {
 
-                     'deviceDvr': sorted(dvr_list, key=operator.itemgetter('sort')),
 
-                     'deviceIpc': sorted(ipc_list, key=operator.itemgetter('sort')),
 
-                 }
 
-                 return response.json(0, res)
 
-             except Exception as e:
 
-                 print(e)
 
-                 return response.json(500, repr(e))
 
-     def newAppVersion(self, response, app_bundle_id, lang, version_number):
 
-         version_number_qs = AppVersionNumber.objects.filter(app_bundle__app_bundle_id=app_bundle_id).values(
 
-             'version_number')  # 获取包
 
-         if not version_number_qs.exists():
 
-             return response.json(173)
 
-         # 获取版本号
 
-         try:
 
-             app_bundle_list = []
 
-             version_qs = version_number_qs.filter(version_number=version_number).values('version_number')  # 判断版本是否存在
 
-             if version_qs.exists():
 
-                 version_number = version_qs[0]['version_number']
 
-             else:
 
-                 all_version_number_qs = version_number_qs.values('version_number')  # 输入版本号不存在,则获取全部版本号
 
-                 test_list = [item[key] for item in all_version_number_qs for key in item]
 
-                 if version_number > test_list[-1] or version_number < test_list[0]:  # 判断该版本最靠进已有版本号
 
-                     version_qs = version_number_qs.filter().values('version_number').order_by('version_number')
 
-                     total_list = [item[key] for item in version_qs for key in item]
 
-                     version_number = total_list[-1]
 
-                 else:
 
-                     pos = bisect_left(test_list, version_number)
 
-                     if pos == 0:
 
-                         return test_list[0]
 
-                     if pos == len(test_list):
 
-                         return test_list[-1]
 
-                     before = test_list[pos - 1]
 
-                     version_qs = AppVersionNumber.objects.filter(version_number=before).values('version_number')
 
-                     version_number = version_qs[0]['version_number']
 
-             all_version_list = [item[key] for item in version_number_qs for key in item]
 
-             index = all_version_list.index(version_number)  # 获取版本号的索引
 
-             if app_bundle_id == 'com.ansjer.zccloud' or app_bundle_id == 'com.ansjer.zccloud_a':  # 判断App包
 
-                 version_number_qs = version_number_qs.values('version_number')[0:index + 1]
 
-             else:
 
-                 version_number_qs = version_number_qs.values('version_number')[1:index + 1]
 
-             for version_number in version_number_qs:  # 获取版本号对应的设备信息图标
 
-                 version_number = version_number['version_number']
 
-                 version_number_qs = AppVersionNumber.objects.filter(version_number=version_number,
 
-                                                                     app_bundle__app_bundle_id=app_bundle_id).values(
 
-                     'id')
 
-                 version_number_id = version_number_qs[0]['id']
 
-                 app_bundle_qs = AppBundle.objects.filter(app_bundle_id=app_bundle_id,
 
-                                                          app_device_type__devicenamelanguage__lang=lang,
 
-                                                          app_device_type__app_version_number_id=version_number_id). \
 
-                     annotate(
 
-                     model=F('app_device_type__model'), type=F('app_device_type__type'), icon=F('app_device_type__icon'),
 
-                     name=F('app_device_type__devicenamelanguage__name'),
 
-                     sort=F('app_device_type__devicenamelanguage__sort'),
 
-                     app_version_number_id=F('app_device_type__app_version_number_id')).values('model', 'type', 'icon',
 
-                                                                                               'name', 'sort',
 
-                                                                                               'app_device_type__app_version_number_id')
 
-                 for app_bundle in app_bundle_qs:
 
-                     app_bundle_list.append({
 
-                         'model': app_bundle['model'],
 
-                         'type': app_bundle['type'],
 
-                         'icon': app_bundle['icon'],
 
-                         'name': app_bundle['name'],
 
-                         'sort': app_bundle['sort'],
 
-                         'app_device_type__app_version_number_id': app_bundle['app_device_type__app_version_number_id'],
 
-                     })
 
-             dvr_list = [app_bundle for app_bundle in app_bundle_list if app_bundle['model'] == 1]
 
-             ipc_list = [app_bundle for app_bundle in app_bundle_list if app_bundle['model'] == 2]
 
-             print(dvr_list, ipc_list)
 
-             res = {
 
-                 'deviceDvr': sorted(dvr_list, key=operator.itemgetter('sort')),
 
-                 'deviceIpc': sorted(ipc_list, key=operator.itemgetter('sort')),
 
-             }
 
-             return response.json(0, res)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     @staticmethod
 
-     def get_app_device_type_list(request_dict, response):
 
-         app_bundle_id = request_dict.get('app_bundle_id', None)
 
-         lang = request_dict.get('lang', 'cn')
 
-         model = request_dict.get('model', None)
 
-         type = request_dict.get('type', None)
 
-         name = request_dict.get('name', None)
 
-         pageNo = request_dict.get('pageNo', None)
 
-         pageSize = request_dict.get('pageSize', None)
 
-         if not all([pageNo, pageSize]):
 
-             return response.json(444)
 
-         page = int(pageNo)
 
-         line = int(pageSize)
 
-         try:
 
-             if not app_bundle_id:
 
-                 app_bundle_id = 'com.ansjer.zccloud'
 
-             app_bundle_qs = AppBundle.objects.filter(app_bundle_id=app_bundle_id)
 
-             if lang:
 
-                 app_bundle_qs = app_bundle_qs.filter(app_device_type__devicenamelanguage__lang=lang)
 
-             app_bundle_qs = app_bundle_qs.annotate(
 
-                 model=F('app_device_type__model'), type=F('app_device_type__type'), icon=F('app_device_type__icon'),
 
-                 lang=F('app_device_type__devicenamelanguage__lang'),
 
-                 name=F('app_device_type__devicenamelanguage__name'),
 
-                 sort=F('app_device_type__devicenamelanguage__sort')).values('id', 'app_device_type__id', 'model',
 
-                                                                             'type', 'icon',
 
-                                                                             'app_device_type__devicenamelanguage__id',
 
-                                                                             'lang', 'name', 'sort').order_by(
 
-                 'app_device_type__devicenamelanguage__sort')
 
-             if not app_bundle_qs.exists():
 
-                 return response.json(0)
 
-             app_bundle_qs = app_bundle_qs.all()
 
-             if name:
 
-                 app_bundle_qs = app_bundle_qs.filter(name=name)
 
-             if model:
 
-                 app_bundle_qs = app_bundle_qs.filter(model=model)
 
-             if type:
 
-                 app_bundle_qs = app_bundle_qs.filter(type=type)
 
-             total = app_bundle_qs.count()
 
-             app_bundle_qs = app_bundle_qs[(page - 1) * line:page * line]
 
-             app_device_type_list = [app_bundle for app_bundle in app_bundle_qs]
 
-             return response.json(0, {'list': app_device_type_list, 'total': total})
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     @staticmethod
 
-     def get_app_bundle_id_list(response):
 
-         try:
 
-             app_info_qs = App_Info.objects.filter().values('id', 'appBundleId', 'appName')
 
-             appBundleIdList = list(app_info_qs)
 
-             return response.json(0, {'list': appBundleIdList})
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     @staticmethod
 
-     def edit_app_device_type(request_dict, response):
 
-         # app_device_type表数据
 
-         app_device_type_id = request_dict.get('app_device_type__id', None)
 
-         model = request_dict.get('model', None)
 
-         type = request_dict.get('type', None)
 
-         icon = request_dict.get('icon', None)
 
-         # device_name_language表数据
 
-         device_name_language_id = request_dict.get('app_device_type__devicenamelanguage__id', None)
 
-         lang = request_dict.get('lang', None)
 
-         name = request_dict.get('name', None)
 
-         sort = request_dict.get('sort', None)
 
-         if not all([app_device_type_id, model, type, icon, device_name_language_id, lang, name, sort]):
 
-             return response.json(444)
 
-         try:
 
-             with transaction.atomic():
 
-                 AppDeviceType.objects.filter(id=app_device_type_id).update(model=model, type=type, icon=icon)
 
-                 DeviceNameLanguage.objects.filter(id=device_name_language_id).update(lang=lang, name=name, sort=sort)
 
-             return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     @staticmethod
 
-     def delete_app_device_type(request_dict, response):
 
-         app_bundle_id = request_dict.get('appBundleId', None)
 
-         app_device_type_id = request_dict.get('appDeviceTypeId', None)
 
-         if not all([app_bundle_id, app_device_type_id]):
 
-             return response.json(444)
 
-         try:
 
-             app_bundle_qs = AppBundle.objects.get(id=app_bundle_id)
 
-             app_device_type_qs = AppDeviceType.objects.filter(id=app_device_type_id)
 
-             app_bundle_qs.app_device_type.remove(*app_device_type_qs)
 
-             return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
-     @staticmethod
 
-     def reset_all(request, request_dict, response):
 
-         uid = request_dict.get('uid', None)
 
-         if not uid:
 
-             return response.json(444)
 
-         try:
 
-             # 记录操作日志
 
-             ip = CommonService.get_ip_address(request)
 
-             content = json.loads(json.dumps(request_dict))
 
-             log = {
 
-                 'ip': ip,
 
-                 'user_id': 2,
 
-                 'status': 200,
 
-                 'time': int(time.time()),
 
-                 'url': 'deviceManagement/resetAll',
 
-                 'content': json.dumps(content),
 
-                 'operation': '{}重置所有'.format(uid),
 
-             }
 
-             with transaction.atomic():
 
-                 LogModel.objects.create(**log)
 
-                 # 删除主用户
 
-                 Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
 
-                 # 删除云存
 
-                 UID_Bucket.objects.filter(uid=uid).delete()
 
-                 Unused_Uid_Meal.objects.filter(uid=uid).delete()
 
-                 Order_Model.objects.filter(UID=uid, order_type=0).delete()
 
-                 StsCrdModel.objects.filter(uid=uid).delete()
 
-                 VodHlsModel.objects.filter(uid=uid).delete()
 
-                 # 删除vod_hls分表数据
 
-                 split_vod_hls_obj = SplitVodHlsObject()
 
-                 split_vod_hls_obj.del_vod_hls_data(uid=uid)
 
-                 ExperienceContextModel.objects.filter(uid=uid).delete()
 
-                 # 删除AI
 
-                 ExperienceAiModel.objects.filter(uid=uid).delete()
 
-                 AiService.objects.filter(uid=uid).delete()
 
-                 return response.json(0)
 
-         except Exception as e:
 
-             print(e)
 
-             return response.json(500, repr(e))
 
 
  |