DeviceShare.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  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/3/4 16:30
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: DeviceShare.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. from django.views.generic.base import View
  15. from Model.models import Device_Info, Device_User
  16. from Object.ResponseObject import ResponseObject
  17. from Object.TokenObject import TokenObject
  18. from Ansjer.config import SERVER_DOMAIN
  19. import jwt
  20. from Service.CommonService import CommonService
  21. class DeviceShareView(View):
  22. def get(self, request, *args, **kwargs):
  23. request.encoding = 'utf-8'
  24. operation = kwargs.get('operation')
  25. return self.validation(request.GET, operation)
  26. def post(self, request, *args, **kwargs):
  27. request.encoding = 'utf-8'
  28. operation = kwargs.get('operation')
  29. return self.validation(request.POST, operation)
  30. def validation(self, request_dict, operation):
  31. response = ResponseObject()
  32. token = request_dict.get('token', None)
  33. if token:
  34. tko = TokenObject(token)
  35. if tko.code == 0:
  36. userID = tko.userID
  37. if operation == 'generateTokenUrl':
  38. return self.do_generate_token_url(userID, request_dict, response)
  39. elif operation == 'confirm':
  40. return self.do_confirm(userID, request_dict, response)
  41. elif operation == 'queryUser':
  42. return self.do_query_user(userID, request_dict, response)
  43. elif operation == 'deleteUser':
  44. return self.do_delete_user(userID, request_dict, response)
  45. else:
  46. return response.json(414)
  47. else:
  48. return response.json(tko.code)
  49. else:
  50. return response.json(444, {'param': 'token'})
  51. def do_generate_token_url(self, userID, request_dict, response):
  52. UID = request_dict.get('UID', None)
  53. dvqs = Device_Info.objects.filter(UID=UID, userID_id=userID, isShare=False)
  54. if dvqs.exists():
  55. import time
  56. data = {'sharer': userID, 'UID': UID}
  57. share_token = jwt.encode(data, 'jwt.#^^&', algorithm='HS256')
  58. share_url = '{SERVER_DOMAIN}deviceShare/confirm?shareToken={shareToken}' \
  59. .format(SERVER_DOMAIN=SERVER_DOMAIN, shareToken=share_token.decode('utf-8'))
  60. return response.json(0, {'share_url': share_url})
  61. else:
  62. return response.json(173)
  63. def do_confirm(self, userID, request_dict, response):
  64. shareToken = request_dict.get('shareToken', None)
  65. if shareToken is not None:
  66. data = jwt.decode(shareToken, 'jwt.#^^&', algorithms='HS256')
  67. # 分享者userID
  68. sharer = data.get('sharer', None)
  69. # 分享的uid
  70. UID = data.get('UID', None)
  71. dval = Device_Info.objects.filter(userID_id=userID, UID=UID)
  72. if not dval.exists():
  73. try:
  74. sharerUser = Device_User.objects.get(userID=sharer)
  75. sharerDvqs = Device_Info.objects.get(userID_id=sharer, UID=UID)
  76. sharerDvqs.id = CommonService.getUserID(getUser=False)
  77. sharerDvqs.userID_id = userID
  78. sharerDvqs.isShare = True
  79. sharerDvqs.primaryUserID = sharer
  80. if sharerUser.username:
  81. primaryMaster = sharerUser.username
  82. elif sharerUser.userEmail:
  83. primaryMaster = sharerUser.userEmail
  84. elif sharerUser.phone:
  85. primaryMaster = sharerUser.phone
  86. else:
  87. return response.json(178)
  88. print(primaryMaster)
  89. sharerDvqs.primaryMaster = primaryMaster
  90. sharerDvqs.data_joined = None
  91. sharerDvqs.save()
  92. except Exception as e:
  93. return response.json(10, repr(e))
  94. else:
  95. return response.json(0)
  96. else:
  97. return response.json(174)
  98. else:
  99. return response.json(444, {'param': 'shareToken'})
  100. # 1,这个用户的分享出去的设备
  101. # 2,获得上面个的设备拥有者
  102. # http://192.168.136.39:8000/deviceShare/queryEq?token=XXX&UID=jLBDSU9547NTRSMF111A
  103. def do_query_user(self, userID, request_dict, response):
  104. UID = request_dict.get('UID', None)
  105. if UID is not None:
  106. # 查询分享获得的用户
  107. qs = Device_Info.objects.filter(UID=UID, isShare=True, primaryUserID=userID). \
  108. values('userID__NickName', 'userID__username', 'userID__userEmail', 'userID__phone', 'id')
  109. data = []
  110. # print(qs)
  111. for q in qs:
  112. d = {'id': q['id']}
  113. if q['userID__NickName']:
  114. d['user'] = q['userID__NickName']
  115. elif q['userID__username']:
  116. d['user'] = q['userID__username']
  117. elif q['userID__userEmail']:
  118. d['user'] = q['userID__userEmail']
  119. elif q['userID__phone']:
  120. d['user'] = q['userID__phone']
  121. data.append(d)
  122. return response.json(0, data)
  123. else:
  124. return response.json(444, {'param': 'UID'})
  125. def do_delete_user(self, userID, request_dict, response):
  126. id = request_dict.get('id', None)
  127. if id:
  128. try:
  129. Device_Info.objects.filter(id=id, primaryUserID=userID).update(isExist=0)
  130. except Exception as e:
  131. return response.json(10, repr(e))
  132. else:
  133. return response.json(0)
  134. else:
  135. return response.json(444, 'id')