UidUser.py 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547
  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. import base64
  31. '''
  32. 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
  33. http://192.168.136.40:8077/uiduser/query?token=local&page=1&line=10&is_ap=1&NickName=1234zcxv&uid=zxcvasdfqwerzxcvqwer
  34. http://192.168.136.40:8077/uiduser/delete?token=local&id=138001380001573884997393980&is_ap=1
  35. '''
  36. # 添加设备字段
  37. def addInterface(request):
  38. request.encoding = 'utf-8'
  39. response = ResponseObject()
  40. if request.method == 'POST':
  41. request_dict = request.POST
  42. elif request.method == 'GET':
  43. request_dict = request.GET
  44. else:
  45. return response.json(444)
  46. token = request_dict.get('token', None)
  47. UID = request_dict.get('UID', None)
  48. NickName = request_dict.get('NickName', None)
  49. View_Account = request_dict.get('View_Account', None)
  50. View_Password = request_dict.get('View_Password', '')
  51. Type = request_dict.get('Type', None)
  52. ChannelIndex = request_dict.get('ChannelIndex', None)
  53. is_ap = request_dict.get('is_ap', None)
  54. if all([UID, NickName, View_Account, Type, ChannelIndex]):
  55. tko = TokenObject(token)
  56. response.lang = tko.lang
  57. if tko.code == 0:
  58. userID = tko.userID
  59. re_uid = re.compile(r'^[A-Za-z0-9]{20}$')
  60. if re_uid.match(UID):
  61. is_ap = int(is_ap)
  62. is_exist = UidUserModel.objects.filter(UID=UID, userID_id=userID, is_ap=is_ap)
  63. if is_exist:
  64. return response.json(174)
  65. else:
  66. try:
  67. pk = CommonService.getUserID(getUser=False)
  68. create_data = {
  69. 'id': pk, 'userID_id': userID, 'UID': UID,
  70. 'NickName': NickName, 'View_Account': View_Account,
  71. 'View_Password': View_Password, 'Type': Type, 'ChannelIndex': ChannelIndex
  72. }
  73. UidUserModel.objects.create(**create_data)
  74. # 判断影子信息
  75. nowTime = int(time.time())
  76. us_qs = UidSetModel.objects.filter(uid=UID)
  77. if not us_qs.exists():
  78. uid_set_create_dict = {
  79. 'uid': UID,
  80. 'addTime': nowTime,
  81. 'updTime': nowTime,
  82. 'ip': CommonService.get_ip_address(request),
  83. 'channel': ChannelIndex,
  84. 'nickname': NickName}
  85. UidSetModel.objects.create(**uid_set_create_dict)
  86. except Exception as e:
  87. return response.json(10, repr(e))
  88. else:
  89. uid_user_qs = UidUserModel.objects.filter(id=pk). \
  90. values('id', 'userID', 'NickName', 'UID', 'View_Account', 'View_Password',
  91. 'ChannelIndex', 'Type', 'isShare', 'primaryUserID', 'primaryMaster',
  92. 'data_joined', 'version', 'isVod', 'isExist','is_ap')
  93. uid_user_ql = CommonService.qs_to_list(uid_user_qs)
  94. ubqs = UID_Bucket.objects.filter(uid=UID). \
  95. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  96. res = uid_user_ql[0]
  97. res['vod'] = list(ubqs)
  98. return response.json(0, res)
  99. else:
  100. return response.json(444, {'param': 'UID'})
  101. else:
  102. return response.json(tko.code)
  103. else:
  104. return response.json(444, {'param': 'UID,NickName,View_Account,View_Password,Type,ChannelIndex'})
  105. # 新查询设备字段
  106. def queryInterface(request):
  107. request.encoding = 'utf-8'
  108. response = ResponseObject()
  109. if request.method == 'POST':
  110. request_dict = request.POST
  111. elif request.method == 'GET':
  112. request_dict = request.GET
  113. else:
  114. return response.json(444)
  115. token = request_dict.get('token', None)
  116. page = request_dict.get('page', None)
  117. line = request_dict.get('line', None)
  118. NickName = request_dict.get('NickName', None)
  119. uid = request_dict.get('uid', None)
  120. is_ap = request_dict.get('is_ap', None)
  121. page = int(page)
  122. line = int(line)
  123. tko = TokenObject(token)
  124. response.lang = tko.lang
  125. if page <= 0:
  126. return response.json(0)
  127. if tko.code == 0:
  128. userID = tko.userID
  129. redisObj = RedisObject(db=8)
  130. redisObj.del_data(key='uid_qs_' + userID)
  131. uid_user_qs = UidUserModel.objects.filter(userID_id=userID)
  132. if is_ap:
  133. is_ap = int(is_ap)
  134. uid_user_qs = uid_user_qs.filter(is_ap=is_ap)
  135. if NickName:
  136. uid_user_qs = uid_user_qs.filter(NickName__icontains=NickName)
  137. if uid:
  138. uid_user_qs = uid_user_qs.filter(UID=uid)
  139. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  140. values('id', 'userID', 'NickName', 'UID', 'View_Account',
  141. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  142. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  143. 'isVod', 'isExist', 'NotificationMode','is_ap')
  144. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  145. uid_list = []
  146. for uid_user in uid_user_ls:
  147. uid_list.append(uid_user['UID'])
  148. ubqs = UID_Bucket.objects.filter(uid__in=uid_list). \
  149. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  150. upqs = UID_Preview.objects.filter(uid__in=uid_list).order_by('channel').values('id', 'uid', 'channel')
  151. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  152. bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
  153. nowTime = int(time.time())
  154. data = []
  155. # 设备拓展信息表
  156. us_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'version', 'nickname')
  157. uv_dict = {}
  158. for us in us_qs:
  159. uv_dict[us['uid']] = {'version': us['version'], 'nickname': us['nickname']}
  160. for p in uid_user_ls:
  161. p['vod'] = []
  162. for dm in ubqs:
  163. if p['UID'] == dm['uid']:
  164. if dm['endTime'] > nowTime:
  165. p['vod'].append(dm)
  166. p['preview'] = []
  167. for up in upqs:
  168. if p['UID'] == up['uid']:
  169. obj = 'uid_preview/{uid}/channel_{channel}.png'.format(uid=up['uid'], channel=up['channel'])
  170. img_sign = bucket.sign_url('GET', obj, 300)
  171. p['preview'].append(img_sign)
  172. p_uid = p['UID']
  173. if p_uid in uv_dict:
  174. # 设备版本号
  175. p['uid_version'] = uv_dict[p_uid]['version']
  176. # 设备昵称
  177. if uv_dict[p_uid]['nickname']:
  178. p['NickName'] = uv_dict[p_uid]['nickname']
  179. else:
  180. # 设备版本号
  181. p['uid_version'] = ''
  182. data.append(p)
  183. return response.json(0, data)
  184. else:
  185. return response.json(tko.code)
  186. # http://192.168.136.40:8077/uiduser/update?token=local&id=138001380001573885065588328&View_Account=12&View_Password=555&NickName=555
  187. # 添加设备字段
  188. def updateInterface(request):
  189. request.encoding = 'utf-8'
  190. response = ResponseObject()
  191. if request.method == 'POST':
  192. request_dict = request.POST
  193. elif request.method == 'GET':
  194. request_dict = request.GET
  195. else:
  196. return response.json(444)
  197. token = request_dict.get('token', None)
  198. NickName = request_dict.get('NickName', None)
  199. View_Account = request_dict.get('View_Account', None)
  200. View_Password = request_dict.get('View_Password', None)
  201. Type = request_dict.get('Type', None)
  202. tko = TokenObject(token)
  203. response.lang = tko.lang
  204. if tko.code == 0:
  205. userID = tko.userID
  206. uid_user_qs = UidUserModel.objects.filter(userID_id=userID,)
  207. if uid_user_qs.exists():
  208. update_dict = {}
  209. if NickName:
  210. update_dict['NickName'] = NickName
  211. if View_Account is not None:
  212. update_dict['View_Account'] = View_Account
  213. if View_Password is not None:
  214. update_dict['View_Password'] = View_Password
  215. if Type is not None:
  216. update_dict['Type'] = Type
  217. is_update = uid_user_qs.update(**update_dict)
  218. if is_update:
  219. return response.json(0)
  220. else:
  221. return response.json(177)
  222. else:
  223. return response.json(174)
  224. else:
  225. return response.json(tko.code)
  226. # 新删除设备
  227. def deleteInterface(request):
  228. '''
  229. 删除用户设备
  230. :param request:
  231. :return:
  232. '''
  233. response = ResponseObject()
  234. request.encoding = 'utf-8'
  235. if request.method == 'POST':
  236. request_dict = request.POST
  237. elif request.method == 'GET':
  238. request_dict = request.GET
  239. else:
  240. return response.json(444)
  241. token = request_dict.get('token', None)
  242. id = request_dict.get('id', None)
  243. is_ap = request_dict.get('is_ap', None)
  244. if all([token, id, is_ap]):
  245. tko = TokenObject(token)
  246. response.lang = tko.lang
  247. if tko.code == 0:
  248. userID = tko.userID
  249. redisObj = RedisObject(db=8)
  250. redisObj.del_data(key='uid_qs_' + userID)
  251. uid_user_qs = UidUserModel.objects.filter(userID_id=userID, id=id)
  252. if uid_user_qs.exists():
  253. uid_user_qs.delete()
  254. return response.json(0)
  255. else:
  256. return response.json(173)
  257. else:
  258. return response.json(tko.code)
  259. else:
  260. return response.json(444, {'param': 'token,id,is_ap'})
  261. # 设备信息添加
  262. class UidUserView(View):
  263. @method_decorator(csrf_exempt)
  264. def dispatch(self, *args, **kwargs):
  265. return super(UidUserView, self).dispatch(*args, **kwargs)
  266. def get(self, request, *args, **kwargs):
  267. request.encoding = 'utf-8'
  268. operation = kwargs.get('operation')
  269. return self.validation(request.GET, request, operation)
  270. def post(self, request, *args, **kwargs):
  271. request.encoding = 'utf-8'
  272. operation = kwargs.get('operation')
  273. return self.validation(request.POST, request, operation)
  274. def validation(self, request_dict, request, operation):
  275. response = ResponseObject()
  276. if operation is None:
  277. return response.json(444, 'error path')
  278. token = request_dict.get('token', None)
  279. # 设备主键uid
  280. tko = TokenObject(token)
  281. response.lang = tko.lang
  282. if tko.code != 0:
  283. return response.json(tko.code)
  284. userID = tko.userID
  285. if operation == 'adminDelete':
  286. return self.do_admin_delete(request_dict, userID, response)
  287. elif operation == 'adminQuery':
  288. return self.do_admin_query(request_dict, userID, response)
  289. else:
  290. return response.json(444, 'error path')
  291. # 管理员删除
  292. def do_admin_delete(self, request_dict, userID, response):
  293. own_perm = ModelService.check_perm(userID, 20)
  294. if own_perm is True:
  295. id = request_dict.getlist('id', None)
  296. uid_user_qs = UidUserModel.objects.filter(id__in=id)
  297. if uid_user_qs.exists():
  298. uid_user_qs.delete()
  299. return response.json(0)
  300. else:
  301. return response.json(173)
  302. else:
  303. return response.json(404)
  304. # 管理员查询接口
  305. def do_admin_query(self, request_dict, userID, response):
  306. own_perm = ModelService.check_perm(userID, 20)
  307. if own_perm is True:
  308. page = request_dict.get('page', None)
  309. line = request_dict.get('line', None)
  310. page = int(page)
  311. line = int(line)
  312. deviceContent = request_dict.get('content', None)
  313. if deviceContent:
  314. try:
  315. searchCondition = json.loads(deviceContent)
  316. except Exception as e:
  317. return response.json(10, repr(e))
  318. else:
  319. kwargs = CommonService.get_kwargs(data=searchCondition)
  320. uid_user_qs = UidUserModel.objects.filter(**kwargs).order_by('-id')
  321. if not uid_user_qs.exists():
  322. return response.json(0, [])
  323. count = uid_user_qs.count()
  324. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  325. values('id', 'userID', 'userID__username', 'userID__userEmail', 'userID__NickName' 'NickName',
  326. 'UID', 'View_Account',
  327. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  328. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  329. 'isVod', 'isExist', 'NotificationMode', 'is_ap')
  330. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  331. return response.json(0, {'datas': uid_user_ls, 'count': count})
  332. else:
  333. uid_user_qs = UidUserModel.objects.all().order_by('-id')
  334. if not uid_user_qs.exists():
  335. return response.json(0, [])
  336. count = uid_user_qs.count()
  337. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  338. values('id', 'userID', 'userID__username', 'userID__userEmail', 'userID__NickName', 'NickName',
  339. 'UID', 'View_Account',
  340. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  341. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  342. 'isVod', 'isExist', 'NotificationMode', 'is_ap')
  343. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  344. return response.json(0, {'datas' : uid_user_ls, 'count': count})
  345. else:
  346. return response.json(404)
  347. # v3添加设备字段
  348. def v3addInterface(request):
  349. request.encoding = 'utf-8'
  350. response = ResponseObject()
  351. if request.method == 'POST':
  352. request_dict = request.POST
  353. elif request.method == 'GET':
  354. request_dict = request.GET
  355. else:
  356. return response.json(444)
  357. token = request_dict.get('token', None)
  358. UID = request_dict.get('UID', None)
  359. NickName = request_dict.get('NickName', None)
  360. View_Account = request_dict.get('View_Account', None)
  361. View_Password = request_dict.get('View_Password', '')
  362. Type = request_dict.get('Type', None)
  363. ChannelIndex = request_dict.get('ChannelIndex', None)
  364. is_ap = request_dict.get('is_ap', None)
  365. try:
  366. for i in range(1, 4):
  367. if i == 1:
  368. View_Password = base64.b64decode(View_Password)
  369. View_Password = View_Password.decode('utf-8')
  370. View_Password = View_Password[1:-1]
  371. if i == 2:
  372. View_Password = base64.b64decode(View_Password)
  373. View_Password = View_Password.decode('utf-8')
  374. View_Password = View_Password[2:-2]
  375. if i == 3:
  376. View_Password = base64.b64decode(View_Password)
  377. View_Password = View_Password.decode('utf-8')
  378. View_Password = View_Password[3:-3]
  379. print(View_Password)
  380. except Exception as e:
  381. return response.json(111)
  382. if not View_Password:
  383. return response.json(424)
  384. if all([UID, NickName, View_Account, Type, ChannelIndex]):
  385. tko = TokenObject(token)
  386. response.lang = tko.lang
  387. if tko.code == 0:
  388. userID = tko.userID
  389. re_uid = re.compile(r'^[A-Za-z0-9]{20}$')
  390. if re_uid.match(UID):
  391. is_ap = int(is_ap)
  392. is_exist = UidUserModel.objects.filter(UID=UID, userID_id=userID, is_ap=is_ap)
  393. if is_exist:
  394. return response.json(174)
  395. else:
  396. try:
  397. pk = CommonService.getUserID(getUser=False)
  398. create_data = {
  399. 'id': pk, 'userID_id': userID, 'UID': UID,
  400. 'NickName': NickName, 'View_Account': View_Account,
  401. 'View_Password': View_Password, 'Type': Type, 'ChannelIndex': ChannelIndex
  402. }
  403. UidUserModel.objects.create(**create_data)
  404. # 判断影子信息
  405. nowTime = int(time.time())
  406. us_qs = UidSetModel.objects.filter(uid=UID)
  407. if not us_qs.exists():
  408. uid_set_create_dict = {
  409. 'uid': UID,
  410. 'addTime': nowTime,
  411. 'updTime': nowTime,
  412. 'ip': CommonService.get_ip_address(request),
  413. 'channel': ChannelIndex,
  414. 'nickname': NickName}
  415. UidSetModel.objects.create(**uid_set_create_dict)
  416. except Exception as e:
  417. return response.json(10, repr(e))
  418. else:
  419. uid_user_qs = UidUserModel.objects.filter(id=pk). \
  420. values('id', 'userID', 'NickName', 'UID', 'View_Account', 'View_Password',
  421. 'ChannelIndex', 'Type', 'isShare', 'primaryUserID', 'primaryMaster',
  422. 'data_joined', 'version', 'isVod', 'isExist','is_ap')
  423. uid_user_ql = CommonService.qs_to_list(uid_user_qs)
  424. ubqs = UID_Bucket.objects.filter(uid=UID). \
  425. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  426. res = uid_user_ql[0]
  427. res['vod'] = list(ubqs)
  428. return response.json(0, res)
  429. else:
  430. return response.json(444, {'param': 'UID'})
  431. else:
  432. return response.json(tko.code)
  433. else:
  434. return response.json(444, {'param': 'UID,NickName,View_Account,View_Password,Type,ChannelIndex'})
  435. # v3新查询设备字段
  436. def v3queryInterface(request):
  437. request.encoding = 'utf-8'
  438. response = ResponseObject()
  439. if request.method == 'POST':
  440. request_dict = request.POST
  441. elif request.method == 'GET':
  442. request_dict = request.GET
  443. else:
  444. return response.json(444)
  445. token = request_dict.get('token', None)
  446. page = request_dict.get('page', None)
  447. line = request_dict.get('line', None)
  448. NickName = request_dict.get('NickName', None)
  449. uid = request_dict.get('uid', None)
  450. is_ap = request_dict.get('is_ap', None)
  451. page = int(page)
  452. line = int(line)
  453. tko = TokenObject(token)
  454. response.lang = tko.lang
  455. if page <= 0:
  456. return response.json(0)
  457. if tko.code == 0:
  458. userID = tko.userID
  459. redisObj = RedisObject(db=8)
  460. redisObj.del_data(key='uid_qs_' + userID)
  461. uid_user_qs = UidUserModel.objects.filter(userID_id=userID)
  462. if is_ap:
  463. is_ap = int(is_ap)
  464. uid_user_qs = uid_user_qs.filter(is_ap=is_ap)
  465. if NickName:
  466. uid_user_qs = uid_user_qs.filter(NickName__icontains=NickName)
  467. if uid:
  468. uid_user_qs = uid_user_qs.filter(UID=uid)
  469. uid_user_ql = uid_user_qs[(page - 1) * line:page * line]. \
  470. values('id', 'userID', 'NickName', 'UID', 'View_Account',
  471. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  472. 'primaryUserID', 'primaryMaster', 'data_joined', 'version',
  473. 'isVod', 'isExist', 'NotificationMode','is_ap')
  474. uid_user_ls = CommonService.qs_to_list(uid_user_ql)
  475. uid_list = []
  476. for uid_user in uid_user_ls:
  477. uid_list.append(uid_user['UID'])
  478. ubqs = UID_Bucket.objects.filter(uid__in=uid_list). \
  479. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  480. upqs = UID_Preview.objects.filter(uid__in=uid_list).order_by('channel').values('id', 'uid', 'channel')
  481. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  482. bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
  483. nowTime = int(time.time())
  484. data = []
  485. # 设备拓展信息表
  486. us_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'version', 'nickname')
  487. uv_dict = {}
  488. return response.json(0, us_qs)
  489. for us in us_qs:
  490. uv_dict[us['uid']] = {'version': us['version'], 'nickname': us['nickname']}
  491. for p in uid_user_ls:
  492. p['vod'] = []
  493. for dm in ubqs:
  494. if p['UID'] == dm['uid']:
  495. if dm['endTime'] > nowTime:
  496. p['vod'].append(dm)
  497. p['preview'] = []
  498. for up in upqs:
  499. if p['UID'] == up['uid']:
  500. obj = 'uid_preview/{uid}/channel_{channel}.png'.format(uid=up['uid'], channel=up['channel'])
  501. img_sign = bucket.sign_url('GET', obj, 300)
  502. p['preview'].append(img_sign)
  503. p_uid = p['UID']
  504. if p_uid in uv_dict:
  505. # 设备版本号
  506. p['uid_version'] = uv_dict[p_uid]['version']
  507. # 设备昵称
  508. if uv_dict[p_uid]['nickname']:
  509. p['NickName'] = uv_dict[p_uid]['nickname']
  510. else:
  511. # 设备版本号
  512. p['uid_version'] = ''
  513. data.append(p)
  514. return response.json(0, data)
  515. else:
  516. return response.json(tko.code)