UidSetController.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  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. from Object.RedisObject import RedisObject
  17. import simplejson as json
  18. from django.utils.decorators import method_decorator
  19. from django.views.decorators.csrf import csrf_exempt
  20. from django.views.generic.base import View
  21. from Model.models import UidSetModel, Device_User, Device_Info, UidPushModel, Equipment_Info, UID_Preview, UID_Bucket, \
  22. VodHlsModel, Order_Model, OssCrdModel, UidUserModel, UidChannelSetModel
  23. from Object.ResponseObject import ResponseObject
  24. from Object.TokenObject import TokenObject
  25. from Service.CommonService import CommonService
  26. from Service.ModelService import ModelService
  27. from django.db import transaction
  28. '''
  29. # 管理员获取信息
  30. http://192.168.136.39:8000/uidset/adminQuery?token=local&page=1&line=10
  31. 管理员删除信息
  32. http://192.168.136.39:8000/uidset/adminDelete?token=local&id=2
  33. 管理员添加信息
  34. http://192.168.136.39:8000/uidset/adminAdd?token=local&uid=JW3684H8BSHG9TTM111A
  35. 管理员编辑信息
  36. http://192.168.136.39:8000/uidset/adminUpdate?token=local&id=6&content={"uid":"9999"}
  37. '''
  38. # 设备信息添加
  39. class UidSetView(View):
  40. @method_decorator(csrf_exempt)
  41. def dispatch(self, *args, **kwargs):
  42. return super(UidSetView, self).dispatch(*args, **kwargs)
  43. def get(self, request, *args, **kwargs):
  44. request.encoding = 'utf-8'
  45. operation = kwargs.get('operation')
  46. return self.validation(request.GET, request, operation)
  47. def post(self, request, *args, **kwargs):
  48. request.encoding = 'utf-8'
  49. operation = kwargs.get('operation')
  50. return self.validation(request.POST, request, operation)
  51. def validation(self, request_dict, request, operation):
  52. response = ResponseObject()
  53. if operation is None:
  54. return response.json(444, 'error path')
  55. token = request_dict.get('token', None)
  56. # 设备主键uid
  57. tko = TokenObject(token)
  58. response.lang = tko.lang
  59. if tko.code != 0:
  60. return response.json(tko.code)
  61. userID = tko.userID
  62. if operation == 'queryAll':
  63. return self.do_queryAll(request_dict, userID, response)
  64. elif operation == 'adminQueryAll':
  65. return self.do_admin_queryAll(request_dict, userID, response)
  66. elif operation == 'adminDelete':
  67. return self.do_admin_delete(request_dict, userID, response)
  68. elif operation == 'adminQuery':
  69. return self.do_admin_query(request_dict, userID, response)
  70. elif operation == 'adminAdd':
  71. return self.do_admin_add(request_dict, userID, response)
  72. elif operation == 'adminUpdate':
  73. return self.do_admin_update(request_dict, userID, response)
  74. elif operation == 'update':
  75. return self.do_update(request_dict, response)
  76. elif operation == 'updateSet':
  77. return self.do_update_set(request_dict, response)
  78. elif operation == 'updateChannel':
  79. return self.do_update_channel_set(request_dict, response)
  80. else:
  81. return response.json(444, 'error path')
  82. def do_queryAll(self, request_dict, userID, response):
  83. uid_list = Device_Info.objects.filter(userID_id=userID).values_list('UID', flat=True)
  84. uid_set_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'detect_status', 'detect_interval',
  85. 'version', 'ucode', 'p2p_region', 'tz',
  86. 'video_code', 'channel', 'cloud_vod')
  87. if uid_set_qs.exists():
  88. return response.json(0, list(uid_set_qs))
  89. else:
  90. return response.json(0)
  91. def do_admin_queryAll(self, request_dict, userID, response):
  92. uid = request_dict.get('uid', None)
  93. user_search = UidPushModel.objects.filter(uid_set__uid=uid).values(
  94. 'userID__username', 'userID__userEmail', 'userID__phone', 'userID__is_active',
  95. 'userID__NickName', 'uid_set__video_code', 'uid_set__version', 'uid_set__ucode',
  96. 'uid_set__tz', 'uid_set__p2p_region', 'uid_set__nickname', 'uid_set__detect_status',
  97. 'uid_set__detect_interval', 'uid_set__cloud_vod', 'uid_set__channel', 'updTime',
  98. 'tz', 'token_val', 'push_type', 'm_code',
  99. 'lang', 'app_type', 'uid_set__uid', 'userID__data_joined', 'appBundleId'
  100. )
  101. qs_list = CommonService.qs_to_list(user_search)
  102. return response.json(0, qs_list)
  103. # 管理员删除
  104. def do_admin_delete(self, request_dict, userID, response):
  105. own_perm = ModelService.check_perm(userID, 10)
  106. if own_perm is True:
  107. uid = request_dict.getlist('uid', None)
  108. id_list = request_dict.get('id_list', None)
  109. redisObj = RedisObject(db=8)
  110. redisObj.del_data(key='uid_qs_' + userID)
  111. # 删除回滚
  112. with transaction.atomic(): # 上下文格式,可以在python代码的任何位置使用
  113. val = 1
  114. if 'UidSetModel' in id_list:
  115. del_uid = UidSetModel.objects.filter(uid__in=uid)
  116. if del_uid.exists():
  117. del_uid.delete()
  118. print ('删除UidSetModel')
  119. else:
  120. val = 1
  121. print('UidSetModel表没有数据')
  122. if 'Equipment_Info' in id_list:
  123. del_uid = Equipment_Info.objects.filter(devUid__in=uid)
  124. if del_uid.exists():
  125. del_uid.delete()
  126. # print('删除Equipment_Info')
  127. else:
  128. val = val+1
  129. print('Equipment_Info表没有数据')
  130. if 'UID_Preview' in id_list:
  131. del_uid = UID_Preview.objects.filter(uid__in=uid)
  132. if del_uid.exists():
  133. del_uid.delete()
  134. # print ('删除UID_Preview')
  135. else:
  136. val = val + 1
  137. print('UID_Preview表没有数据')
  138. if 'UID_Bucket' in id_list:
  139. del_uid = UID_Bucket.objects.filter(uid__in=uid)
  140. if del_uid.exists():
  141. del_uid.delete()
  142. # print ('删除UID_Bucket')
  143. else:
  144. val = val + 1
  145. print('UID_Bucket表没有数据')
  146. if 'VodHlsModel' in id_list:
  147. del_uid = VodHlsModel.objects.filter(uid__in=uid)
  148. if del_uid.exists():
  149. # del_uid.delete()
  150. print ('删除VodHlsModel')
  151. else:
  152. val = val + 1
  153. print('VodHlsModel表没有数据')
  154. if 'Order_Model' in id_list:
  155. del_uid = Order_Model.objects.filter(UID__in=uid)
  156. if del_uid.exists():
  157. del_uid.delete()
  158. # print ('删除Order_Model')
  159. else:
  160. val = val + 1
  161. print('Order_Model表没有数据')
  162. if 'Device_Info' in id_list:
  163. del_uid = Device_Info.objects.filter(UID__in=uid)
  164. if del_uid.exists():
  165. del_uid.delete()
  166. # print ('删除Device_Info')
  167. else:
  168. val = val + 1
  169. print('Order_Model表没有数据')
  170. if 'OssCrdModel' in id_list:
  171. del_uid = OssCrdModel.objects.filter(uid__in=uid)
  172. if del_uid.exists():
  173. del_uid.delete()
  174. # print ('删除OssCrdModel')
  175. else:
  176. val = val + 1
  177. print('OssCrdModel表没有数据')
  178. if 'UidUserModel' in id_list:
  179. del_uid = UidUserModel.objects.filter(UID__in=uid)
  180. if del_uid.exists():
  181. del_uid.delete()
  182. # print ('删除UidUserModel')
  183. else:
  184. val = val + 1
  185. print('UidUserModel表没有数据')
  186. #有后台管理 设备配置表UidSetModel ---uid --本身,
  187. #有后台管理 设备关联用户推送表Equipment_Info --devUid --独立没有儿子的,
  188. #有后台管理 设备预览图表UID_Preview ---uid---孤立,
  189. #有后台管理 设备关联套餐表UID_Bucket ---uid---孤立,
  190. #有后台管理 云存回放信息表VodHlsModel ---uid---孤立,
  191. #有后台管理 订单信息表Order_Model --UID----独立没有儿子的,
  192. #有后台管理 用户设备信息表(最多信息量的表)Device_Info ---UID---孤立,
  193. # 设备证书OssCrdModel ---uid---孤立
  194. # 有后台管理 设备ap表 UidUserModel
  195. #设备绑定UidPushModel---关联表---设备配置表UidSetModel---配置表的详情有显示
  196. # raise DatabaseError #测试用,检测是否能捕捉错误
  197. if val == 9:
  198. return response.json(173)
  199. else:
  200. return response.json(0)
  201. else:
  202. return response.json(404)
  203. # 管理员查询接口
  204. def do_admin_query(self, request_dict, userID, response):
  205. own_perm = ModelService.check_perm(userID, 20)
  206. if own_perm is True:
  207. page = request_dict.get('page', None)
  208. line = request_dict.get('line', None)
  209. page = int(page)
  210. line = int(line)
  211. deviceContent = request_dict.get('content', None)
  212. if deviceContent:
  213. try:
  214. searchCondition = json.loads(deviceContent)
  215. except Exception as e:
  216. return response.json(10, repr(e))
  217. else:
  218. kwargs = CommonService.get_kwargs(data=searchCondition)
  219. omqs = UidSetModel.objects.filter(**kwargs).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. omqs = UidSetModel.objects.all().order_by('-id')
  229. if not omqs.exists():
  230. return response.json(0, [])
  231. count = omqs.count()
  232. order_ql = omqs[(page - 1) * line:page * line]
  233. uidset_json = CommonService.qs_to_dict(order_ql)
  234. uidset_json['count'] = count
  235. return response.json(0, uidset_json)
  236. else:
  237. return response.json(404)
  238. # 管理员的添加
  239. def do_admin_add(self, request_dict, userID, response):
  240. own_perm = ModelService.check_perm(userID=userID, permID=40)
  241. if own_perm is not True:
  242. return response.json(404)
  243. uid = request_dict.get('uid', None)
  244. timestamp = int(time.time())
  245. param_flag = CommonService.get_param_flag(
  246. data=[uid])
  247. if param_flag is not True:
  248. return response.json(444)
  249. try:
  250. uidset = UidSetModel(
  251. uid=uid,
  252. addTime=timestamp,
  253. updTime=timestamp)
  254. uidset.save()
  255. return response.json(0)
  256. except Exception:
  257. errorInfo = traceback.format_exc()
  258. print(errorInfo)
  259. return response.json(500, {'details': errorInfo})
  260. # 管理员的编辑
  261. def do_admin_update(self, request_dict, userID, response):
  262. own_perm = ModelService.check_perm(userID=userID, permID=50)
  263. if own_perm is not True:
  264. return response.json(404)
  265. deviceContent = request_dict.get('content', None)
  266. id = request_dict.get('id', None)
  267. if not deviceContent or not id:
  268. return response.json(444, 'content,id')
  269. try:
  270. timestamp = int(time.time())
  271. deviceData = json.loads(deviceContent)
  272. uid_set = UidSetModel.objects.filter(id=id)
  273. if uid_set.exists():
  274. uid_set.update(updTime=timestamp, **deviceData)
  275. return response.json(0)
  276. else:
  277. return response.json(173)
  278. except Exception:
  279. errorInfo = traceback.format_exc()
  280. print(errorInfo)
  281. return response.json(500, {'details': errorInfo})
  282. def do_update(self, request_dict, response):
  283. uid = request_dict.get('uid', None)
  284. region_alexa = request_dict.get('region_alexa', None)
  285. is_alexa = request_dict.get('is_alexa', None)
  286. try:
  287. timestamp = int(time.time())
  288. uid_set = UidSetModel.objects.filter(uid=uid)
  289. if uid_set.exists():
  290. if region_alexa is None:
  291. uid_set.update(updTime=timestamp, is_alexa=is_alexa)
  292. else:
  293. if is_alexa is None:
  294. uid_set.update(updTime=timestamp, region_alexa=region_alexa)
  295. else:
  296. uid_set.update(updTime=timestamp, region_alexa=region_alexa, is_alexa=is_alexa)
  297. return response.json(0)
  298. else:
  299. return response.json(173)
  300. except Exception:
  301. errorInfo = traceback.format_exc()
  302. return response.json(500, {'details': errorInfo})
  303. def do_update_set(self, request_dict, response):
  304. uid = request_dict.get('uid', None)
  305. deviceContent = request_dict.get('content', None)
  306. token = request_dict.get('token', None)
  307. print(deviceContent)
  308. if not deviceContent or not uid:
  309. return response.json(444, 'content,uid')
  310. tko = TokenObject(token)
  311. response.lang = tko.lang
  312. if tko.code != 0:
  313. return response.json(tko.code)
  314. userID = tko.userID
  315. if userID is None:
  316. return response.json(309)
  317. try:
  318. redisObj = RedisObject(db=8)
  319. redisObj.del_data(key='uid_qs_' + userID)
  320. deviceData = json.loads(deviceContent)
  321. uid_set_qs = UidSetModel.objects.filter(uid=uid)
  322. uid_set_qs.update(**deviceData)
  323. except Exception as e:
  324. return response.json(177, repr(e))
  325. else:
  326. return response.json(0)
  327. def do_update_channel_set(self, request_dict, response):
  328. uid = request_dict.get('uid', None)
  329. channel = request_dict.get('channel', None)
  330. channelContent = request_dict.get('content', None)
  331. token = request_dict.get('token', None)
  332. print(channelContent)
  333. if not channelContent or not uid or not channel:
  334. return response.json(444, 'content,uid, chan')
  335. tko = TokenObject(token)
  336. response.lang = tko.lang
  337. if tko.code != 0:
  338. return response.json(tko.code)
  339. userID = tko.userID
  340. if userID is None:
  341. return response.json(309)
  342. try:
  343. redisObj = RedisObject(db=8)
  344. redisObj.del_data(key='uid_qs_' + userID)
  345. deviceData = json.loads(channelContent)
  346. uid_channel_set_qs = UidChannelSetModel.objects.filter(uid__uid=uid, channel=channel)
  347. if not uid_channel_set_qs.exists():
  348. uidObject = UidSetModel.objects.filter(uid=uid)
  349. ucs = {
  350. 'channel': channel,
  351. 'uid': uidObject[0]
  352. }
  353. keys = deviceData.keys()
  354. for key in keys:
  355. ucs[key] = deviceData[key]
  356. UidChannelSetModel.objects.create(**ucs)
  357. else:
  358. uid_channel_set_qs.update(**deviceData)
  359. except Exception as e:
  360. return response.json(177, repr(e))
  361. else:
  362. return response.json(0)