OrderContrller.py 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. @Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.
  5. @AUTHOR: ASJRD018
  6. @NAME: AnsjerFormal
  7. @software: PyCharm
  8. @DATE: 2018/12/6 10:53
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: OrderContrller.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. import time
  15. from django.utils.decorators import method_decorator
  16. from django.views.decorators.csrf import csrf_exempt
  17. from django.views.generic.base import View
  18. from Object.ResponseObject import ResponseObject
  19. from Object.TokenObject import TokenObject
  20. from Model.models import Order_Model, Device_Info
  21. from Service.CommonService import CommonService
  22. from Service.ModelService import ModelService
  23. '''
  24. # 获取所有设备下单信息
  25. http://192.168.136.40:8077/order/querylist?token=local&page=1&line=10
  26. '''
  27. # 设备信息添加
  28. class OrderView(View):
  29. @method_decorator(csrf_exempt)
  30. def dispatch(self, *args, **kwargs):
  31. return super(OrderView, self).dispatch(*args, **kwargs)
  32. def get(self, request, *args, **kwargs):
  33. request.encoding = 'utf-8'
  34. operation = kwargs.get('operation')
  35. return self.validation(request.GET, request, operation)
  36. def post(self, request, *args, **kwargs):
  37. request.encoding = 'utf-8'
  38. operation = kwargs.get('operation')
  39. return self.validation(request.POST, request, operation)
  40. def validation(self, request_dict, request, operation):
  41. response = ResponseObject()
  42. if operation is None:
  43. return response.json(444, 'error path')
  44. token = request_dict.get('token', None)
  45. # 设备主键uid
  46. tko = TokenObject(token)
  47. response.lang = tko.lang
  48. if tko.code != 0:
  49. return response.json(tko.code)
  50. userID = tko.userID
  51. if operation == 'querylist':
  52. return self.do_querylist(request_dict, userID, response)
  53. elif operation == 'adminDelete':
  54. return self.do_admin_delete(request_dict, userID, response)
  55. elif operation == 'adminQuery':
  56. return self.do_admin_query(request_dict, userID, response)
  57. else:
  58. return response.json(444, 'error path')
  59. def do_querylist(self, request_dict, userID, response):
  60. page = request_dict.get('page', None)
  61. line = request_dict.get('line', None)
  62. did = request_dict.get('did', None)
  63. if not page or not line:
  64. return response.json(444, 'page,line')
  65. page = int(page)
  66. line = int(line)
  67. omqs = Order_Model.objects.filter(userID_id=userID, status=1)
  68. # 筛选指定设备id的订单
  69. if did:
  70. dvqs = Device_Info.objects.filter(id=did).values('UID')
  71. if dvqs.exists():
  72. omqs.filter(UID=dvqs[0]['UID'])
  73. else:
  74. return response.json(0)
  75. if not omqs.exists():
  76. return response.json(10, '订单不存在')
  77. if did:
  78. omqs.order_by()
  79. count = omqs.count()
  80. order_ql = omqs[(page - 1) * line:page * line].values("orderID", "UID", "channel", "desc", "price", "currency",
  81. "addTime",
  82. "updTime", "endTime", "paypal", "rank__day",
  83. "rank__price", "status",
  84. "rank__content", "rank__title", "rank__currency",
  85. "rank_id")
  86. order_list = list(order_ql)
  87. data = []
  88. nowTime = int(time.time())
  89. # 这里需要进行优化
  90. uid_list = []
  91. for od in order_list:
  92. uid_list.append(od['UID'])
  93. didqs = Device_Info.objects.filter(userID_id=userID, UID__in=uid_list).values('id', 'UID', 'Type')
  94. for d in order_list:
  95. if d['status'] == 0:
  96. if d['addTime'] + 3600 < nowTime:
  97. d['status'] = 3
  98. for did in didqs:
  99. if d['UID'] == did['UID']:
  100. d['did'] = did['id']
  101. d['Type'] = did['Type']
  102. data.append(d)
  103. return response.json(0, {'data': data, 'count': count})
  104. # admins ^^^^^^^^^^^^
  105. def do_admin_delete(self, request_dict, userID, response):
  106. own_perm = ModelService.check_perm(userID, 20)
  107. if own_perm is True:
  108. orderID = request_dict.get('orderID')
  109. Order_Model.objects.filter(orderID=orderID).delete()
  110. return response.json(0)
  111. else:
  112. return response.json(404)
  113. def do_admin_query(self, request_dict, userID, response):
  114. own_perm = ModelService.check_perm(userID, 20)
  115. if own_perm is True:
  116. page = request_dict.get('page', None)
  117. line = request_dict.get('line', None)
  118. uid = request_dict.get('uid', None)
  119. channel = request_dict.get('channel', None)
  120. orderID = request_dict.get('orderID', None)
  121. page = int(page)
  122. line = int(line)
  123. omqs = Order_Model.objects.filter()
  124. # 筛选指定设备id的订单
  125. if uid:
  126. omqs = omqs.filter(UID=uid)
  127. if channel:
  128. omqs = omqs.filter(channel=channel)
  129. if orderID:
  130. omqs = omqs.filter(orderID=orderID)
  131. if not omqs.exists():
  132. return response.json(0, [])
  133. count = omqs.count()
  134. order_ql = omqs[(page - 1) * line:page * line].values("orderID", "UID", "channel", "desc", "price",
  135. "currency",
  136. "addTime",
  137. "updTime", "endTime", "paypal", "rank__day",
  138. "rank__price", "status",
  139. "rank__content", "rank__title", "rank__currency",
  140. "rank_id")
  141. order_list = list(order_ql)
  142. return response.json(0, {'data': order_list, 'count': count})
  143. else:
  144. return response.json(404)