DeviceShare.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  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=sharer)
  74. sharerDvqs = Device_Info.objects.get(userID_id=sharer, UID=UID)
  75. sharerDvqs.id = CommonService.getUserID(getUser=False)
  76. sharerDvqs.userID_id = userID
  77. sharerDvqs.isShare = True
  78. sharerDvqs.primaryUserID = sharer
  79. if sharerUser.username:
  80. primaryMaster = sharerUser.username
  81. elif sharerUser.userEmail:
  82. primaryMaster = sharerUser.userEmail
  83. elif sharerUser.phone:
  84. primaryMaster = sharerUser.phone
  85. else:
  86. return response.json(178)
  87. print(primaryMaster)
  88. sharerDvqs.primaryMaster = primaryMaster
  89. sharerDvqs.data_joined = None
  90. sharerDvqs.save()
  91. except Exception as e:
  92. return response.json(10, repr(e))
  93. else:
  94. return response.json(0)
  95. else:
  96. return response.json(174)
  97. else:
  98. return response.json(444, {'param': 'shareToken'})
  99. # 1,这个用户的分享出去的设备
  100. # 2,获得上面个的设备拥有者
  101. # http://192.168.136.39:8000/deviceShare/queryEq?token=XXX&UID=jLBDSU9547NTRSMF111A
  102. def do_query_user(self, userID, request_dict, response):
  103. UID = request_dict.get('UID', None)
  104. if UID is not None:
  105. # 查询分享获得的用户
  106. qs = Device_Info.objects.filter(UID=UID, isShare=True, primaryUserID=userID). \
  107. values('userID__NickName', 'userID__username', 'userID__userEmail', 'userID__phone', 'id')
  108. data = []
  109. # print(qs)
  110. for q in qs:
  111. d = {'id': q['id']}
  112. if q['userID__NickName']:
  113. d['user'] = q['userID__NickName']
  114. elif q['userID__username']:
  115. d['user'] = q['userID__username']
  116. elif q['userID__userEmail']:
  117. d['user'] = q['userID__userEmail']
  118. elif q['userID__phone']:
  119. d['user'] = q['userID__phone']
  120. data.append(d)
  121. return response.json(0, data)
  122. else:
  123. return response.json(444, {'param': 'UID'})
  124. def do_delete_user(self, userID, request_dict, response):
  125. id = request_dict.get('id', None)
  126. if id:
  127. try:
  128. Device_Info.objects.filter(id=id, primaryUserID=userID).update(isExist=0)
  129. except Exception as e:
  130. return response.json(10, repr(e))
  131. else:
  132. return response.json(0)
  133. else:
  134. return response.json(444, 'id')