ShadowController.py 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. import json
  2. import time
  3. from django.http import JsonResponse
  4. from Ansjer.config import SERVER_TYPE, LOGGER, CONFIG_INFO, CONFIG_CN
  5. from Model.models import Device_Info, UidSetModel, UID_Preview, VoicePromptModel, UidChannelSetModel, \
  6. AiService, CountryModel, CityInformation, IPAddr, LogModel
  7. from Object.ETkObject import ETkObject
  8. from Object.RedisObject import RedisObject
  9. from Service.CommonService import CommonService
  10. from Object.IPWeatherObject import IPQuery, GeoIP2
  11. # 更新设备影子
  12. def update_device_shadow(request):
  13. request.encoding = 'utf-8'
  14. if request.method == 'POST':
  15. request_dict = request.POST
  16. elif request.method == 'GET':
  17. request_dict = request.GET
  18. else:
  19. return JsonResponse(status=200, data={'code': 0, 'msg': 'success', 'data': {}})
  20. LOGGER.info('---更新设备影子---,使用配置:{}, 参数:{}'.format(SERVER_TYPE,
  21. json.dumps(request_dict.dict())))
  22. # redis加锁
  23. redis_obj = RedisObject()
  24. redis_key = None
  25. try:
  26. etk = request_dict.get('etk', None)
  27. eto = ETkObject(etk)
  28. uid = eto.uid
  29. if not uid:
  30. return JsonResponse(status=200, data={'code': 400001, 'msg': 'The UID length or format is incorrect.',
  31. 'data': {}})
  32. nowTime = int(time.time())
  33. ip = CommonService.get_ip_address(request)
  34. # 重置按钮
  35. is_reset = request_dict.get('is_reset', None)
  36. # 传1则重置设备信息
  37. if is_reset == '1':
  38. LOGGER.info('设备重置: {}'.format(uid))
  39. # 重置语音提示
  40. uid_channel_qs = UidChannelSetModel.objects.filter(uid__uid=uid)
  41. if uid_channel_qs.exists():
  42. uid_channel_qs.update(voice_prompt_intelligent_mute=0, voice_prompt_status=0, voice_prompt_enter=0,
  43. voice_prompt_leave=0, voice_repeat_day=127, voice_start_time=0, voice_end_time=0,
  44. voice_start_x=0, voice_start_y=18, voice_end_x=44, voice_end_y=18,
  45. voice_direction=0)
  46. # 删除预览图
  47. uid_pre_qs = UID_Preview.objects.filter(uid=uid)
  48. if uid_pre_qs.exists():
  49. uid_pre_qs.delete()
  50. # 删除语音提示
  51. voice_qs = VoicePromptModel.objects.filter(uid=uid)
  52. if voice_qs.exists():
  53. voice_qs.delete()
  54. # 关闭移动侦测推送
  55. UidSetModel.objects.filter(uid=uid).update(detect_status=0)
  56. Device_Info.objects.filter(UID=uid).update(NotificationMode=0)
  57. # 关闭AI
  58. AiService.objects.filter(uid=uid, use_status=1).update(detect_status=0, detect_group='')
  59. LOGGER.info('{}v2重置成功'.format(uid))
  60. # 更新ip信息
  61. update_ip_info(ip, uid)
  62. else:
  63. redis_key = f"DEVICE:UPDATE:SHADOW:{uid}"
  64. is_lock = redis_obj.CONN.set(redis_key, value=1, nx=True, ex=60)
  65. if not is_lock:
  66. return JsonResponse(status=200, data={'code': 5, 'msg': 'Please try again one minute later!',
  67. 'data': {}})
  68. ucode = request_dict.get('ucode', None)
  69. version = request_dict.get('version', None)
  70. p2p_region = request_dict.get('p2p_region', None)
  71. tz = request_dict.get('tz', None)
  72. video_code = request_dict.get('video_code', None)
  73. channel = request_dict.get('channel', None)
  74. cloud_vod = request_dict.get('cloud_vod', None)
  75. push_status = request_dict.get('push_status', None)
  76. pwd = request_dict.get('pwd', None)
  77. is_alexa = request_dict.get('is_alexa', None)
  78. is_human = request_dict.get('is_human', None)
  79. is_custom_voice = request_dict.get('is_custom', None)
  80. double_wifi = request_dict.get('double_wifi', None)
  81. mobile_4g = request_dict.get('mobile4G', None)
  82. is_ptz = request_dict.get('is_ptz', None)
  83. is_ai = request_dict.get('is_ai', None)
  84. ai_type = request_dict.get('AiType', None)
  85. isSupportFourPoint = request_dict.get('isSupportFourPoint', None)
  86. # 更新
  87. qs_dict = {
  88. 'updTime': nowTime,
  89. 'ip': ip
  90. }
  91. if channel:
  92. qs_dict['channel'] = channel
  93. if p2p_region:
  94. qs_dict['p2p_region'] = p2p_region
  95. if ucode:
  96. qs_dict['ucode'] = ucode
  97. if version:
  98. qs_dict['version'] = version
  99. if tz:
  100. qs_dict['tz'] = tz
  101. if video_code:
  102. qs_dict['video_code'] = video_code
  103. if cloud_vod:
  104. qs_dict['cloud_vod'] = cloud_vod
  105. if push_status:
  106. # 复位重置推送消息提醒
  107. qs_dict['detect_status'] = 0 if is_reset == '1' else push_status
  108. if pwd:
  109. qs_dict['pwd'] = pwd
  110. if is_human:
  111. qs_dict['is_human'] = is_human
  112. if is_custom_voice:
  113. qs_dict['is_custom_voice'] = is_custom_voice
  114. if double_wifi:
  115. qs_dict['double_wifi'] = double_wifi
  116. if mobile_4g:
  117. qs_dict['mobile_4g'] = int(mobile_4g)
  118. if is_ptz:
  119. qs_dict['is_ptz'] = is_ptz
  120. if is_ai:
  121. qs_dict['is_ai'] = is_ai
  122. if isSupportFourPoint:
  123. qs_dict['isSupportFourPoint'] = isSupportFourPoint
  124. if ai_type:
  125. qs_dict['ai_type'] = ai_type
  126. ipInfo = CommonService.getIpIpInfo(ip, 'CN')
  127. country_qs = CountryModel.objects.filter(country_code=ipInfo['country_code']).values('id')
  128. if country_qs.exists():
  129. country = country_qs[0]['id']
  130. qs_dict['tb_country'] = country
  131. LOGGER.info('{} qs_dict: {}'.format(uid, qs_dict))
  132. save_ip_info(ip, qs_dict)
  133. us_qs = UidSetModel.objects.filter(uid=uid)
  134. if us_qs.exists():
  135. if is_alexa and us_qs[0].is_alexa == 0:
  136. qs_dict['is_alexa'] = is_alexa
  137. us_qs.update(**qs_dict)
  138. # 新增
  139. else:
  140. if is_alexa:
  141. qs_dict['is_alexa'] = is_alexa
  142. qs_dict['uid'] = uid
  143. qs_dict['addTime'] = nowTime
  144. UidSetModel.objects.create(**qs_dict)
  145. # 记录操作日志
  146. content = json.loads(json.dumps(request_dict))
  147. log = {
  148. 'ip': ip,
  149. 'user_id': 1,
  150. 'status': 200,
  151. 'time': nowTime,
  152. 'content': json.dumps(content),
  153. 'url': 'deviceShadow/updateV2',
  154. 'operation': f'{uid}更新设备影子',
  155. }
  156. LogModel.objects.create(**log)
  157. if redis_key:
  158. redis_obj.del_data(redis_key)
  159. return JsonResponse(status=200, data={'code': 0, 'msg': 'success', 'data': {}})
  160. except Exception as e:
  161. if redis_key:
  162. redis_obj.del_data(redis_key)
  163. LOGGER.info('更新设备影子异常: errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  164. return JsonResponse(status=200, data={'code': 1000001, 'update_shadow_error': repr(e)})
  165. def save_ip_info(ip, qs_dict):
  166. """
  167. 保存ip信息
  168. 根据服务器配置使用不同的服务, 国内:阿里云, 测试,国外:geoip2
  169. @param ip:
  170. @param qs_dict:
  171. @return:
  172. """
  173. if CONFIG_INFO == CONFIG_CN:
  174. # 查询ip区级信息
  175. district = get_district(ip)
  176. city_information_qs = CityInformation.objects.filter(district=district).values('city_id')
  177. if city_information_qs.exists():
  178. city_id = city_information_qs[0]['city_id']
  179. qs_dict['tb_city_information_id'] = city_id
  180. else:
  181. ip_addr_qs = IPAddr.objects.filter(ip=ip, is_geoip2=True)
  182. if not ip_addr_qs.exists():
  183. GeoIP2(ip)
  184. def update_ip_info(ip, uid):
  185. """
  186. 更新ip信息
  187. 根据服务器配置使用不同的服务, 国内:阿里云, 测试,国外:geoip2
  188. @param ip:
  189. @param uid:
  190. @return:
  191. """
  192. if CONFIG_INFO == CONFIG_CN:
  193. # 和新ip的city_id不一致,更新tb_city_information_id
  194. uid_set_qs = UidSetModel.objects.filter(uid=uid).values('ip', 'tb_city_information_id')
  195. if uid_set_qs.exists():
  196. # 查询ip区级信息
  197. district = get_district(ip)
  198. city_information_qs = CityInformation.objects.filter(district=district).values('city_id')
  199. if city_information_qs.exists():
  200. city_id = city_information_qs[0]['city_id']
  201. if uid_set_qs[0]['tb_city_information_id'] != city_id:
  202. uid_set_qs.update(tb_city_information_id=city_id)
  203. else:
  204. ip_addr_qs = IPAddr.objects.filter(ip=ip, is_geoip2=True)
  205. if not ip_addr_qs.exists():
  206. GeoIP2(ip)
  207. def get_district(ip):
  208. ip_addr_qs = IPAddr.objects.filter(ip=ip, is_geoip2=False).values('district', 'city')
  209. if ip_addr_qs.exists():
  210. district = ip_addr_qs[0]['district']
  211. city = ip_addr_qs[0]['city']
  212. # 区级信息为空或city_information表查询不到区级信息,使用城市数据
  213. if district == '':
  214. district = city
  215. else:
  216. city_information_qs = CityInformation.objects.filter(district=district)
  217. if not city_information_qs.exists():
  218. city_qs = CityInformation.objects.filter(district=city)
  219. if city_qs.exists():
  220. district = city
  221. else:
  222. ip_qs = IPQuery(ip)
  223. district = ip_qs.district
  224. return district