UidSetController.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. @Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.
  5. @AUTHOR: ASJRD019
  6. @NAME: AnsjerFormal
  7. @software: PyCharm
  8. @DATE: 2019/5/27 15:50
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: AliPayObject.py
  12. @Contact: pzb3076@163.com
  13. """
  14. import time
  15. import traceback
  16. import simplejson as json
  17. from django.utils.decorators import method_decorator
  18. from django.views.decorators.csrf import csrf_exempt
  19. from django.views.generic.base import View
  20. from Model.models import UidSetModel, Device_User, Device_Info, UidPushModel, Equipment_Info, UID_Preview, UID_Bucket, \
  21. VodHlsModel, Order_Model, OssCrdModel,UidUserModel
  22. from Object.ResponseObject import ResponseObject
  23. from Object.TokenObject import TokenObject
  24. from Service.CommonService import CommonService
  25. from Service.ModelService import ModelService
  26. from django.db import transaction
  27. '''
  28. # 管理员获取信息
  29. http://192.168.136.39:8000/uidset/adminQuery?token=local&page=1&line=10
  30. 管理员删除信息
  31. http://192.168.136.39:8000/uidset/adminDelete?token=local&id=2
  32. 管理员添加信息
  33. http://192.168.136.39:8000/uidset/adminAdd?token=local&uid=JW3684H8BSHG9TTM111A
  34. 管理员编辑信息
  35. http://192.168.136.39:8000/uidset/adminUpdate?token=local&id=6&content={"uid":"9999"}
  36. '''
  37. # 设备信息添加
  38. class UidSetView(View):
  39. @method_decorator(csrf_exempt)
  40. def dispatch(self, *args, **kwargs):
  41. return super(UidSetView, self).dispatch(*args, **kwargs)
  42. def get(self, request, *args, **kwargs):
  43. request.encoding = 'utf-8'
  44. operation = kwargs.get('operation')
  45. return self.validation(request.GET, request, operation)
  46. def post(self, request, *args, **kwargs):
  47. request.encoding = 'utf-8'
  48. operation = kwargs.get('operation')
  49. return self.validation(request.POST, request, operation)
  50. def validation(self, request_dict, request, operation):
  51. response = ResponseObject()
  52. if operation is None:
  53. return response.json(444, 'error path')
  54. token = request_dict.get('token', None)
  55. # 设备主键uid
  56. tko = TokenObject(token)
  57. response.lang = tko.lang
  58. if tko.code != 0:
  59. return response.json(tko.code)
  60. userID = tko.userID
  61. if operation == 'queryAll':
  62. return self.do_queryAll(request_dict, userID, response)
  63. elif operation == 'adminQueryAll':
  64. return self.do_admin_queryAll(request_dict, userID, response)
  65. elif operation == 'adminDelete':
  66. return self.do_admin_delete(request_dict, userID, response)
  67. elif operation == 'adminQuery':
  68. return self.do_admin_query(request_dict, userID, response)
  69. elif operation == 'adminAdd':
  70. return self.do_admin_add(request_dict, userID, response)
  71. elif operation == 'adminUpdate':
  72. return self.do_admin_update(request_dict, userID, response)
  73. elif operation == 'update':
  74. return self.do_update(request_dict, response)
  75. else:
  76. return response.json(444, 'error path')
  77. def do_queryAll(self, request_dict, userID, response):
  78. uid_list = Device_Info.objects.filter(userID_id=userID).values_list('UID', flat=True)
  79. uid_set_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'detect_status', 'detect_interval',
  80. 'version', 'ucode', 'p2p_region', 'tz',
  81. 'video_code', 'channel', 'cloud_vod')
  82. if uid_set_qs.exists():
  83. return response.json(0, list(uid_set_qs))
  84. else:
  85. return response.json(0)
  86. def do_admin_queryAll(self, request_dict, userID, response):
  87. uid_list = Device_Info.objects.filter(userID_id=userID).values_list('UID', flat=True)
  88. id = request_dict.get('id', None)
  89. uid_set_qs = UidPushModel.objects.filter(uid_set__id=id).values('addTime',
  90. 'appBundleId','app_type','lang','m_code','push_type','token_val','tz','uid_set',
  91. 'updTime','userID','userID__username'
  92. , 'userID__userEmail', 'userID__NickName'
  93. , 'userID__is_active', 'userID__phone'
  94. )
  95. return response.json(0, list(uid_set_qs))
  96. # 管理员删除
  97. def do_admin_delete(self, request_dict, userID, response):
  98. own_perm = ModelService.check_perm(userID, 10)
  99. if own_perm is True:
  100. uid = request_dict.getlist('uid', None)
  101. id_list = request_dict.get('id_list', None)
  102. # 删除回滚
  103. with transaction.atomic(): # 上下文格式,可以在python代码的任何位置使用
  104. val = 1
  105. if 'UidSetModel' in id_list:
  106. del_uid = UidSetModel.objects.filter(uid__in=uid)
  107. if del_uid.exists():
  108. del_uid.delete()
  109. print ('删除UidSetModel')
  110. else:
  111. val = 1
  112. print('UidSetModel表没有数据')
  113. if 'Equipment_Info' in id_list:
  114. del_uid = Equipment_Info.objects.filter(devUid__in=uid)
  115. if del_uid.exists():
  116. del_uid.delete()
  117. # print('删除Equipment_Info')
  118. else:
  119. val = val+1
  120. print('Equipment_Info表没有数据')
  121. if 'UID_Preview' in id_list:
  122. del_uid = UID_Preview.objects.filter(uid__in=uid)
  123. if del_uid.exists():
  124. del_uid.delete()
  125. # print ('删除UID_Preview')
  126. else:
  127. val = val + 1
  128. print('UID_Preview表没有数据')
  129. if 'UID_Bucket' in id_list:
  130. del_uid = UID_Bucket.objects.filter(uid__in=uid)
  131. if del_uid.exists():
  132. del_uid.delete()
  133. # print ('删除UID_Bucket')
  134. else:
  135. val = val + 1
  136. print('UID_Bucket表没有数据')
  137. if 'VodHlsModel' in id_list:
  138. del_uid = VodHlsModel.objects.filter(uid__in=uid)
  139. if del_uid.exists():
  140. # del_uid.delete()
  141. print ('删除VodHlsModel')
  142. else:
  143. val = val + 1
  144. print('VodHlsModel表没有数据')
  145. if 'Order_Model' in id_list:
  146. del_uid = Order_Model.objects.filter(UID__in=uid)
  147. if del_uid.exists():
  148. del_uid.delete()
  149. # print ('删除Order_Model')
  150. else:
  151. val = val + 1
  152. print('Order_Model表没有数据')
  153. if 'Device_Info' in id_list:
  154. del_uid = Device_Info.objects.filter(UID__in=uid)
  155. if del_uid.exists():
  156. del_uid.delete()
  157. # print ('删除Device_Info')
  158. else:
  159. val = val + 1
  160. print('Order_Model表没有数据')
  161. if 'OssCrdModel' in id_list:
  162. del_uid = OssCrdModel.objects.filter(uid__in=uid)
  163. if del_uid.exists():
  164. del_uid.delete()
  165. # print ('删除OssCrdModel')
  166. else:
  167. val = val + 1
  168. print('OssCrdModel表没有数据')
  169. if 'UidUserModel' in id_list:
  170. del_uid = UidUserModel.objects.filter(UID__in=uid)
  171. if del_uid.exists():
  172. del_uid.delete()
  173. # print ('删除UidUserModel')
  174. else:
  175. val = val + 1
  176. print('UidUserModel表没有数据')
  177. #有后台管理 设备配置表UidSetModel ---uid --本身,
  178. #有后台管理 设备关联用户推送表Equipment_Info --devUid --独立没有儿子的,
  179. #有后台管理 设备预览图表UID_Preview ---uid---孤立,
  180. #有后台管理 设备关联套餐表UID_Bucket ---uid---孤立,
  181. #有后台管理 云存回放信息表VodHlsModel ---uid---孤立,
  182. #有后台管理 订单信息表Order_Model --UID----独立没有儿子的,
  183. #有后台管理 用户设备信息表(最多信息量的表)Device_Info ---UID---孤立,
  184. # 设备证书OssCrdModel ---uid---孤立
  185. # 有后台管理 设备ap表 UidUserModel
  186. #设备绑定UidPushModel---关联表---设备配置表UidSetModel---配置表的详情有显示
  187. # raise DatabaseError #测试用,检测是否能捕捉错误
  188. if val == 9:
  189. return response.json(173)
  190. else:
  191. return response.json(0)
  192. else:
  193. return response.json(404)
  194. # 管理员查询接口
  195. def do_admin_query(self, request_dict, userID, response):
  196. own_perm = ModelService.check_perm(userID, 20)
  197. if own_perm is True:
  198. page = request_dict.get('page', None)
  199. line = request_dict.get('line', None)
  200. page = int(page)
  201. line = int(line)
  202. deviceContent = request_dict.get('content', None)
  203. if deviceContent:
  204. try:
  205. searchCondition = json.loads(deviceContent)
  206. except Exception as e:
  207. return response.json(10, repr(e))
  208. else:
  209. kwargs = CommonService.get_kwargs(data=searchCondition)
  210. omqs = UidSetModel.objects.filter(**kwargs).order_by('-id')
  211. if not omqs.exists():
  212. return response.json(0, [])
  213. count = omqs.count()
  214. order_ql = omqs[(page - 1) * line:page * line]
  215. uidset_json = CommonService.qs_to_dict(order_ql)
  216. uidset_json['count'] = count
  217. return response.json(0, uidset_json)
  218. else:
  219. omqs = UidSetModel.objects.all().order_by('-id')
  220. if not omqs.exists():
  221. return response.json(0, [])
  222. count = omqs.count()
  223. order_ql = omqs[(page - 1) * line:page * line]
  224. uidset_json = CommonService.qs_to_dict(order_ql)
  225. uidset_json['count'] = count
  226. return response.json(0, uidset_json)
  227. else:
  228. return response.json(404)
  229. # 管理员的添加
  230. def do_admin_add(self, request_dict, userID, response):
  231. own_perm = ModelService.check_perm(userID=userID, permID=40)
  232. if own_perm is not True:
  233. return response.json(404)
  234. uid = request_dict.get('uid', None)
  235. timestamp = int(time.time())
  236. param_flag = CommonService.get_param_flag(
  237. data=[uid])
  238. if param_flag is not True:
  239. return response.json(444)
  240. try:
  241. uidset = UidSetModel(
  242. uid=uid,
  243. addTime=timestamp,
  244. updTime=timestamp)
  245. uidset.save()
  246. return response.json(0)
  247. except Exception:
  248. errorInfo = traceback.format_exc()
  249. print(errorInfo)
  250. return response.json(500, {'details': errorInfo})
  251. # 管理员的编辑
  252. def do_admin_update(self, request_dict, userID, response):
  253. own_perm = ModelService.check_perm(userID=userID, permID=50)
  254. if own_perm is not True:
  255. return response.json(404)
  256. deviceContent = request_dict.get('content', None)
  257. id = request_dict.get('id', None)
  258. if not deviceContent or not id:
  259. return response.json(444, 'content,id')
  260. try:
  261. timestamp = int(time.time())
  262. deviceData = json.loads(deviceContent)
  263. uid_set = UidSetModel.objects.filter(id=id)
  264. if uid_set.exists():
  265. uid_set.update(updTime=timestamp, **deviceData)
  266. return response.json(0)
  267. else:
  268. return response.json(173)
  269. except Exception:
  270. errorInfo = traceback.format_exc()
  271. print(errorInfo)
  272. return response.json(500, {'details': errorInfo})
  273. def do_update(self, request_dict, response):
  274. uid = request_dict.get('uid', None)
  275. region_alexa = request_dict.get('region_alexa', None)
  276. is_alexa = request_dict.get('is_alexa', None)
  277. try:
  278. timestamp = int(time.time())
  279. uid_set = UidSetModel.objects.filter(uid=uid)
  280. if uid_set.exists():
  281. uid_set.update(updTime=timestamp,region_alexa=region_alexa,is_alexa=is_alexa )
  282. return response.json(0)
  283. else:
  284. return response.json(173)
  285. except Exception:
  286. errorInfo = traceback.format_exc()
  287. print(errorInfo)
  288. return response.json(500, {'details': errorInfo})