| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200 | #!/usr/bin/env python3# -*- coding: utf-8 -*-"""@Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.@AUTHOR: ASJRD018@NAME: AnsjerFormal@software: PyCharm@DATE: 2018/12/5 9:30@Version: python3.6@MODIFY DECORD:ansjer dev@file: CloudVod.py@Contact: chanjunkai@163.com"""import jsonimport mathimport timeimport urllibfrom Object.AliPayObject import AliPayObjectimport oss2import paypalrestsdkfrom aliyunsdkcore import clientfrom aliyunsdksts.request.v20150401 import AssumeRoleRequestfrom django.http import JsonResponse, HttpResponseRedirect, HttpResponsefrom django.utils.decorators import method_decoratorfrom django.views.decorators.csrf import csrf_exemptfrom django.views.generic.base import Viewfrom Ansjer.config import OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET, OSS_ROLE_ARN, SERVER_DOMAIN, PAYPAL_CRD, \    SERVER_DOMAIN_SSLfrom Model.models import Device_Info, Order_Model, Store_Meal, VodHlsModel, OssCrdModel, UID_Bucketfrom Object.ResponseObject import ResponseObjectfrom Object.TokenObject import TokenObjectfrom Object.UidTokenObject import UidTokenObjectfrom Service.CommonService import CommonServicefrom Service.ModelService import ModelService'''# 获取设备推送hls流 证书http://192.168.136.40:8077/cloudVod/getSts?uidToken=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1aWQiOiJGVFNMTDhITTQzN1ozOFdVMTExQSIsImNoYW5uZWwiOiI0In0.HO-PzoRwhQ4CFNkjthqOitf48c-XOvHjtNGCeUmBe9g# 获取存储的播放文件列表#修改状态http://192.168.136.40:8077/cloudVod/status?token=local&uid=xxx&channel=4&status=1# 回调vodhttp://192.168.136.40:8077/cloudVod/storeplaylist?uidToken=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1aWQiOiJGVFNMTDhITTQzN1ozOFdVMTExQSIsImNoYW5uZWwiOiI0In0.HO-PzoRwhQ4CFNkjthqOitf48c-XOvHjtNGCeUmBe9g&time=1234567891=============================# 生成订单http://test.dvema.com/cloudVod/createOrder?token=test&uid=xxx&channel=4&rank=1# 修改设备云存状态http://test.dvema.com/cloudVod/status?uid=xxx&channel=4&token=test&status=1# 获取指定设备云存关联信息http://test.dvema.com/cloudVod/details?token=test&uid=xxxx# 获取回放列表http://test.dvema.com/cloudVod/getHlsList?uid=xxxx&channel=4&token=test&daytime=20181210012设备端http://test.dvema.com/cloudVod/getSts?uidToken=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJjaGFubmVsIjoiNCIsInVpZCI6IkZUU0xMOEhNNDM3WjM4V1UxMTFBIn0.wkrwYvIYf5qEukOSTxALSAgSqop-gNBdEvSwScOgYB8# 支付宝支付http://192.168.136.40:8077/cloudVod/aliPayCreateOrder?token=local&channel=2&rank=1&uid=OOBDSU9547NTRSMF111A'''# 设备信息添加class CloudVodView(View):    @method_decorator(csrf_exempt)    def dispatch(self, *args, **kwargs):        return super(CloudVodView, self).dispatch(*args, **kwargs)    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):        response = ResponseObject()        # operation => cloudVod/path        if operation is None:            return response.json(444, 'error path')        if operation == 'getSts':            # 移动侦测获取设备sts证书            ip = CommonService.get_ip_address(request)            return self.do_getSts(request_dict, ip, response)        # 付款完成        elif operation == 'payExecute':            return self.do_paypal_execute(request_dict, response)        elif operation == 'storeplaylist':            return self.do_store_palylist(request_dict, response)        elif operation == 'payOK':            return self.do_pay_ok()        elif operation == 'payError':            return self.do_pay_error()        elif operation == 'aliPayCallback':            return self.do_ali_pay_callback(request)        elif operation == 'dopaypalcallback':            return self.do_pay_by_paypal_callback(request)        elif operation == 'doalicallback':            return self.do_pay_by_ali_callback(request)        else:            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            if operation == 'createOrder':                return self.do_create_order(request_dict, userID, response)            elif operation == 'status':                return self.do_change_status(request_dict, userID, response)            elif operation == 'details':                return self.do_get_details(request_dict, response)            elif operation == 'filterVod':                return self.do_filter_playlist(request_dict, userID, response)            elif operation == 'findVod':                return self.do_find_playlist(request_dict, userID, response)            # 支付宝支付            elif operation == 'aliPayCreateOrder':                return self.do_pay_by_ali(request_dict, userID, response)            elif operation == 'orderStatus':                return self.do_pay_status(request_dict, userID)            elif operation == 'createPayOrder':                return self.do_create_pay_order(request_dict, userID, response)            else:                return response.json(414)    def do_ali_pay_callback(self, request):        response = ResponseObject()        data = request.POST.dict()        signature = data["sign"]        data.pop('sign')        orderID = data['out_trade_no']        order_qs = Order_Model.objects.filter(orderID=orderID, status=0)        print(order_qs)        if not order_qs.exists():            return response.json(404)        print(json.dumps(data))        print(signature)        # verify        aliPayObj = AliPayObject()        alipay = aliPayObj.conf()        success = alipay.verify(data, signature)        if success and data["trade_status"] in ("TRADE_SUCCESS", "TRADE_FINISHED"):            print("trade succeed")            nowTime = int(time.time())            order_list = order_qs.values("UID", "rank__id", "channel")            rank_id = order_list[0]['rank__id']            print(rank_id)            UID = order_list[0]['UID']            channel = order_list[0]['channel']            order_qs.update(status=1, updTime=nowTime)            smqs = Store_Meal.objects.filter(id=rank_id).values("day", "bucket_id", "bucket__storeDay")            bucketId = smqs[0]['bucket_id']            if not smqs.exists():                return response.json(0, '套餐已删除')            addTime = int(smqs[0]["day"]) * 24 * 3600            ubqs = UID_Bucket.objects.filter(uid=UID, channel=channel). \                values("bucket_id", "endTime", "bucket__storeDay")            nowTime = int(time.time())            if ubqs.exists():                # 判断是否过期了                if nowTime > ubqs[0]['endTime']:                    ubqs.update(endTime=nowTime + addTime)                else:                    # 同一个bucket续费                    if bucketId == ubqs[0]['bucket_id']:                        ubqs.update(endTime=ubqs[0]['endTime'] + addTime)                    else:                        if ubqs[0]['bucket__storeDay'] > smqs[0]['bucket__storeDay']:                            return response.json(10, '不可选低级别套餐')                        else:                            # 升级                            origin_storeDay = int(ubqs[0]['bucket__storeDay'])                            upgrade_storeDay = int(smqs[0]['bucket__storeDay'])                            ctcTime = ubqs[0]['endTime'] - nowTime                            multiple = math.ceil(upgrade_storeDay / origin_storeDay)                            ubqs.update(endTime=ctcTime / multiple + addTime + ubqs[0]['endTime'], bucket_id=bucketId)                            # 付款成功把oss token删除                            OssCrdModel.objects.filter(uid=UID, channel=channel).delete()            # 新增模式            else:                print('create')                UID_Bucket.objects.create(uid=UID, channel=channel,                                          bucket_id=bucketId, endTime=nowTime + addTime)            red_url = "{SERVER_DOMAIN}cloudVod/payOK".format(SERVER_DOMAIN=SERVER_DOMAIN)            return HttpResponseRedirect(red_url)        return response.json(0, signature)    def do_pay_by_ali(self, request_dict, userID, response):        uid = request_dict.get('uid', None)        rank = request_dict.get('rank', None)        channel = request_dict.get('channel', None)        qs = Device_Info.objects.filter(userID_id=userID, UID=uid, isShare=False)        if not qs.exists():            return response.json(12)        if not channel or not rank:            return response.json(444, 'channel,rank')        smqs = Store_Meal.objects.filter(id=rank). \            values("currency", "price", "content", "day", "bucket__storeDay", "bucket__region", "type")        if not smqs.exists():            # 套餐不存在            return response.json(173)        if smqs[0]['type'] != 1:            return response.json(10, '不支持支付宝支付')        currency = smqs[0]['currency']        price = smqs[0]['price']        content = smqs[0]['content']        day = smqs[0]['day']        nowTime = int(time.time())        ubqs = UID_Bucket.objects.filter(uid=uid, channel=channel, endTime__gte=nowTime). \            values("bucket__storeDay", "bucket__region")        if ubqs.exists():            if ubqs[0]['bucket__region'] != smqs[0]['bucket__region']:                return response.json(712)  # 区域不一致            elif ubqs[0]['bucket__storeDay'] != smqs[0]['bucket__storeDay']:                return response.json(713)  # 不可更改套餐            # 续费流程        nowTime = int(time.time())        # 新增流程        orderID = CommonService.createOrderID()        try:            aliPayObj = AliPayObject()            alipay = aliPayObj.conf()            order_string = alipay.api_alipay_trade_wap_pay(                out_trade_no=orderID,                total_amount=price,                subject="测试哟",                return_url="{SERVER_DOMAIN_SSL}cloudVod/payOK".format(SERVER_DOMAIN_SSL=SERVER_DOMAIN_SSL),                notify_url="{SERVER_DOMAIN_SSL}cloudVod/aliPayCallback".format(SERVER_DOMAIN_SSL=SERVER_DOMAIN_SSL)                # return_url="http://192.168.136.40/cloudVod/payOK",                # notify_url="http://192.168.136.40/cloudVod/aliPayCallback"            )        except Exception as e:            print(repr(e))            return response.json(10, repr(e))        if order_string:            redirectUrl = aliPayObj.alipay_prefix + order_string            Order_Model.objects.create(orderID=orderID, UID=uid, channel=channel, userID_id=userID, desc=content,                                       price=price, currency=currency, addTime=nowTime, updTime=nowTime,                                       endTime=nowTime + int(day) * 3600 * 24, rank_id=rank, paypal='', payType=1)            return JsonResponse(status=200,                                data={'result_code': 0, 'reason': 'success',                                      'result': {"redirectUrl": redirectUrl, "orderID": orderID},                                      'error_code': 0})        else:            return response.json(10, '生成订单错误')    def do_get_details(self, request_dict, response):        uid = request_dict.get('uid', None)        dvqs = Device_Info.objects.filter(UID=uid, isShare=False)        if not dvqs.exists():            return response.json(12)        ubqs = UID_Bucket.objects.filter(uid=uid). \            values('bucket__content', 'status', 'channel', 'endTime', 'uid')        res = []        if ubqs.exists():            res = list(ubqs)        return response.json(0, res)    def do_pay_error(self):        response = HttpResponse()        response.content = '''<!DOCTYPE html><html><head>	<!--浏览器不缓存-->	<meta http-equiv="Pragma" content="no-cache">	<meta http-equiv="Cache-Control" content="no-cache">	<meta http-equiv="Expires" content="0">	<!--utf-8-->    <meta http-equiv="content-type" content="text/html;charset=utf-8">    <!-- viewport的<meta>标签,这个标签可以修改在大部分的移动设备上面的显示,为了确保适当的绘制和触屏缩放。-->    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <link rel="shortcut icon" href="https://test.dvema.com/web/images/favicon.ico" type="image/x-icon"  charset="utf-8"/>      <title>Trading particulars</title>    <style>    	.title_head{    		height: 50px;    		border-radius: 5px;    		background-color: #c3c6c7;     		text-align: center;    		line-height: 50px;    	}    	.content{    		text-align: center;    		margin-top: 50px;    		font-size: 20px;    		color : #ec7648    	}    	.content_img{    		width: 60px;     		height: 60px;    	}    	.bottom{    		 margin-bottom: 10px;     		 margin-top: 250px;     		 color : #ec7648    	}    	.bottom_div{    		border: 1px solid #ec7648;     		line-height: 38px;     		text-align: center;     		width: 100px;     		height: 38px;    		border-radius: 5px;    	}    	    	.bottom_div:hover{    		background-color: #dde4e2;    	}    </style></head><body>	<div class="title_head">Trading particulars</div>    <div class="content">    	<p >    		<img src="https://test.dvema.com/web/images/failed.jpg" class="content_img">    		<br />    		Payment failure    	</p>    </div>    <center class="bottom">    	<div class="bottom_div" onclick="payOKButton()">     	 Finish    	</div>    </center>    <script> 	    // 点击付款成功按钮    function payOKButton() {        // 复杂数据        console.log('success')        window.webkit.messageHandlers.jsCallOC.postMessage({"status": 0});    }	</script></body> </html>                '''        return response    def do_pay_ok(self):        response = HttpResponse()        response.content = '''<!DOCTYPE html><html><head>	<!--浏览器不缓存-->	<meta http-equiv="Pragma" content="no-cache">	<meta http-equiv="Cache-Control" content="no-cache">	<meta http-equiv="Expires" content="0">	<!--utf-8-->    <meta http-equiv="content-type" content="text/html;charset=utf-8">    <!-- viewport的<meta>标签,这个标签可以修改在大部分的移动设备上面的显示,为了确保适当的绘制和触屏缩放。-->    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <link rel="shortcut icon" href="https://test.dvema.com/web/images/favicon.ico" type="image/x-icon"  charset="utf-8"/>      <title>Trading particulars</title>    <style>    	.title_head{    		height: 50px;    		border-radius: 5px;    		background-color: #c3c6c7;     		text-align: center;    		line-height: 50px;    	}    	.content{    		text-align: center;    		margin-top: 50px;    		font-size: 20px;    		color : green    	}    	.content_img{    		width: 60px;     		height: 60px;    	}    	.bottom{    		 margin-bottom: 10px;     		 margin-top: 250px;     		 color : green    	}    	.bottom_div{    		border: 1px solid green;     		line-height: 38px;     		text-align: center;     		width: 100px;     		height: 38px;    		border-radius: 5px;    	}    	    	.bottom_div:hover{    		background-color: #dde4e2;    	}    </style></head><body>	<div class="title_head">Trading particulars</div>    <div class="content">    	<p >    		<img src="https://test.dvema.com/web/images/timg.jpg" class="content_img">    		<br />    		Successful payment    	</p>    </div>    <center class="bottom">    	<div class="bottom_div" onclick="payOKButton()">     	 Finish    	</div>    </center>    <script> 	    // 点击付款成功按钮    function payOKButton() {        // 复杂数据        console.log('success')        window.webkit.messageHandlers.jsCallOC.postMessage({"status": 1});    }	</script></body> </html>        '''        return response    def do_pay_by_ali_callback(self, request):        response = ResponseObject()        data = request.POST.dict()        signature = data["sign"]        data.pop('sign')        orderID = data['out_trade_no']        order_qs = Order_Model.objects.filter(orderID=orderID, status=0)        print(order_qs)        if not order_qs.exists():            return response.json(404)        print(json.dumps(data))        print(signature)        # verify        aliPayObj = AliPayObject()        alipay = aliPayObj.conf()        success = alipay.verify(data, signature)        if success and data["trade_status"] in ("TRADE_SUCCESS", "TRADE_FINISHED"):            print("trade succeed")            nowTime = int(time.time())            order_list = order_qs.values("UID", "commodity_code", "channel")            UID = order_list[0]['UID']            channel = order_list[0]['channel']            commodity_code = order_list[0]['commodity_code']            order_qs.update(status=1, updTime=nowTime)            smqs = Store_Meal.objects.filter(commodity_code=commodity_code).\                values("day", "bucket_id", "bucket__storeDay")            bucketId = smqs[0]['bucket_id']            if not smqs.exists():                return response.json(0, '套餐已删除')            addTime = int(smqs[0]["day"]) * 24 * 3600            ubqs = UID_Bucket.objects.filter(uid=UID, channel=channel). \                values("bucket_id", "endTime", "bucket__storeDay")            nowTime = int(time.time())            if ubqs.exists():                ubqs_count = ubqs.count()                ubq = ubqs[ubqs_count - 1, ubqs_count]                new_starTime = ubq['endTime'] + 1                UID_Bucket.objects.create(uid=UID, channel=channel, bucket_id=bucketId, endTime=new_starTime + addTime)            else:                UID_Bucket.objects.create(uid=UID, channel=channel, bucket_id=bucketId, endTime=nowTime + addTime)            red_url = "{SERVER_DOMAIN}cloudVod/payOK".format(SERVER_DOMAIN=SERVER_DOMAIN)            return HttpResponseRedirect(red_url)        return response.json(0, signature)    def do_pay_by_paypal_callback(self, request_dict, response):        paymentId = request_dict.get('paymentId', None)        PayerID = request_dict.get('PayerID', None)        orderID = request_dict.get('orderID', None)        if not paymentId or not PayerID or not orderID:            red_url = "{SERVER_DOMAIN}cloudVod/payError".format(SERVER_DOMAIN=SERVER_DOMAIN)            return HttpResponseRedirect(red_url)        paypalrestsdk.configure(PAYPAL_CRD)        # ID of the payment. This ID is provided when creating payment.        payment = paypalrestsdk.Payment.find(paymentId)        payres = payment.execute({"payer_id": PayerID})        print(payres)        if not payres:            red_url = "{SERVER_DOMAIN}cloudVod/payError".format(SERVER_DOMAIN=SERVER_DOMAIN)            return HttpResponseRedirect(red_url)        print("Payment execute successfully")        order_qs = Order_Model.objects.filter(orderID=orderID)        nowTime = int(time.time())        order_qs.update(status=1, updTime=nowTime)        order_list = order_qs.values("UID", "channel", "commodity_code")        UID = order_list[0]['UID']        channel = order_list[0]['channel']        commodity_code = order_list[0]['commodity_code']        smqs = Store_Meal.objects.filter(commodity_code=commodity_code).\            values("day", "bucket_id", "bucket__storeDay")        bucketId = smqs[0]['bucket_id']        if not smqs.exists():            return response.json(0, '套餐已删除')        addTime = int(smqs[0]["day"]) * 24 * 3600        # ##        ubqs = UID_Bucket.objects.filter(uid=UID, channel=channel, endTime__gte=nowTime). \            values("bucket__storeDay", "bucket__region", "endTime")        if ubqs.exists():            ubqs_count = ubqs.count()            ubq = ubqs[ubqs_count - 1, ubqs_count]            new_starTime = ubq['endTime'] + 1            UID_Bucket.objects.create(uid=UID, channel=channel, bucket_id=bucketId, endTime=new_starTime + addTime)        else:            UID_Bucket.objects.create(uid=UID, channel=channel, bucket_id=bucketId, endTime=nowTime + addTime)            # return response.json(0)        red_url = "{SERVER_DOMAIN}cloudVod/payOK".format(SERVER_DOMAIN=SERVER_DOMAIN)        return HttpResponseRedirect(red_url)    def do_create_pay_order(self, request_dict, userID, response):        uid = request_dict.get('uid', None)        channel = request_dict.get('channel', None)        commodity_code = request_dict.get('commodity_code', None)        pay_type = int(request_dict.get('pay_type', None))        dv_qs = Device_Info.objects.filter(userID_id=userID, UID=uid, isShare=False, isExist=1)        if not dv_qs.exists():            return response.json(12)        smqs = Store_Meal.objects.filter(commodity_code=commodity_code, type=pay_type). \            values('currency', 'price', 'content', 'day', 'commodity_type', 'title', 'content')        if not smqs.exists():            return response.json(10, '套餐不存在')        currency = smqs[0]['currency']        price = smqs[0]['price']        content = smqs[0]['content']        day = smqs[0]['day']        commodity_type = smqs[0]['commodity_type']        # ubqs = UID_Bucket.objects.filter(uid=uid, channel=channel, endTime__gte=nowTime). \        #     values("bucket__storeDay", "bucket__region", "endTime")        # if ubqs.exists():        #     ubqs_count = ubqs.count()        #     ubq = ubqs[ubqs_count - 1, ubqs_count]        #     new_starTime = ubq['endTime'] + 1        nowTime = int(time.time())        orderID = CommonService.createOrderID()        if pay_type == 0:            call_sub_url = "{SERVER_DOMAIN}cloudVod/dopaypalcallback?orderID={orderID}". \                format(SERVER_DOMAIN=SERVER_DOMAIN, orderID=orderID)            # call_sub_url = "http://192.168.136.40:8077/cloudVod/payExecute?orderID={orderID}".format(            #     SERVER_DOMAIN=SERVER_DOMAIN, orderID=orderID)            call_clc_url = "{SERVER_DOMAIN}cloudVod/payError".format(SERVER_DOMAIN=SERVER_DOMAIN)            paypalrestsdk.configure(PAYPAL_CRD)            payment = paypalrestsdk.Payment({                "intent": "sale",                "payer": {"payment_method": "paypal"},                "redirect_urls": {"return_url": call_sub_url, "cancel_url": call_clc_url},                "transactions": [{                    "item_list": {                        "items": [                            {"name": "Cloud video", "sku": "1", "price": price, "currency": "USD", "quantity": 1}]},                    "amount": {"total": price, "currency": currency},                    "description": content                }]})            if payment.create():                print("Payment created successfully")            else:                print(payment.error)                return response.json(10, payment.error)            print(payment)            for link in payment.links:                if link.rel == "approval_url":                    approval_url = str(link.href)                    print("Redirect for approval: %s" % (approval_url))                    Order_Model.objects.create(orderID=orderID, UID=uid, channel=channel, userID_id=userID,                                               desc=content,                                               price=price, currency=currency, addTime=nowTime, updTime=nowTime,                                               endTime=(nowTime + int(day) * 3600 * 24), paypal=approval_url,                                               commodity_code=commodity_code, commodity_type=commodity_type)                    return response.json(0, {"redirectUrl": approval_url, "orderID": orderID})            return response.json(10, 'generate_order_false')        else:            try:                aliPayObj = AliPayObject()                alipay = aliPayObj.conf()                subject = smqs[0]['title'] + smqs[0]['content']                order_string = alipay.api_alipay_trade_wap_pay(                    out_trade_no=orderID,                    total_amount=price,                    subject=subject,                    return_url="{SERVER_DOMAIN_SSL}cloudVod/payOK".format(SERVER_DOMAIN_SSL=SERVER_DOMAIN_SSL),                    notify_url="{SERVER_DOMAIN_SSL}cloudVod/doalicallback".format(SERVER_DOMAIN_SSL=SERVER_DOMAIN_SSL)                    # return_url="http://192.168.136.40/cloudVod/payOK",                    # notify_url="http://192.168.136.40/cloudVod/aliPayCallback"                )            except Exception as e:                print(repr(e))                return response.json(10, repr(e))            else:                if order_string:                    redirectUrl = aliPayObj.alipay_prefix + order_string                    Order_Model.objects.create(orderID=orderID, UID=uid, channel=channel, userID_id=userID,                                               desc=content, price=price, currency=currency, addTime=nowTime,                                               updTime=nowTime, endTime=nowTime + int(day) * 3600 * 24,                                               commodity_code=commodity_code, commodity_type=commodity_type,                                               paypal='', payType=1)                    return JsonResponse(status=200, data={'result_code': 0, 'reason': 'success',                                                          'result': {"redirectUrl": redirectUrl, "orderID": orderID},                                                          'error_code': 0})                else:                    return response.json(10, '生成订单错误')    def do_create_order(self, request_dict, userID, response):        uid = request_dict.get('uid', None)        rank = request_dict.get('rank', None)        channel = request_dict.get('channel', None)        if not uid or not channel or not rank:            return response.json(444, 'channel,rank')        qs = Device_Info.objects.filter(userID_id=userID, UID=uid, isShare=False)        if not qs.exists():            return response.json(12)        smqs = Store_Meal.objects.filter(id=rank). \            values("currency", "price", "content", "day", "bucket__storeDay", "bucket__region", "type")        if not smqs.exists():            return response.json(10, '套餐不存在')        if smqs[0]['type'] != 0:            return response.json(10, '套餐不支持paypal支付')        currency = smqs[0]['currency']        price = smqs[0]['price']        content = smqs[0]['content']        day = smqs[0]['day']        nowTime = int(time.time())        ubqs = UID_Bucket.objects.filter(uid=uid, channel=channel, endTime__gte=nowTime). \            values("bucket__storeDay", "bucket__region")        if ubqs.exists():            if ubqs[0]['bucket__region'] != smqs[0]['bucket__region']:                return response.json(712)  # 区域不一致            # elif ubqs[0]['bucket__storeDay'] > smqs[0]['bucket__storeDay']:            #     return response.json(711)  # 不可降级            elif ubqs[0]['bucket__storeDay'] != smqs[0]['bucket__storeDay']:                return response.json(713)  # 不可更改套餐            # 续费流程        nowTime = int(time.time())        # 判断是否存在未完成订单        # hasOrder = Order_Model.objects.filter(UID=uid, channel=channel, addTime__gte=nowTime - 3600, status=0,        #                                       rank_id=rank, userID_id=userID).values('paypal')        # if hasOrder.exists():        #     approval_url = hasOrder[0]['paypal']        #     return response.json(0, {"redirectUrl": approval_url})        # 新增流程        orderID = CommonService.createOrderID()        call_sub_url = "{SERVER_DOMAIN}cloudVod/payExecute?orderID={orderID}". \            format(SERVER_DOMAIN=SERVER_DOMAIN, orderID=orderID)        # call_sub_url = "http://192.168.136.40:8077/cloudVod/payExecute?orderID={orderID}".format(        #     SERVER_DOMAIN=SERVER_DOMAIN, orderID=orderID)        call_clc_url = "{SERVER_DOMAIN}cloudVod/payError".format(SERVER_DOMAIN=SERVER_DOMAIN)        paypalrestsdk.configure(PAYPAL_CRD)        payment = paypalrestsdk.Payment({            "intent": "sale",            "payer": {"payment_method": "paypal"},            "redirect_urls": {"return_url": call_sub_url, "cancel_url": call_clc_url},            "transactions": [{                "item_list": {                    "items": [{"name": "Cloud video", "sku": "1", "price": price, "currency": "USD", "quantity": 1}]},                "amount": {"total": price, "currency": currency},                "description": content            }]})        if payment.create():            print("Payment created successfully")        else:            print(payment.error)            return response.json(10, payment.error)        print(payment)        for link in payment.links:            if link.rel == "approval_url":                approval_url = str(link.href)                print("Redirect for approval: %s" % (approval_url))                Order_Model.objects.create(orderID=orderID, UID=uid, channel=channel, userID_id=userID, desc=content,                                           price=price, currency=currency, addTime=nowTime, updTime=nowTime,                                           endTime=nowTime + int(day) * 3600 * 24,                                           rank_id=rank,                                           paypal=approval_url)                return response.json(0, {"redirectUrl": approval_url, "orderID": orderID})        return response.json(10, 'generate_order_false')    #  生成设备sts上传授权    def do_getSts(self, request_dict, ip, response):        uidToken = request_dict.get('uidToken', None)        utko = UidTokenObject(uidToken)        if utko.flag is False:            return response.json(444, 'uidToken')        UID = utko.UID        channel = utko.channel        print(channel)        print(UID)        ubqs = UID_Bucket.objects.filter(uid=UID, channel=channel, status=1). \            values('channel', 'bucket__bucket', 'bucket__endpoint', 'bucket__region', 'endTime')        now_time = int(time.time())        if not ubqs.exists():            res = {'code': 404, 'msg': '未购买'}            return HttpResponse(json.dumps(res, ensure_ascii=False), content_type="application/json,charset=utf-8")        elif ubqs[0]['endTime'] < now_time:            res = {'code': 404, 'msg': '过期'}            return HttpResponse(json.dumps(res, ensure_ascii=False), content_type="application/json,charset=utf-8")        oc_qs = OssCrdModel.objects.filter(uid=UID, channel=channel).values("addTime", "data")        if oc_qs.exists():            endTime = int(oc_qs[0]["addTime"]) + 3500            if endTime > now_time:                print(endTime)                print(now_time)                res = json.loads(oc_qs[0]["data"])                return JsonResponse(status=200, data=res)        # 套餐id        storage = '{uid}/vod{channel}/'.format(uid=UID, channel=channel)        bucket_name = ubqs[0]['bucket__bucket']        endpoint = ubqs[0]['bucket__endpoint']        access_key_id = OSS_STS_ACCESS_KEY        access_key_secret = OSS_STS_ACCESS_SECRET        region_id = ubqs[0]['bucket__region']        role_arn = OSS_ROLE_ARN        clt = client.AcsClient(access_key_id, access_key_secret, region_id)        req = AssumeRoleRequest.AssumeRoleRequest()        # 设置返回值格式为JSON。        req.set_accept_format('json')        req.set_RoleArn(role_arn)        req.set_RoleSessionName(UID)        req.set_DurationSeconds(3600)        Resource_access = "acs:oss:*:*:{bucket_name}/{uid_channel}*".format(bucket_name=bucket_name,                                                                            uid_channel=storage)        print(Resource_access)        policys = {            "Version": "1",            "Statement": [                {                    "Action": ["oss:PutObject", "oss:DeleteObject", ],                    "Resource": [Resource_access],                    "Effect": "Allow",                    "Condition": {                        "IpAddress": {"acs:SourceIp": ip}                        # "IpAddress": {"acs:SourceIp": "120.237.157.184"}                        # "IpAddress": {"acs:SourceIp": "*"}                    }                }            ]        }        req.set_Policy(Policy=json.dumps(policys))        body = clt.do_action(req)        # 使用RAM账号的AccessKeyId和AccessKeySecret向STS申请临时token。        token = json.loads(body.decode('utf-8'))        print(token)        res = {            'AccessKeyId': token['Credentials']['AccessKeyId'],            'AccessKeySecret': token['Credentials']['AccessKeySecret'],            'SecurityToken': token['Credentials']['SecurityToken'],            'Expiration': token['Credentials']['Expiration'],            'expire': '3600',            'endpoint': endpoint,            'bucket_name': bucket_name,            'arn': token['AssumedRoleUser']['Arn'],            'code': 0,            'storage': storage,            'endTime': ubqs[0]['endTime'],            'ip': ip}        if oc_qs.exists():            oc_qs.update(data=json.dumps(res), addTime=now_time)        else:            OssCrdModel.objects.create(uid=UID, channel=channel, data=json.dumps(res), addTime=now_time)        return JsonResponse(status=200, data=res)    def do_paypal_execute(self, request_dict, response):        paymentId = request_dict.get('paymentId', None)        PayerID = request_dict.get('PayerID', None)        orderID = request_dict.get('orderID', None)        if not paymentId or not PayerID or not orderID:            red_url = "{SERVER_DOMAIN}cloudVod/payError".format(SERVER_DOMAIN=SERVER_DOMAIN)            return HttpResponseRedirect(red_url)        paypalrestsdk.configure(PAYPAL_CRD)        # ID of the payment. This ID is provided when creating payment.        payment = paypalrestsdk.Payment.find(paymentId)        payres = payment.execute({"payer_id": PayerID})        print(payres)        if not payres:            red_url = "{SERVER_DOMAIN}cloudVod/payError".format(SERVER_DOMAIN=SERVER_DOMAIN)            return HttpResponseRedirect(red_url)        print("Payment execute successfully")        order_qs = Order_Model.objects.filter(orderID=orderID)        nowTime = int(time.time())        order_qs.update(status=1, updTime=nowTime)        order_list = order_qs.values("UID", "rank_id", "channel")        rank_id = order_list[0]['rank_id']        UID = order_list[0]['UID']        channel = order_list[0]['channel']        smqs = Store_Meal.objects.filter(id=rank_id).values("day", "bucket_id", "bucket__storeDay")        bucketId = smqs[0]['bucket_id']        if not smqs.exists():            return response.json(0, '套餐已删除')        addTime = int(smqs[0]["day"]) * 24 * 3600        ubqs = UID_Bucket.objects.filter(uid=UID, channel=channel).values("bucket_id", "endTime", "bucket__storeDay")        nowTime = int(time.time())        if ubqs.exists():            # 判断是否过期了            if nowTime > ubqs[0]['endTime']:                ubqs.update(endTime=nowTime + addTime)            else:                # 同一个bucket续费                if bucketId == ubqs[0]['bucket_id']:                    ubqs.update(endTime=ubqs[0]['endTime'] + addTime)                else:                    if ubqs[0]['bucket__storeDay'] > smqs[0]['bucket__storeDay']:                        return response.json(10, '不可选低级别套餐')                    else:                        # 升级                        origin_storeDay = int(ubqs[0]['bucket__storeDay'])                        upgrade_storeDay = int(smqs[0]['bucket__storeDay'])                        ctcTime = ubqs[0]['endTime'] - nowTime                        multiple = math.ceil(upgrade_storeDay / origin_storeDay)                        ubqs.update(endTime=ctcTime / multiple + addTime + ubqs[0]['endTime'], bucket_id=bucketId)                        # 付款成功把oss token删除                        OssCrdModel.objects.filter(uid=UID, channel=channel).delete()        # 新增模式        else:            print('create')            UID_Bucket.objects.create(uid=UID, channel=channel,                                      bucket_id=bucketId, endTime=nowTime + addTime)            # return response.json(0)        red_url = "{SERVER_DOMAIN}cloudVod/payOK".format(SERVER_DOMAIN=SERVER_DOMAIN)        return HttpResponseRedirect(red_url)    def do_change_status(self, request_dict, userID, response):        uid = request_dict.get('uid', None)        status = request_dict.get('status', None)        channel = request_dict.get('channel', None)        if not uid or not status or not channel:            return response.json(444, 'uid,status,channel')        dvqs = Device_Info.objects.filter(UID=uid, userID_id=userID, isShare=False)        if not dvqs.exists():            return response.json(12)        ubqs = UID_Bucket.objects.filter(channel=channel, uid=uid)        if not ubqs.exists():            return response.json(10, '未购买')        now_time = int(time.time())        if now_time > ubqs[0].endTime:            return response.json(10, '已过期')        ubqs.update(status=status)        if status == 0:            return response.json(0)        utko = UidTokenObject()        utko.generate(data={'uid': uid, 'channel': channel})        uidTkUrl = "{SERVER_DOMAIN}cloudVod/getSts?uidToken={uidToken}". \            format(uidToken=utko.token, SERVER_DOMAIN=SERVER_DOMAIN)        storeHlsUrl = "{SERVER_DOMAIN}cloudVod/storeplaylist?uidToken={uidToken}". \            format(uidToken=utko.token, SERVER_DOMAIN=SERVER_DOMAIN)        return response.json(0, {'uidTkUrl': uidTkUrl, 'storeHlsUrl': storeHlsUrl})    def do_store_palylist(self, request_dict, response):        uidToken = request_dict.get('uidToken', None)        storeTime = request_dict.get('time', None)        sec = request_dict.get('sec', None)        utko = UidTokenObject(uidToken)        if utko.flag is False:            return response.json(444, 'uidToken')        if not uidToken or not storeTime or not sec:            return response.json(444, 'uidToken,time,sec')        UID = utko.UID        channel = utko.channel        print(channel)        print(UID)        nowTime = int(time.time())        if not OssCrdModel.objects.filter(uid=UID, channel=channel).exists():            res = {'code': 404, 'msg': '设备未购买'}            return HttpResponse(json.dumps(res, ensure_ascii=False), content_type="application/json,charset=utf-8")        qs = UID_Bucket.objects.filter(uid=UID, channel=channel, status=1, endTime__gte=nowTime). \            values("channel", "bucket__storeDay", "bucket_id")        if not qs.exists():            res = {'code': 404, 'msg': '设备未购买'}            return HttpResponse(json.dumps(res, ensure_ascii=False), content_type="application/json,charset=utf-8")        storeDay = qs[0]['bucket__storeDay']        bucketID = qs[0]['bucket_id']        endTime = int(storeTime) + storeDay * 86400        VodHlsModel.objects.create(uid=UID, channel=channel, time=storeTime,                                   endTime=endTime, bucket_id=bucketID, sec=sec)        return response.json(0)    def do_filter_playlist(self, request_dict, userID, response):        startTime = int(request_dict.get('startTime', None))        endTime = int(request_dict.get('endTime', None))        uid = request_dict.get('uid', None)        channel = request_dict.get('channel', None)        dvqs = Device_Info.objects.filter(UID=uid, userID_id=userID, isShare=False)        if not dvqs.exists():            return response.json(12)        ubqs = UID_Bucket.objects.filter(uid=uid, channel=channel).values('status')        if not ubqs.exists():            return response.json(10, '设备未购买')        nowTime = int(time.time())        vodqs = VodHlsModel.objects.filter(uid=uid, channel=channel, time__range=(startTime, endTime),                                           endTime__gte=nowTime) \            .values("time", "sec", "bucket__bucket", "bucket__endpoint", "bucket__region")        vod_play_list = []        print(vodqs)        auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)        for vod in vodqs:            bucket_name = vod["bucket__bucket"]            endpoint = vod["bucket__endpoint"]            bucket = oss2.Bucket(auth, endpoint, bucket_name)            m3u8 = '{uid}/vod{channel}/{time}/{time}.m3u8'. \                format(uid=uid, channel=channel, time=vod['time'])            ts = '{uid}/vod{channel}/{time}/ts0.ts'. \                format(uid=uid, channel=channel, time=vod['time'])            url = bucket.sign_url('GET', m3u8, 3600, params={'x-oss-process': 'hls/sign'})            urllst = url.split('?')            url_start = urllib.parse.unquote(urllst[0])            url_end = urllst[1]            vod_play_url = '{url_start}?{url_end}'. \                format(url_start=url_start, url_end=url_end)            thumb = bucket.sign_url('GET', ts, 3600,                                    params={'x-oss-process': 'video/snapshot,t_10000,m_fast,w_300'})            vod_play_list.append({'name': vod['time'], 'sign_url': vod_play_url, 'thumb': thumb, 'sec': vod['sec']})        return response.json(0, vod_play_list)    # backend find play list0    def do_find_playlist(self, request_dict, userID, response):        startTime = int(request_dict.get('startTime', None))        endTime = int(request_dict.get('endTime', None))        UID = request_dict.get('uid', None)        channel = request_dict.get('channel', None)        own_perm = ModelService.check_perm(userID, 20)        if own_perm is False:            return response.json(404)        nowTime = int(time.time())        vodqs = VodHlsModel.objects.filter(uid=UID, channel=channel, time__range=(startTime, endTime),                                           endTime__gte=nowTime) \            .values("time", "sec", "bucket__bucket", "bucket__endpoint", "bucket__region", "id")        vod_play_list = []        print(vodqs)        auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)        for vod in vodqs:            bucket_name = vod["bucket__bucket"]            endpoint = vod["bucket__endpoint"]            bucket = oss2.Bucket(auth, endpoint, bucket_name)            m3u8 = '{uid}/vod{channel}/{time}/{time}.m3u8'. \                format(uid=UID, channel=channel, time=vod['time'])            ts = '{uid}/vod{channel}/{time}/ts0.ts'. \                format(uid=UID, channel=channel, time=vod['time'])            url = bucket.sign_url('GET', m3u8, 3600, params={'x-oss-process': 'hls/sign'})            urllst = url.split('?')            url_start = urllib.parse.unquote(urllst[0])            url_end = urllst[1]            vod_play_url = '{url_start}?{url_end}'. \                format(url_start=url_start, url_end=url_end)            thumb = bucket.sign_url('GET', ts, 3600,                                    params={'x-oss-process': 'video/snapshot,t_1000,m_fast,w_300'})            vod_play_list.append(                {'name': vod['time'], 'sign_url': vod_play_url, 'thumb': thumb, 'sec': vod['sec'], 'id': vod['id']})        return response.json(0, vod_play_list)    def do_pay_status(self, request_dict, userID):        orderID = request_dict.get('orderID', None)        om_qs = Order_Model.objects.filter(userID_id=userID, orderID=orderID).values('status')        response = HttpResponse()        success_pay_content = '''                <!DOCTYPE html>                <html>                <head>                	<!--浏览器不缓存-->                	<meta http-equiv="Pragma" content="no-cache">                	<meta http-equiv="Cache-Control" content="no-cache">                	<meta http-equiv="Expires" content="0">                	<!--utf-8-->                    <meta http-equiv="content-type" content="text/html;charset=utf-8">                    <!-- viewport的<meta>标签,这个标签可以修改在大部分的移动设备上面的显示,为了确保适当的绘制和触屏缩放。-->                    <meta name="viewport" content="width=device-width, initial-scale=1.0">                    <link rel="shortcut icon" href="https://test.dvema.com/web/images/favicon.ico" type="image/x-icon"  charset="utf-8"/>                      <title>Trading particulars</title>                    <style>                    	.title_head{                    		height: 50px;                    		border-radius: 5px;                    		background-color: #c3c6c7;                     		text-align: center;                    		line-height: 50px;                    	}                    	.content{                    		text-align: center;                    		margin-top: 50px;                    		font-size: 20px;                    		color : green                    	}                    	.content_img{                    		width: 60px;                     		height: 60px;                    	}                    	.bottom{                    		 margin-bottom: 10px;                     		 margin-top: 250px;                     		 color : green                    	}                    	.bottom_div{                    		border: 1px solid green;                     		line-height: 38px;                     		text-align: center;                     		width: 100px;                     		height: 38px;                    		border-radius: 5px;                    	}                    	.bottom_div:hover{                    		background-color: #dde4e2;                    	}                    </style>                </head>                <body>                	<div class="title_head">Trading particulars</div>                    <div class="content">                    	<p >                    		<img src="https://test.dvema.com/web/images/timg.jpg" class="content_img">                    		<br />                    		Successful payment                    	</p>                    </div>                    <center class="bottom">                    	<div class="bottom_div" onclick="payOKButton()">                     	 Finish                    	</div>                    </center>                    <script> 	    // 点击付款成功按钮                    function payOKButton() {                        // 复杂数据                        console.log('success')                        window.webkit.messageHandlers.jsCallOC.postMessage({"status": 1});                    }                	</script>                </body>                 </html>                        '''        falil_pay_content = '''        <!DOCTYPE html>        <html>        <head>        	<!--浏览器不缓存-->        	<meta http-equiv="Pragma" content="no-cache">        	<meta http-equiv="Cache-Control" content="no-cache">        	<meta http-equiv="Expires" content="0">        	<!--utf-8-->            <meta http-equiv="content-type" content="text/html;charset=utf-8">            <!-- viewport的<meta>标签,这个标签可以修改在大部分的移动设备上面的显示,为了确保适当的绘制和触屏缩放。-->            <meta name="viewport" content="width=device-width, initial-scale=1.0">            <link rel="shortcut icon" href="https://test.dvema.com/web/images/favicon.ico" type="image/x-icon"  charset="utf-8"/>              <title>Trading particulars</title>            <style>            	.title_head{            		height: 50px;            		border-radius: 5px;            		background-color: #c3c6c7;             		text-align: center;            		line-height: 50px;            	}            	.content{            		text-align: center;            		margin-top: 50px;            		font-size: 20px;            		color : #ec7648            	}            	.content_img{            		width: 60px;             		height: 60px;            	}            	.bottom{            		 margin-bottom: 10px;             		 margin-top: 250px;             		 color : #ec7648            	}            	.bottom_div{            		border: 1px solid #ec7648;             		line-height: 38px;             		text-align: center;             		width: 100px;             		height: 38px;            		border-radius: 5px;            	}            	.bottom_div:hover{            		background-color: #dde4e2;            	}            </style>        </head>        <body>        	<div class="title_head">Trading particulars</div>            <div class="content">            	<p >            		<img src="https://test.dvema.com/web/images/failed.jpg" class="content_img">            		<br />            		Payment failure            	</p>            </div>            <center class="bottom">            	<div class="bottom_div" onclick="payOKButton()">             	 Finish            	</div>            </center>            <script> 	    // 点击付款成功按钮            function payOKButton() {                // 复杂数据                console.log('success')                window.webkit.messageHandlers.jsCallOC.postMessage({"status": 0});            }        	</script>        </body>         </html>                        '''        if om_qs.exists():            if om_qs[0]['status'] == 1:                response.content = success_pay_content                return response            else:                # response.content = falil_pay_content                # return response                # exit()                # 如果未支付则调用查询订单是否支付成功                aliPayObj = AliPayObject()                alipay = aliPayObj.conf()                # check order status                print("now sleep 3s")                # time.sleep(3)                result = alipay.api_alipay_trade_query(out_trade_no=orderID)                if result.get("trade_status", "") == "TRADE_SUCCESS":                    print('paid')                    print("trade succeed")                    order_qs = Order_Model.objects.filter(orderID=orderID, status=0)                    if order_qs.exists():                        nowTime = int(time.time())                        order_list = order_qs.values("UID", "rank__id", "channel")                        rank_id = order_list[0]['rank__id']                        print(rank_id)                        UID = order_list[0]['UID']                        channel = order_list[0]['channel']                        order_qs.update(status=1, updTime=nowTime)                        smqs = Store_Meal.objects.filter(id=rank_id).values("day", "bucket_id", "bucket__storeDay")                        bucketId = smqs[0]['bucket_id']                        if not smqs.exists():                            response.content = falil_pay_content                            return response                        addTime = int(smqs[0]["day"]) * 24 * 3600                        ubqs = UID_Bucket.objects.filter(uid=UID, channel=channel). \                            values("bucket_id", "endTime", "bucket__storeDay")                        nowTime = int(time.time())                        if ubqs.exists():                            # 判断是否过期了                            if nowTime > ubqs[0]['endTime']:                                ubqs.update(endTime=nowTime + addTime)                            else:                                # 同一个bucket续费                                if bucketId == ubqs[0]['bucket_id']:                                    ubqs.update(endTime=ubqs[0]['endTime'] + addTime)                                else:                                    if ubqs[0]['bucket__storeDay'] > smqs[0]['bucket__storeDay']:                                        response.content = falil_pay_content                                        return response                                    else:                                        # 升级                                        origin_storeDay = int(ubqs[0]['bucket__storeDay'])                                        upgrade_storeDay = int(smqs[0]['bucket__storeDay'])                                        ctcTime = ubqs[0]['endTime'] - nowTime                                        multiple = math.ceil(upgrade_storeDay / origin_storeDay)                                        ubqs.update(endTime=ctcTime / multiple + addTime + ubqs[0]['endTime'],                                                    bucket_id=bucketId)                                        # 付款成功把oss token删除                                        OssCrdModel.objects.filter(uid=UID, channel=channel).delete()                        # 新增模式                        else:                            print('create')                            UID_Bucket.objects.create(uid=UID, channel=channel,                                                      bucket_id=bucketId, endTime=nowTime + addTime)                        response.content = success_pay_content                        return response                    else:                        response.content = falil_pay_content                        return response                else:                    print("not paid...")                    response.content = falil_pay_content                    return response        else:            response.content = falil_pay_content            return responsedef deleteVodHls(request):    response = ResponseObject()    i = int(request.GET.get('i', 5))    import time    nowTime = int(time.time())    for i in range(i):        vh_qs = VodHlsModel.objects.filter(time__lte=str(nowTime - 3600 * 24 * 35))[0:10000]        id_list = vh_qs.values_list("id", flat=True)        print(id_list)        VodHlsModel.objects.filter(id__in=list(id_list)).delete()    return response.json(0)
 |