ShadowController.py 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  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: AnsjerPush
  7. @software: PyCharm
  8. @DATE: 2020/2/14 13:54
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: ShadowController.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. # 测试环境
  15. # test.shadow.dvema.com
  16. # 生产环境
  17. # shadow.dvema.com
  18. # 设备影子更新
  19. import logging
  20. import threading
  21. import time
  22. from ratelimit.decorators import ratelimit
  23. import requests
  24. from django.http import JsonResponse
  25. from AnsjerPush.config import SERVER_TYPE
  26. from Model.models import Device_Info, UidSetModel, UID_Preview, VoicePromptModel, UID_Bucket, UidChannelSetModel, \
  27. AiService
  28. from Object.ETkObject import ETkObject
  29. from Object.ResponseObject import ResponseObject
  30. from Service.CommonService import CommonService
  31. def generate_utk(request):
  32. request.encoding = 'utf-8'
  33. response = ResponseObject()
  34. if request.method == 'GET':
  35. request_dict = request.GET
  36. elif request.method == 'POST':
  37. request_dict = request.POST
  38. else:
  39. return response.json(444, 'wrong method')
  40. username = request_dict.get('username', None)
  41. password = request_dict.get('password', None)
  42. uid = request_dict.get('uid', None)
  43. if username and password:
  44. if username == 'debug_user' and password == 'debug_password':
  45. # utko = UidTokenObject()
  46. # # right
  47. # utko.generate(data={'uid': uid})
  48. etkObj = ETkObject(etk='')
  49. etk = etkObj.encrypt(uid)
  50. return response.json(0, {'etk': etk})
  51. else:
  52. return response.json(404)
  53. else:
  54. return response.json(444, 'username password')
  55. # 设备影子更新
  56. @ratelimit(key='ip', rate='1/h', block=True)
  57. def update_device_shadow(request):
  58. request.encoding = 'utf-8'
  59. response = ResponseObject()
  60. if request.method == 'POST':
  61. request_dict = request.POST
  62. elif request.method == 'GET':
  63. request_dict = request.GET
  64. else:
  65. return response.json(444)
  66. logger = logging.getLogger('info')
  67. try:
  68. asy = threading.Thread(target=async_device_shadow,
  69. args=(request_dict, request))
  70. asy.start()
  71. return JsonResponse(status=200, data={'code': 0, 'msg': 'success', 'data': {}})
  72. except Exception as e:
  73. logger.info('更新设备影子异常: {}'.format(repr(e)))
  74. return JsonResponse(status=200, data={'code': 0, 'update_shadow_error': repr(e)})
  75. def async_device_shadow(request_dict, request):
  76. try:
  77. logger = logging.getLogger('info')
  78. etk = request_dict.get('etk', None)
  79. eto = ETkObject(etk)
  80. uid = eto.uid
  81. if not uid:
  82. return False
  83. logger.info('使用配置: {}'.format(SERVER_TYPE))
  84. logger.info('data: {}'.format(request_dict.dict()))
  85. if SERVER_TYPE != 'Ansjer.test_settings':
  86. if SERVER_TYPE != 'Ansjer.cn_formal_settings': # 同步更新国内数据
  87. requests.post(url='http://shadow.zositechc.cn/deviceShadow/update', data=request_dict.dict(), timeout=2)
  88. nowTime = int(time.time())
  89. # 重置按钮
  90. is_reset = request_dict.get('is_reset', None)
  91. # 传1则重置设备信息
  92. if is_reset == '1':
  93. logger.info('设备重置: {}'.format(uid))
  94. # 重置语音提示
  95. uid_channel_qs = UidChannelSetModel.objects.filter(uid__uid=uid)
  96. if uid_channel_qs.exists():
  97. uid_channel_qs.update(voice_prompt_intelligent_mute=0, voice_prompt_status=0, voice_prompt_enter=0,
  98. voice_prompt_leave=0, voice_repeat_day=127, voice_start_time=0, voice_end_time=0,
  99. voice_start_x=0, voice_start_y=18, voice_end_x=44, voice_end_y=18,
  100. voice_direction=0)
  101. # 购买云存套餐的设备isExist置为2
  102. uid_bucket = UID_Bucket.objects.filter(uid=uid, endTime__gte=nowTime).values('id', 'has_unused').order_by(
  103. 'addTime')
  104. if not uid_bucket.exists():
  105. Device_Info.objects.filter(UID=uid).update(isExist=2)
  106. # 删除预览图
  107. uid_pre_qs = UID_Preview.objects.filter(uid=uid)
  108. if uid_pre_qs.exists():
  109. uid_pre_qs.delete()
  110. # 删除语音提示
  111. voice_qs = VoicePromptModel.objects.filter(uid=uid)
  112. if voice_qs.exists():
  113. voice_qs.delete()
  114. # 关闭移动侦测的消息提醒
  115. Device_Info.objects.filter(UID=uid).update(NotificationMode=0)
  116. # 关闭AI
  117. AiService.objects.filter(uid=uid, use_status=1).update(detect_status=0, detect_group='')
  118. logger.info('{}重置成功'.format(uid))
  119. ucode = request_dict.get('ucode', None)
  120. version = request_dict.get('version', None)
  121. p2p_region = request_dict.get('p2p_region', None)
  122. tz = request_dict.get('tz', None)
  123. video_code = request_dict.get('video_code', None)
  124. ip = CommonService.get_ip_address(request)
  125. channel = request_dict.get('channel', None)
  126. cloud_vod = request_dict.get('cloud_vod', None)
  127. push_status = request_dict.get('push_status', None)
  128. pwd = request_dict.get('pwd', None)
  129. is_alexa = request_dict.get('is_alexa', None)
  130. is_human = request_dict.get('is_human', None)
  131. is_custom_voice = request_dict.get('is_custom', None)
  132. double_wifi = request_dict.get('double_wifi', None)
  133. mobile_4g = request_dict.get('mobile4G', None)
  134. is_ptz = request_dict.get('is_ptz', None)
  135. is_ai = request_dict.get('is_ai', None)
  136. # 更新
  137. qs_dict = {
  138. 'updTime': nowTime,
  139. 'ip': ip
  140. }
  141. if channel:
  142. qs_dict['channel'] = channel
  143. if p2p_region:
  144. qs_dict['p2p_region'] = p2p_region
  145. if ucode:
  146. qs_dict['ucode'] = ucode
  147. if version:
  148. qs_dict['version'] = version
  149. if tz:
  150. qs_dict['tz'] = tz
  151. if video_code:
  152. qs_dict['video_code'] = video_code
  153. if cloud_vod:
  154. qs_dict['cloud_vod'] = cloud_vod
  155. if push_status:
  156. # 复位重置推送消息提醒
  157. qs_dict['detect_status'] = 0 if is_reset == '1' else push_status
  158. if pwd:
  159. qs_dict['pwd'] = pwd
  160. if is_human:
  161. qs_dict['is_human'] = is_human
  162. if is_custom_voice:
  163. qs_dict['is_custom_voice'] = is_custom_voice
  164. if double_wifi:
  165. qs_dict['double_wifi'] = double_wifi
  166. if mobile_4g:
  167. qs_dict['mobile_4g'] = int(mobile_4g)
  168. if is_ptz:
  169. qs_dict['is_ptz'] = is_ptz
  170. if is_ai:
  171. qs_dict['is_ai'] = is_ai
  172. logger.info('{} qs_dict: {}'.format(uid, qs_dict))
  173. us_qs = UidSetModel.objects.filter(uid=uid)
  174. if us_qs.exists():
  175. if is_alexa and us_qs[0].is_alexa == 0:
  176. qs_dict['is_alexa'] = is_alexa
  177. us_qs.update(**qs_dict)
  178. # 新增
  179. else:
  180. if is_alexa:
  181. qs_dict['is_alexa'] = is_alexa
  182. qs_dict['uid'] = uid
  183. qs_dict['addTime'] = nowTime
  184. UidSetModel.objects.create(**qs_dict)
  185. logger.info('***设备影子保存成功{}'.format(uid))
  186. except Exception as e:
  187. print(repr(e))
  188. print('异步保存设备影子信息报错,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))