| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398 | import osimport simplejson as jsonimport timefrom django.utils import timezonefrom django.utils.decorators import method_decoratorfrom django.views.decorators.csrf import csrf_exemptfrom django.views.generic.base import Viewfrom Ansjer.config import BASE_DIR, SERVER_DOMAINfrom Model.models import Equipment_Version, EquipmentVersionLimitModel, CountryIPModelfrom Object.RedisObject import RedisObjectfrom Object.ResponseObject import ResponseObjectfrom Object.TokenObject import TokenObjectfrom Object.UrlTokenObject import UrlTokenObjectfrom Service.CommonService import CommonServicefrom Service.ModelService import ModelServicefrom django.db.models import Q'''http://192.168.136.45:8077/equipment/OTA?token=test&operation=query&page=1&line=10http://192.168.136.45:8077/equipment/OTA?token=test&operation=find&page=1&line=10&content={}http://192.168.136.40:8077/equipment/OTA?eid=138001524641441203480138000&token=test&operation=deletehttp://192.168.136.40:8077/equipment/OTA?eid=138001524641441203480138000&token=test&operation=update&status=1https://cdna.artstation.com/p/assets/images/images/004/727/674/large/daniel-dociu-snowcavels.jpg?1485828233&dl=1https://cdna.artstation.com/p/assets/images/images/004/693/910/large/daniel-dociu-smoothsailing.jpg?1485560128&dl=1'''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)        if not eid:            return response.json(444, 'eid')        own_perm = ModelService.check_perm(userID=userID, permID=230)        if not own_perm:            return response.json(404)        ev = Equipment_Version.objects.filter(eid=eid)        if not ev.exists():            return response.json(173)        try:            has_ev = Equipment_Version.objects.filter(filePath=ev[0].filePath)            if has_ev.exists():                pass            else:                filepath = os.path.join(BASE_DIR, ev[0].filePath)                os.remove(filepath)            ev.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))            pass        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)            # return self.do_check_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:                pass            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')        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        if file_path.find('static/Upgrade/') != -1:            path = file_path.replace('static/Upgrade/', '').replace('\\', '/')            # 创建url的token            tko = UrlTokenObject()            path = tko.generate(data={'Url': "ansjer/" + CommonService.RandomStr(6) + "/" + file_path})            url = SERVER_DOMAIN + 'OTA/downloads/' + path        elif file_path.find('static/otapack') != -1:            file_path = file_path            # 创建url的token            tko = UrlTokenObject()            file_path = tko.generate(data={'Url': "ansjer/" + CommonService.RandomStr(6) + "/" + file_path})            url = SERVER_DOMAIN + 'dlotapack/' + file_path        else:            return response.json(900, '2')        # http: // 192.168.136.39:8000 / EquipmentVersion / checkVer?code = 20D20410010        res = {            "url": url,            "fileSize": eqs[0].fileSize,            "Description": eqs[0].Description,            "softwareVersion": eqs[0].softwareVersion        }        print(url)        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)
 |