DeviceShare.py 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  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. data = {'sharer': userID, 'UID': UID}
  56. share_token = jwt.encode(data, 'jwt.#^^&', algorithm='HS256')
  57. share_url = '{SERVER_DOMAIN}deviceShare/confirm?shareToken={shareToken}' \
  58. .format(SERVER_DOMAIN=SERVER_DOMAIN, shareToken=share_token.decode('utf-8'))
  59. return response.json(0, {'share_url': share_url})
  60. else:
  61. return response.json(173)
  62. def do_confirm(self, userID, request_dict, response):
  63. shareToken = request_dict.get('shareToken', None)
  64. if shareToken is not None:
  65. data = jwt.decode(shareToken, 'jwt.#^^&', algorithms='HS256')
  66. # 分享者userID
  67. sharer = data.get('sharer', None)
  68. # 分享的uid
  69. UID = data.get('UID', None)
  70. dval = Device_Info.objects.filter(userID_id=userID, UID=UID)
  71. if not dval.exists():
  72. try:
  73. sharerUser = Device_User.objects.get(userID=userID)
  74. sharerDvqs = Device_Info.objects.get(userID_id=sharer, UID=UID)
  75. except Exception as e:
  76. return response.json(10, repr(e))
  77. else:
  78. sharerDvqs.id = CommonService.getUserID(getUser=False)
  79. sharerDvqs.userID_id = userID
  80. sharerDvqs.isShare = True
  81. sharerDvqs.primaryUserID = sharer
  82. if sharerUser.username:
  83. primaryMaster = sharerUser.username
  84. elif sharerUser.userEmail:
  85. primaryMaster = sharerUser.userEmail
  86. elif sharerUser.phone:
  87. primaryMaster = sharerUser.phone
  88. else:
  89. return response.json(178)
  90. sharerDvqs.primaryMaster = primaryMaster
  91. sharerDvqs.data_joined = None
  92. sharerDvqs.save()
  93. return response.json(0)
  94. else:
  95. return response.json(174)
  96. else:
  97. return response.json(444, {'param': 'shareToken'})
  98. # 1,这个用户的分享出去的设备
  99. # 2,获得上面个的设备拥有者
  100. # http://192.168.136.39:8000/deviceShare/queryEq?token=XXX&UID=jLBDSU9547NTRSMF111A
  101. def do_query_user(self, userID, request_dict, response):
  102. UID = request_dict.get('UID', None)
  103. if UID is not None:
  104. # 查询分享获得的用户
  105. qs = Device_Info.objects.filter(UID=UID, isShare=True, primaryUserID=userID). \
  106. values('userID__NickName',
  107. 'userID__username',
  108. 'userID__userEmail',
  109. 'userID__phone',
  110. 'id')
  111. data = []
  112. for q in qs:
  113. d = {'id': q['id']}
  114. if not q['userID_NickName']:
  115. d['user'] = q['userID_NickName']
  116. elif not q['userID__username']:
  117. d['user'] = q['userID__username']
  118. elif not q['userID__userEmail']:
  119. d['user'] = q['userID__userEmail']
  120. elif not q['userID__phone']:
  121. d['user'] = q['userID__phone']
  122. data.append(d)
  123. return response.json(0, data)
  124. else:
  125. return response.json(444, {'param': 'UID'})
  126. def do_delete_user(self, userID, request_dict, response):
  127. id = request_dict.get('id', None)
  128. if id:
  129. try:
  130. Device_Info.objects.filter(id=id, primaryUserID=userID).delete()
  131. except Exception as e:
  132. return response.json(10, repr(e))
  133. else:
  134. return response.json(0)
  135. else:
  136. return response.json(444, 'id')