deviceStatus.py 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. """
  5. import json
  6. import time
  7. import requests
  8. import uuid
  9. import logging
  10. from django.views.generic import TemplateView
  11. from django.shortcuts import render_to_response
  12. from django.http import JsonResponse
  13. import http.client
  14. from urllib.parse import urlencode
  15. from object.ResObject import ResObject
  16. import subprocess
  17. # from gevent.pool import Pool
  18. from model.models import UserModel,UidRtspModel
  19. from object.ResponseObject import ResponseObject
  20. from object.tkObject import tkObject
  21. from service.CommonService import CommonService
  22. from model.models import AlexaAuthModel
  23. from object.RedisObject import RedisObject
  24. from django.utils.decorators import method_decorator
  25. from django.views.decorators.csrf import csrf_exempt
  26. rtspServer = "rtsp.zositech.org,3.16.66.144"
  27. class deviceStatus(TemplateView):
  28. @method_decorator(csrf_exempt)
  29. def dispatch(self, *args, **kwargs):
  30. return super(deviceStatus, self).dispatch(*args, **kwargs)
  31. def get(self, request, *args, **kwargs):
  32. request.encoding = 'utf-8'
  33. operation = kwargs.get('operation')
  34. return self.validation(request.GET, request, operation)
  35. def post(self, request, *args, **kwargs):
  36. request.encoding = 'utf-8'
  37. operation = kwargs.get('operation')
  38. return self.validation(request.POST, request, operation)
  39. def validation(self, request_dict, request, operation):
  40. response = ResponseObject()
  41. if operation is None:
  42. return JsonResponse({'code':404,'msg':'not found'})
  43. if operation == 'saveAccessToken':
  44. return self.saveAccessToken(request_dict, response)
  45. if operation == 'addOrUpdate':
  46. return self.addOrUpdate(request_dict, response)
  47. if operation == 'delete':
  48. return self.delete(request_dict, response)
  49. elif operation == 'test':
  50. return self.discover(request_dict, response)
  51. def saveAccessToken(self,request_dict, response):
  52. access_token = request_dict.get("access_token", '')
  53. refresh_token = request_dict.get("refresh_token", '')
  54. token = request_dict.get("token", '')
  55. logger = logging.getLogger('django')
  56. logger.info('login-------------begin---token')
  57. logger.info(access_token)
  58. logger.info(refresh_token)
  59. alexAuth = AlexaAuthModel.objects.filter(token=token)
  60. nowTime = int(time.time())
  61. if not alexAuth.exists():
  62. AlexaAuthModel.objects.create(
  63. access_token = access_token,
  64. refresh_token = refresh_token,
  65. token = token,
  66. expiresTime = nowTime + 3200,
  67. addTime=nowTime,
  68. updTime=nowTime)
  69. else:
  70. alexAuth.update(
  71. access_token = access_token,
  72. refresh_token = refresh_token,
  73. expiresTime = nowTime + 3200,
  74. token = token,
  75. updTime=nowTime
  76. )
  77. return JsonResponse({'code':200,'msg':'success'})
  78. def discover(self,request_dict, response):
  79. userID = 158943604783713800138000
  80. token = 'cGSOD01pi2BICtGd1SVdjegwrVKV1Kmn'
  81. alexAuth = AlexaAuthModel.objects.filter(token=token)
  82. if not alexAuth.exists():
  83. return JsonResponse({'code':200,'msg':'fail'})
  84. else:
  85. res = alexAuth.values()
  86. access_token = res[0]['access_token']
  87. refresh_token = res[0]['refresh_token']
  88. token = res[0]['token']
  89. return JsonResponse({'code':200,'msg':res[0]['access_token']})
  90. def addOrUpdate(self,request_dict, response):
  91. UID = request_dict.get("UID", '')
  92. userID = request_dict.get("userID", '')
  93. uid_nick = request_dict.get("uid_nick", '')
  94. if UID != '' and userID != '' and uid_nick != '':
  95. return JsonResponse({'code':200,'msg':'success'})
  96. else:
  97. return JsonResponse({'code':200,'msg':'fail'})
  98. access_token = 'xx'
  99. api_uri = 'https://api.amazonalexa.com/v3/events'
  100. messageId = str(uuid.uuid4())
  101. access_token = access_token
  102. bearer_access_token = 'Bearer {access_token}'.format(access_token=access_token)
  103. headers = {'content-type': "application/json", 'Authorization': bearer_access_token}
  104. payload = {
  105. "event": {
  106. "header": {
  107. "namespace": "Alexa.Discovery",
  108. "name": "AddOrUpdateReport",
  109. "payloadVersion": "3",
  110. "messageId": messageId
  111. },
  112. "payload": {
  113. "endpoints": [
  114. {
  115. "endpointId": UID,
  116. "manufacturerName": "zosi smart",
  117. "description": "Camera connected via zosi smart",
  118. "friendlyName": uid_nick,
  119. "displayCategories": [
  120. "CAMERA"
  121. ],
  122. "capabilities": [
  123. {
  124. "type": "AlexaInterface",
  125. "interface": "Alexa.CameraStreamController",
  126. "version": "3",
  127. "cameraStreamConfigurations": [
  128. {
  129. "protocols": ["RTSP"],
  130. "resolutions": [{"width": 1280, "height": 720}],
  131. "authorizationTypes": ["NONE"],
  132. "videoCodecs": ["H264"],
  133. "audioCodecs": ["ACC"]
  134. }]
  135. },
  136. {
  137. "type": "AlexaInterface",
  138. "interface": "Alexa.MediaMetadata",
  139. "version": "3",
  140. "proactivelyReported": True,
  141. # "retrievable": True
  142. }
  143. ]
  144. }
  145. ],
  146. "scope": {
  147. "type": "BearerToken",
  148. "token": access_token
  149. }
  150. }
  151. }
  152. }
  153. response = requests.post(api_uri, data = payload, headers = headers)
  154. request_json = response.json()
  155. return JsonResponse({'res': request_json})
  156. def delete(self,request_dict, response):
  157. UID = request_dict.get("UID", '')
  158. if UID != '':
  159. return JsonResponse({'code':200,'msg':'success'})
  160. else:
  161. return JsonResponse({'code':200,'msg':'fail'})
  162. def post_to_api(self, payload):
  163. connection = http.client.HTTPSConnection("api.amazon.com")
  164. headers = {
  165. 'content-type': "application/x-www-form-urlencoded",
  166. 'cache-control': "no-cache"
  167. }
  168. response = requests.post('https://api.amazon.com/auth/o2/token', urlencode(payload), headers= headers, allow_redirects=True)
  169. request_json = response.json()
  170. return JsonResponse({'res': request_json})