gatewayController.py 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. # -*- coding: utf-8 -*-
  2. """
  3. @Author : Rocky
  4. @Time : 2022/5/9 10:51
  5. @File :gatewayController.py
  6. """
  7. import logging
  8. import time
  9. from django.views.generic.base import View
  10. from Model.models import SensorRecord, GatewaySubDevice, GatewayPush, Device_Info
  11. from Object.ResponseObject import ResponseObject
  12. from Object.utils import LocalDateTimeUtil
  13. from Service.CommonService import CommonService
  14. from Service.EquipmentInfoService import EquipmentInfoService
  15. from Service.GatewayService import GatewayPushService
  16. class GatewayView(View):
  17. def get(self, request, *args, **kwargs):
  18. request.encoding = 'utf-8'
  19. operation = kwargs.get('operation')
  20. return self.validation(request.GET, operation)
  21. def post(self, request, *args, **kwargs):
  22. request.encoding = 'utf-8'
  23. operation = kwargs.get('operation')
  24. return self.validation(request.POST, operation)
  25. def validation(self, request_dict, operation):
  26. response = ResponseObject()
  27. if operation == 'gatewayPush': # 网关推送
  28. return self.gateway_push(request_dict, response)
  29. else:
  30. return response.json(414)
  31. @staticmethod
  32. def gateway_push(request_dict, response):
  33. """
  34. 网关推送
  35. @param request_dict: 请求参数
  36. @request_dict serial_number: 序列号
  37. @request_dict ieee_addr: 长地址
  38. @request_dict src_addr: 短地址
  39. @request_dict sensor_type: 传感器类型
  40. @request_dict event_type: 事件类型
  41. @request_dict alarm: 消息内容
  42. @param response: 响应对象
  43. @return: response
  44. """
  45. logger = logging.getLogger('info')
  46. serial_number = request_dict.get('serial_number', None)
  47. ieee_addr = request_dict.get('ieee_addr', None)
  48. src_addr = request_dict.get('src_addr', None)
  49. sensor_type = int(request_dict.get('sensor_type', None))
  50. event_type = int(request_dict.get('event_type', None))
  51. alarm = request_dict.get('alarm', None)
  52. logger.info('---调用网关推送接口--- request_dict:{}'.format(request_dict))
  53. if not all([serial_number, ieee_addr, src_addr, sensor_type, event_type, alarm]):
  54. return response.json(444)
  55. n_time = int(time.time())
  56. try:
  57. nickname = serial_number
  58. # 查询子设备表id
  59. gateway_sub_device_qs = GatewaySubDevice.objects.filter(device__serial_number=serial_number,
  60. device_type=sensor_type, ieee_addr=ieee_addr,
  61. src_addr=src_addr).values('id', 'nickname')
  62. if gateway_sub_device_qs.exists():
  63. gateway_sub_device_id = gateway_sub_device_qs[0]['id']
  64. nickname = gateway_sub_device_qs[0]['nickname']
  65. # 写入传感器记录数据
  66. SensorRecord.objects.create(gateway_sub_device_id=gateway_sub_device_id, alarm=alarm,
  67. event_type=event_type, created_time=n_time)
  68. device_info_qs = Device_Info.objects.filter(serial_number=serial_number).values('userID_id')
  69. if not device_info_qs.exists():
  70. return response.json(173)
  71. local_date_time = ''
  72. equipment_info_list = []
  73. for device_info in device_info_qs:
  74. user_id = device_info['userID_id']
  75. # 查询推送配置数据
  76. gateway_push_qs = GatewayPush.objects.filter(user_id=user_id, logout=False). \
  77. values('user_id', 'app_bundle_id', 'app_type', 'push_type', 'token_val', 'm_code', 'lang', 'm_code',
  78. 'tz')
  79. if not gateway_push_qs.exists():
  80. continue
  81. kwargs = {
  82. 'n_time': n_time,
  83. 'event_type': event_type,
  84. 'nickname': nickname,
  85. }
  86. user_id = gateway_push_qs[0]['user_id']
  87. app_bundle_id = gateway_push_qs[0]['app_bundle_id']
  88. push_type = gateway_push_qs[0]['push_type']
  89. token_val = gateway_push_qs[0]['token_val']
  90. lang = gateway_push_qs[0]['lang']
  91. tz = gateway_push_qs[0]['tz'] if gateway_push_qs[0]['tz'] else 0
  92. # 获取推送所需数据
  93. msg_title = GatewayPushService.get_msg_title(app_bundle_id, nickname)
  94. msg_text = GatewayPushService.get_msg_text(n_time, tz, lang, alarm)
  95. kwargs['msg_title'] = msg_title
  96. kwargs['msg_text'] = msg_text
  97. kwargs['app_bundle_id'] = app_bundle_id
  98. kwargs['token_val'] = token_val
  99. try:
  100. # 推送消息
  101. if push_type == 0: # ios apns
  102. GatewayPushService.ios_apns_push(**kwargs)
  103. elif push_type == 1: # android gcm
  104. GatewayPushService.android_fcm_push(**kwargs)
  105. elif push_type == 2: # android 极光推送
  106. GatewayPushService.android_jpush(**kwargs)
  107. except Exception as e:
  108. logger.info('网关推送消息异常,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  109. continue
  110. # 组织存储数据
  111. local_date_time = CommonService.get_now_time_str(n_time=n_time, tz=0, lang='cn')[:10]
  112. equipment_info_list.append(EquipmentInfoService.get_equipment_info_obj(
  113. local_date_time,
  114. add_time=n_time,
  115. event_time=n_time,
  116. receive_time=n_time,
  117. device_uid=serial_number,
  118. device_nick_name=nickname,
  119. alarm=alarm,
  120. event_type=event_type,
  121. device_user_id=user_id,
  122. ))
  123. if equipment_info_list:
  124. # 根据日期获得星期几
  125. week = LocalDateTimeUtil.date_to_week(local_date_time)
  126. EquipmentInfoService.equipment_info_bulk_create(week, equipment_info_list)
  127. return response.json(0)
  128. except Exception as e:
  129. logger.info('---网关推送接口异常--- {}'.format(repr(e)))
  130. return response.json(500, repr(e))