UidUser.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  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: 2019/11/15 16:45
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: UserUid.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. # 添加设备字段
  15. import oss2
  16. import re
  17. import time
  18. import simplejson as json
  19. from django.utils.decorators import method_decorator
  20. from django.views.decorators.csrf import csrf_exempt
  21. from django.views.generic.base import View
  22. from Ansjer.config import OSS_STS_ACCESS_SECRET, OSS_STS_ACCESS_KEY
  23. from Model.models import UID_Bucket, UID_Preview, UidSetModel
  24. from Model.models import UidUserModel
  25. from Object.ResponseObject import ResponseObject
  26. from Object.TokenObject import TokenObject
  27. from Service.CommonService import CommonService
  28. from Service.ModelService import ModelService
  29. from Object.RedisObject import RedisObject
  30. '''
  31. http://192.168.136.40:8077/uiduser/add?token=local&UID=z123asdfqwerzxcvqw12&NickName=xxoxox&View_Account=user&View_Password=password&ChannelIndex=8&is_ap=1&Type=5&NickName=1234zcxv
  32. http://192.168.136.40:8077/uiduser/query?token=local&page=1&line=10&is_ap=1&NickName=1234zcxv&uid=zxcvasdfqwerzxcvqwer
  33. http://192.168.136.40:8077/uiduser/delete?token=local&id=138001380001573884997393980&is_ap=1
  34. '''
  35. # 添加设备字段
  36. def addInterface(request):
  37. request.encoding = 'utf-8'
  38. response = ResponseObject()
  39. if request.method == 'POST':
  40. request_dict = request.POST
  41. elif request.method == 'GET':
  42. request_dict = request.GET
  43. else:
  44. return response.json(444)
  45. token = request_dict.get('token', None)
  46. UID = request_dict.get('UID', None)
  47. NickName = request_dict.get('NickName', None)
  48. View_Account = request_dict.get('View_Account', None)
  49. View_Password = request_dict.get('View_Password', '')
  50. Type = request_dict.get('Type', None)
  51. ChannelIndex = request_dict.get('ChannelIndex', None)
  52. is_ap = request_dict.get('is_ap', None)
  53. if all([UID, NickName, View_Account, Type, ChannelIndex]):
  54. tko = TokenObject(token)
  55. response.lang = tko.lang
  56. if tko.code == 0:
  57. userID = tko.userID
  58. re_uid = re.compile(r'^[A-Za-z0-9]{20}$')
  59. if re_uid.match(UID):
  60. is_ap = int(is_ap)
  61. is_exist = UidUserModel.objects.filter(UID=UID, userID_id=userID, is_ap=is_ap)
  62. if is_exist:
  63. return response.json(174)
  64. else:
  65. try:
  66. pk = CommonService.getUserID(getUser=False)
  67. create_data = {
  68. 'id': pk, 'userID_id': userID, 'UID': UID,
  69. 'NickName': NickName, 'View_Account': View_Account,
  70. 'View_Password': View_Password, 'Type': Type, 'ChannelIndex': ChannelIndex
  71. }
  72. UidUserModel.objects.create(**create_data)
  73. # 判断影子信息
  74. nowTime = int(time.time())
  75. us_qs = UidSetModel.objects.filter(uid=UID)
  76. if not us_qs.exists():
  77. uid_set_create_dict = {
  78. 'uid': UID,
  79. 'addTime': nowTime,
  80. 'updTime': nowTime,
  81. 'ip': CommonService.get_ip_address(request),
  82. 'channel': ChannelIndex,
  83. 'nickname': NickName}
  84. UidSetModel.objects.create(**uid_set_create_dict)
  85. except Exception as e:
  86. return response.json(10, repr(e))
  87. else:
  88. uid_user_qs = UidUserModel.objects.filter(id=pk). \
  89. values('id', 'userID', 'NickName', 'UID', 'View_Account', 'View_Password',
  90. 'ChannelIndex', 'Type', 'isShare', 'primaryUserID', 'primaryMaster',
  91. 'data_joined', 'version', 'isVod', 'isExist','is_ap')
  92. uid_user_ql = CommonService.qs_to_list(uid_user_qs)
  93. ubqs = UID_Bucket.objects.filter(uid=UID). \
  94. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  95. res = uid_user_ql[0]
  96. res['vod'] = list(ubqs)
  97. return response.json(0, res)
  98. else:
  99. return response.json(444, {'param': 'UID'})
  100. else:
  101. return response.json(tko.code)
  102. else:
  103. return response.json(444, {'param': 'UID,NickName,View_Account,View_Password,Type,ChannelIndex'})
  104. # 新查询设备字段
  105. def queryInterface(request):
  106. request.encoding = 'utf-8'
  107. response = ResponseObject()
  108. if request.method == 'POST':
  109. request_dict = request.POST
  110. elif request.method == 'GET':
  111. request_dict = request.GET
  112. else:
  113. return response.json(444)
  114. token = request_dict.get('token', None)
  115. page = request_dict.get('page', None)
  116. line = request_dict.get('line', None)
  117. NickName = request_dict.get('NickName', None)
  118. uid = request_dict.get('uid', None)
  119. is_ap = request_dict.get('is_ap', None)
  120. page = int(page)
  121. line = int(line)
  122. tko = TokenObject(token)
  123. response.lang = tko.lang
  124. if page <= 0:
  125. return response.json(0)
  126. if tko.code == 0:
  127. userID = tko.userID
  128. redisObj = RedisObject(db=8)
  129. redisObj.del_data(key='uid_qs_' + userID)
  130. uid_user_qs = UidUserModel.objects.filter(userID_id=userID)
  131. if is_ap:
  132. is_ap = int(is_ap)
  133. uid_user_qs = uid_user_qs.filter(is_ap=is_ap)
  134. if NickName:
  135. uid_user_qs = uid_user_qs.filter(NickName__icontains=NickName)
  136. if uid:
  137. uid_user_qs = uid_user_qs.filter(UID=uid)
  138. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  139. values('id', 'userID', 'NickName', 'UID', 'View_Account',
  140. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  141. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  142. 'isVod', 'isExist', 'NotificationMode','is_ap')
  143. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  144. uid_list = []
  145. for uid_user in uid_user_ls:
  146. uid_list.append(uid_user['UID'])
  147. ubqs = UID_Bucket.objects.filter(uid__in=uid_list). \
  148. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  149. upqs = UID_Preview.objects.filter(uid__in=uid_list).order_by('channel').values('id', 'uid', 'channel')
  150. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  151. bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
  152. nowTime = int(time.time())
  153. data = []
  154. # 设备拓展信息表
  155. us_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'version', 'nickname')
  156. uv_dict = {}
  157. for us in us_qs:
  158. uv_dict[us['uid']] = {'version': us['version'], 'nickname': us['nickname']}
  159. for p in uid_user_ls:
  160. p['vod'] = []
  161. for dm in ubqs:
  162. if p['UID'] == dm['uid']:
  163. if dm['endTime'] > nowTime:
  164. p['vod'].append(dm)
  165. p['preview'] = []
  166. for up in upqs:
  167. if p['UID'] == up['uid']:
  168. obj = 'uid_preview/{uid}/channel_{channel}.png'.format(uid=up['uid'], channel=up['channel'])
  169. img_sign = bucket.sign_url('GET', obj, 300)
  170. p['preview'].append(img_sign)
  171. p_uid = p['UID']
  172. if p_uid in uv_dict:
  173. # 设备版本号
  174. p['uid_version'] = uv_dict[p_uid]['version']
  175. # 设备昵称
  176. if uv_dict[p_uid]['nickname']:
  177. p['NickName'] = uv_dict[p_uid]['nickname']
  178. else:
  179. # 设备版本号
  180. p['uid_version'] = ''
  181. data.append(p)
  182. return response.json(0, data)
  183. else:
  184. return response.json(tko.code)
  185. # http://192.168.136.40:8077/uiduser/update?token=local&id=138001380001573885065588328&View_Account=12&View_Password=555&NickName=555
  186. # 添加设备字段
  187. def updateInterface(request):
  188. request.encoding = 'utf-8'
  189. response = ResponseObject()
  190. if request.method == 'POST':
  191. request_dict = request.POST
  192. elif request.method == 'GET':
  193. request_dict = request.GET
  194. else:
  195. return response.json(444)
  196. token = request_dict.get('token', None)
  197. NickName = request_dict.get('NickName', None)
  198. View_Account = request_dict.get('View_Account', None)
  199. View_Password = request_dict.get('View_Password', None)
  200. Type = request_dict.get('Type', None)
  201. tko = TokenObject(token)
  202. response.lang = tko.lang
  203. if tko.code == 0:
  204. userID = tko.userID
  205. uid_user_qs = UidUserModel.objects.filter(userID_id=userID,)
  206. if uid_user_qs.exists():
  207. update_dict = {}
  208. if NickName:
  209. update_dict['NickName'] = NickName
  210. if View_Account is not None:
  211. update_dict['View_Account'] = View_Account
  212. if View_Password is not None:
  213. update_dict['View_Password'] = View_Password
  214. if Type is not None:
  215. update_dict['Type'] = Type
  216. is_update = uid_user_qs.update(**update_dict)
  217. if is_update:
  218. return response.json(0)
  219. else:
  220. return response.json(177)
  221. else:
  222. return response.json(174)
  223. else:
  224. return response.json(tko.code)
  225. # 新删除设备
  226. def deleteInterface(request):
  227. '''
  228. 删除用户设备
  229. :param request:
  230. :return:
  231. '''
  232. response = ResponseObject()
  233. request.encoding = 'utf-8'
  234. if request.method == 'POST':
  235. request_dict = request.POST
  236. elif request.method == 'GET':
  237. request_dict = request.GET
  238. else:
  239. return response.json(444)
  240. token = request_dict.get('token', None)
  241. id = request_dict.get('id', None)
  242. is_ap = request_dict.get('is_ap', None)
  243. if all([token, id, is_ap]):
  244. tko = TokenObject(token)
  245. response.lang = tko.lang
  246. if tko.code == 0:
  247. userID = tko.userID
  248. redisObj = RedisObject(db=8)
  249. redisObj.del_data(key='uid_qs_' + userID)
  250. uid_user_qs = UidUserModel.objects.filter(userID_id=userID, id=id)
  251. if uid_user_qs.exists():
  252. uid_user_qs.delete()
  253. return response.json(0)
  254. else:
  255. return response.json(173)
  256. else:
  257. return response.json(tko.code)
  258. else:
  259. return response.json(444, {'param': 'token,id,is_ap'})
  260. # 设备信息添加
  261. class UidUserView(View):
  262. @method_decorator(csrf_exempt)
  263. def dispatch(self, *args, **kwargs):
  264. return super(UidUserView, self).dispatch(*args, **kwargs)
  265. def get(self, request, *args, **kwargs):
  266. request.encoding = 'utf-8'
  267. operation = kwargs.get('operation')
  268. return self.validation(request.GET, request, operation)
  269. def post(self, request, *args, **kwargs):
  270. request.encoding = 'utf-8'
  271. operation = kwargs.get('operation')
  272. return self.validation(request.POST, request, operation)
  273. def validation(self, request_dict, request, operation):
  274. response = ResponseObject()
  275. if operation is None:
  276. return response.json(444, 'error path')
  277. token = request_dict.get('token', None)
  278. # 设备主键uid
  279. tko = TokenObject(token)
  280. response.lang = tko.lang
  281. if tko.code != 0:
  282. return response.json(tko.code)
  283. userID = tko.userID
  284. if operation == 'adminDelete':
  285. return self.do_admin_delete(request_dict, userID, response)
  286. elif operation == 'adminQuery':
  287. return self.do_admin_query(request_dict, userID, response)
  288. else:
  289. return response.json(444, 'error path')
  290. # 管理员删除
  291. def do_admin_delete(self, request_dict, userID, response):
  292. own_perm = ModelService.check_perm(userID, 20)
  293. if own_perm is True:
  294. id = request_dict.getlist('id', None)
  295. uid_user_qs = UidUserModel.objects.filter(id__in=id)
  296. if uid_user_qs.exists():
  297. uid_user_qs.delete()
  298. return response.json(0)
  299. else:
  300. return response.json(173)
  301. else:
  302. return response.json(404)
  303. # 管理员查询接口
  304. def do_admin_query(self, request_dict, userID, response):
  305. own_perm = ModelService.check_perm(userID, 20)
  306. if own_perm is True:
  307. page = request_dict.get('page', None)
  308. line = request_dict.get('line', None)
  309. page = int(page)
  310. line = int(line)
  311. deviceContent = request_dict.get('content', None)
  312. if deviceContent:
  313. try:
  314. searchCondition = json.loads(deviceContent)
  315. except Exception as e:
  316. return response.json(10, repr(e))
  317. else:
  318. kwargs = CommonService.get_kwargs(data=searchCondition)
  319. uid_user_qs = UidUserModel.objects.filter(**kwargs).order_by('-id')
  320. if not uid_user_qs.exists():
  321. return response.json(0, [])
  322. count = uid_user_qs.count()
  323. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  324. values('id', 'userID', 'userID__username', 'userID__userEmail', 'userID__NickName' 'NickName',
  325. 'UID', 'View_Account',
  326. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  327. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  328. 'isVod', 'isExist', 'NotificationMode', 'is_ap')
  329. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  330. return response.json(0, {'datas': uid_user_ls, 'count': count})
  331. else:
  332. uid_user_qs = UidUserModel.objects.all().order_by('-id')
  333. if not uid_user_qs.exists():
  334. return response.json(0, [])
  335. count = uid_user_qs.count()
  336. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  337. values('id', 'userID', 'userID__username', 'userID__userEmail', 'userID__NickName', 'NickName',
  338. 'UID', 'View_Account',
  339. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  340. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  341. 'isVod', 'isExist', 'NotificationMode', 'is_ap')
  342. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  343. return response.json(0, {'datas' : uid_user_ls, 'count': count})
  344. else:
  345. return response.json(404)