123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434 |
- import os
- import simplejson as json
- import time
- from django.utils import timezone
- from django.utils.decorators import method_decorator
- from django.views.decorators.csrf import csrf_exempt
- from django.views.generic.base import View
- from Ansjer.config import BASE_DIR, SERVER_DOMAIN
- from Model.models import Equipment_Version, EquipmentVersionLimitModel
- from Object.RedisObject import RedisObject
- from Object.ResponseObject import ResponseObject
- from Object.TokenObject import TokenObject
- from Object.UrlTokenObject import UrlTokenObject
- from Service.CommonService import CommonService
- from Service.ModelService import ModelService
- from django.db.models import Q
- class EquipmentOTA(View):
- @method_decorator(csrf_exempt)
- def dispatch(self, *args, **kwargs):
- return super(EquipmentOTA, self).dispatch(*args, **kwargs)
- def get(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- return self.validation(request_dict=request.GET)
- def post(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- return self.validation(request_dict=request.POST)
- def validation(self, request_dict, *args, **kwargs):
- token = request_dict.get('token', None)
- response = ResponseObject()
- if token is None:
- return response.json(309)
- tko = TokenObject(token)
- response.lang = tko.lang
- if tko.code != 0:
- return response.json(tko.code)
- userID = tko.userID
- if userID is None:
- return response.json(309)
- operation = request_dict.get('operation', None)
- if operation == 'delete':
- return self.delete(request_dict, userID, response)
- elif operation == 'query':
- return self.query(request_dict, userID, response)
- elif operation == 'find':
- return self.find(request_dict, userID, response)
- elif operation == 'update':
- return self.update(request_dict, userID, response)
- else:
- return response.json(444, 'operation')
- def delete(self, request_dict, userID, response):
- eid = request_dict.get('eid', None)
- version = request_dict.get('version', None)
- if not eid or not version:
- return response.json(444, 'eid or version')
- own_perm = ModelService.check_perm(userID=userID, permID=230)
- if not own_perm:
- return response.json(404)
- equipment_version = Equipment_Version.objects.filter(eid=eid, version=version)
- if not equipment_version.exists():
- return response.json(173)
- try:
- # 删除文件和相应数据
- file_path = equipment_version[0].filePath
- file_path = os.path.join(BASE_DIR, file_path).replace('\\', '/')
- os.remove(file_path)
- equipment_version.delete()
- except Exception as e:
- return response.json(176, repr(e))
- else:
- return response.json(0)
- def query(self, request_dict, userID, response):
- page = int(request_dict.get('page', None))
- line = int(request_dict.get('line', None))
- lang = request_dict.get('lang', None)
- if page is None or line is None:
- return response.json(444, 'page,line')
- own_permission = ModelService.check_perm(userID=userID, permID=240)
- if own_permission is not True:
- return response.json(404)
- if lang is None:
- qs = Equipment_Version.objects.all().order_by('-data_joined')
- else:
- qs = Equipment_Version.objects.filter(lang=lang).order_by('-data_joined')
- if qs.exists():
- count = qs.count()
- res = qs[(page - 1) * line:page * line]
- send_json = CommonService.qs_to_dict(res)
- send_json['count'] = count
- return response.json(0, send_json)
- return response.json(0)
- def find(self, request_dict, userID, response):
- page = int(request_dict.get('page', None))
- line = int(request_dict.get('line', None))
- content = request_dict.get('content', None)
- if page is None or line is None or content is None:
- return response.json(444)
- own_permission = ModelService.check_perm(userID=userID, permID=250)
- if own_permission is not True:
- return response.json(404)
- content = json.loads(content)
- search_kwargs = CommonService.get_kwargs(data=content)
- qs = Equipment_Version.objects.filter(**search_kwargs)
- if not qs.exists():
- return response.json(0, [])
- count = qs.count()
- res = qs[(page - 1) * line:page * line]
- send_json = CommonService.qs_to_dict(res)
- send_json['count'] = count
- return response.json(0, send_json)
- def update(self, request_dict, userID, response):
- eid = request_dict.get('eid', None)
- if eid is None:
- return response.json(444, 'eid')
- own_permission = ModelService.check_perm(userID=userID, permID=230)
- if own_permission is not True:
- return response.json(404)
- ev = Equipment_Version.objects.filter(eid=eid)
- if not ev.exists():
- return response.json(10, 'ev none')
- status = request_dict.get('status', None)
- try:
- update_time = timezone.localtime(timezone.now())
- ev.update(status=status, update_time=update_time)
- except Exception as e:
- print(repr(e))
- else:
- return response.json(0, {'update_time': str(update_time)})
- class EquipmentVersionView(View):
- def get(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- operation = kwargs.get('operation')
- return self.validation(request.GET, operation, request)
- def post(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- operation = kwargs.get('operation')
- return self.validation(request.POST, operation, request)
- def validation(self, request_dict, operation, request):
- response = ResponseObject()
- if operation is None:
- return response.json(444, 'error path')
- elif operation == 'checkVer':
- return self.do_check_value(request_dict, response)
- elif operation == 'checkIpcVer':
- return self.check_ipc_ver(request_dict, response)
- token = request_dict.get('token', None)
- # 设备主键uid
- tko = TokenObject(token)
- response.lang = tko.lang
- if tko.code != 0:
- return response.json(tko.code)
- userID = tko.userID
- own_perm = ModelService.check_perm(userID, 240)
- if own_perm is False:
- return response.json(404)
- if operation == 'query':
- return self.do_query(request_dict, response)
- if operation == 'update':
- return self.do_update(request_dict, response, request)
- if operation == 'filter':
- return self.do_filter(request_dict, response)
- else:
- return response.json(444, 'error path')
- def do_update(self, request_dict, response, request):
- code = request_dict.get('code', None)
- status = request_dict.get('status', None)
- lang = request_dict.get('lang', None)
- max_ver = request_dict.get('max_ver', None)
- file_s = request.FILES.get('file', None)
- paths = 'static/versions/image'
- if not os.path.exists(paths):
- os.makedirs(paths) # makedirs 创建文件时如果路径不存在会创建这个路径
- # print ('该文件不存在')
- else:
- print('该文件存在')
- ev = Equipment_Version.objects.filter(code=code, lang=lang)
- if file_s is None:
- rv_path = 'static/versions/image/' + code + '.png'
- img = SERVER_DOMAIN + 'sysfile/' + rv_path
- else:
- rv_path = 'static/versions/image/' + code + '.png'
- try:
- as_path = os.path.join(BASE_DIR, rv_path)
- if os.path.exists(as_path):
- os.remove(as_path)
- with open(as_path, 'wb+') as destination:
- for chunk in file_s.chunks():
- destination.write(chunk)
- except Exception as e:
- print(repr(e))
- else:
- img = SERVER_DOMAIN + 'sysfile/' + rv_path
- if code is not None:
- if ev.exists():
- try:
- update_time = timezone.localtime(timezone.now())
- update_dict = {
- 'status': status,
- 'img': img,
- 'update_time': update_time
- }
- if max_ver:
- update_dict['max_ver'] = max_ver
- ev.update(**update_dict)
- except Exception as e:
- return response.json(404, repr(e))
- else:
- return response.json(0, {'update_time': str(update_time), 'img': img})
- else:
- return response.json(173)
- else:
- return response.json(444, 'code')
- def do_check_ver(self, request_dict, response):
- code = request_dict.get('code', None)
- ov = request_dict.get('ov', None)
- uid = request_dict.get('uid', '')
- if not code:
- return response.json(444, 'code')
- eqs = Equipment_Version.objects.filter(code=uid, status=1, lang='en').order_by('-data_joined')
- if not eqs.exclude():
- eqs = Equipment_Version.objects.filter(code=code, status=1, lang='en').order_by('-data_joined')
- if not eqs.exists():
- return response.json(900)
- if ov is not None:
- # 判断大小
- if ov > eqs[0].softwareVersion:
- return response.json(0, {'softwareVersion': ov})
- file_path = eqs[0].filePath
- if file_path.find('static/Upgrade/') != -1:
- path = file_path.replace('static/Upgrade/', '').replace('\\', '/')
- url = SERVER_DOMAIN + 'OTA/downloads/' + path + '?time=' + str(time.time())
- elif file_path.find('static/otapack') != -1:
- url = SERVER_DOMAIN + 'OTA/downloadsPack/' + file_path + '?time=' + str(time.time())
- # url = SERVER_DOMAIN + 'dl/otaPack/' + file_path + '?time=' + str(time.time())
- else:
- return response.json(900, '2')
- res = {
- "url": url,
- "fileSize": eqs[0].fileSize,
- "Description": eqs[0].Description,
- "softwareVersion": eqs[0].softwareVersion
- }
- return response.json(0, res)
- # 修改加密的路径
- def do_check_value(self, request_dict, response):
- code = request_dict.get('code', None)
- ov = request_dict.get('ov', None)
- uid = request_dict.get('uid', '')
- if not code:
- return response.json(444, 'code')
- eqs = Equipment_Version.objects.filter(code=uid, status=1, lang='en').order_by('-data_joined')
- # 限制NVR版本升级
- if code == '681008800304A0001100000300001Z' and ov == '1.7.2':
- return response.json(900)
- if not eqs.exclude():
- eqs = Equipment_Version.objects.filter(code=code, status=1, lang='en').order_by('-data_joined')
- if not eqs.exists():
- return response.json(900)
- if ov is not None:
- # 判断大小
- if ov > eqs[0].softwareVersion:
- return response.json(0, {'softwareVersion': ov})
- equipment = eqs[0]
- redisObject = RedisObject()
- key = 'limit_{eid}'.format(eid=equipment.eid)
- evl_qs = redisObject.get_data(key=key)
- if evl_qs:
- evl_qs = json.loads(evl_qs)
- else:
- evl_qs = EquipmentVersionLimitModel.objects.filter(equipment_version_id=equipment.eid, status=1).values()
- if evl_qs.exists():
- redisObject.set_data(key=key, val=json.dumps(list(evl_qs.values())), expire=600)
- if evl_qs and len(evl_qs) > 0:
- evl = evl_qs[0]
- if evl['type'] == 1: # uid限制
- uids = json.loads(evl['content'])
- if not uids.__contains__(uid):
- return response.json(902)
- file_path = eqs[0].filePath
- url = SERVER_DOMAIN
- if file_path.find('static/Upgrade/') != -1:
- # 创建url的token
- tko = UrlTokenObject()
- path = tko.generate(data={'Url': "ansjer/" + CommonService.RandomStr(6) + "/" + file_path})
- url += 'OTA/downloads/' + path
- elif file_path.find('static/otapack') != -1:
- file_path = file_path
- param_url = "ansjer/" + CommonService.RandomStr(6) + "/" + file_path
- data = {'Url': param_url, 'user_id': '', 'uid': uid, 'serial_number': '', 'old_version': ov,
- 'new_version': eqs[0].softwareVersion, 'mci': 'NVR'}
- dvr_ota_key = 'ASJ:SERVER:VERSION:{}'.format(uid)
- dvr_ota_value = json.dumps(data)
- expire = 600
- redisObject.set_data(dvr_ota_key, dvr_ota_value, expire)
- # 创建url的token
- tko = UrlTokenObject()
- file_path = tko.generate(data={'uid': uid})
- url += 'dlotapack/' + file_path
- res = {
- "url": url,
- "fileSize": eqs[0].fileSize,
- "Description": eqs[0].Description,
- "softwareVersion": eqs[0].softwareVersion
- }
- print(url)
- return response.json(0, res)
- @staticmethod
- def check_ipc_ver(request_dict, response):
- """
- NVR获取IPC升级链接
- @param request_dict: 请求参数
- @request_dict lang: 语言
- @request_dict code: 网关设备id
- @request_dict now_ver: 设备当前版本
- @param response: 响应对象
- @return: response
- """
- lang = request_dict.get('lang', None)
- code = request_dict.get('code', None)
- now_ver = request_dict.get('now_ver', None)
- if not all([code, lang, now_ver]):
- return response.json(902, {'param': 'code, lang, ver'})
- equipment_version_qs = Equipment_Version.objects.filter(code=code, status=1, lang=lang).order_by('-data_joined')
- if not equipment_version_qs.exists():
- return response.json(902)
- equipment = equipment_version_qs[0]
- file_path = equipment.filePath
- max_ver = equipment.max_ver
- if now_ver > max_ver:
- return response.json(902)
- url = SERVER_DOMAIN + 'OTA/downloadsPack/' + file_path
- file_name = file_path[file_path.rindex('/')+1:]
- res = {
- "url": url,
- "fileName": file_name,
- "fileSize": equipment.fileSize,
- "Description": equipment.Description,
- "softwareVersion": equipment.softwareVersion
- }
- return response.json(0, res)
- def do_query(self, request_dict, response):
- mci = request_dict.get('mci', None)
- page = request_dict.get('page', None)
- line = request_dict.get('line', None)
- code = request_dict.get('code', None)
- if not page or not line:
- return response.json(444, 'page,line')
- else:
- page = int(page)
- line = int(line)
- cv_qs = Equipment_Version.objects
- if mci is not None:
- cv_qs = cv_qs.filter(mci=mci)
- if code is not None:
- cv_qs = cv_qs.filter(code__contains=code)
- cv_qs = cv_qs.order_by('code').values_list('code', flat=True).distinct()
- print(cv_qs)
- count = cv_qs.count()
- cv_qs = list(cv_qs[(page - 1) * line:page * line])
- # return response.json(0, cv_qs)
- ev_qs = Equipment_Version.objects.filter(code__in=list(cv_qs)).values()
- ev_list = CommonService.qs_to_list(ev_qs)
- datas = {}
- # 组装数据
- for ev in ev_list:
- for code in cv_qs:
- if code not in datas.keys():
- datas[code] = []
- if code == ev['code']:
- datas[code].append(ev)
- res = {
- 'datas': datas,
- 'count': count
- }
- return response.json(0, res)
- def do_filter(self, request_dict, response):
- mci = request_dict.get('mci', None)
- page = request_dict.get('page', None)
- line = request_dict.get('line', None)
- code = request_dict.get('code', None)
- lang = request_dict.get('lang', None)
- if not page or not line:
- return response.json(444, 'page,line')
- else:
- page = int(page)
- line = int(line)
- ev_qs = Equipment_Version.objects
- if mci:
- ev_qs = ev_qs.filter(mci=mci)
- if code:
- ev_qs = ev_qs.filter(code__contains=code)
- if lang:
- if lang == 'cn' or lang == 'zh-Hans':
- ev_qs = ev_qs.filter(Q(lang='cn') | Q(lang='zh-Hans'))
- else:
- ev_qs = ev_qs.filter(lang=lang)
- count = ev_qs.count()
- ev_qs = ev_qs[(page - 1) * line:page * line].values()
- ev_ls = CommonService.qs_to_list(ev_qs)
- res = {
- 'datas': ev_ls,
- 'count': count
- }
- return response.json(0, res)
|