SmokeSensationwarnController.class.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. use Think\Cache\Driver;
  5. include '../Common/function.php';
  6. class SmokeSensationwarnController extends PushWarnController
  7. {
  8. public function message_smoke_sensation()
  9. {
  10. $Data = I('post.');
  11. //日志打印
  12. $filename_log = "/var/www/html/jdxf/log/smoke_sensation_b_log" . date("Y-m-d") . ".log";
  13. $this->printing_log($Data, $filename_log);
  14. //需要用到的参数
  15. if (!empty($Data['IMEI'])) {
  16. $device_code = $Data['IMEI'];
  17. } else if (!empty($Data['IEMI'])) {
  18. $device_code = $Data['IEMI'];
  19. }
  20. $unique_number = $device_code;
  21. $insert_id = $Data['insert_id'];
  22. $remarks = $Data['bz'];
  23. $time = $Data['time'];
  24. $evt = $Data['evt'];
  25. if (empty($insert_id) || empty($device_code) || empty($evt) || empty($unique_number)) {
  26. echo '缺少重要参数,请检查推送代码!';
  27. exit();
  28. }
  29. //3小时以内相同设备报警未处理则不推送
  30. // $redis = new \Redis();
  31. // $result = $redis->connect('127.0.0.1', 6379);
  32. // $if_push = 1;
  33. // if ($result == 1) {
  34. // $res = $redis->get("$unique_number");
  35. // if ($res == 1) {
  36. // $if_push = 1;
  37. //
  38. // } else if (!empty($res)) {
  39. // if (floor((strtotime($Data['time']) - strtotime($res)) / 3600) > 3) {
  40. // $if_push = 1;
  41. // } else {
  42. // $if_push = 0;
  43. // }
  44. // } else {
  45. // $if_push = 1;
  46. // }
  47. // $redis->get("$unique_number");
  48. // $redis->set("$unique_number", "$time");
  49. // $redis->close();
  50. // }
  51. switch ($evt) {
  52. case 'y01':
  53. $status = '报警';
  54. $where = " AND data2 like '%6%'";
  55. break;
  56. case 'y02':
  57. $status = '报警静音';
  58. $where = " AND data2 like '%6%'";
  59. break;
  60. case 'y06':
  61. case 'y03':
  62. $status = '保留';
  63. $where = " AND data2 like '%6%'";
  64. break;
  65. case 'y04':
  66. $status = '低压';
  67. $where = " AND data2 like '%6%'";
  68. break;
  69. case 'y05':
  70. $status = '故障';
  71. $where = " AND data2 like '%6%'";
  72. break;
  73. case 'y07':
  74. $status = '火灾报警';
  75. $where = " AND data2 like '%6%'";
  76. break;
  77. case 'y08':
  78. $status = '温度报警';
  79. $where = " AND data2 like '%6%'";
  80. break;
  81. case 'y09':
  82. $status = '烟感电量低';
  83. $where = " AND data2 like '%6%'";
  84. break;
  85. case 'y10':
  86. $status = '防拆报警';
  87. $where = " AND data2 like '%6%'";
  88. break;
  89. case 'y11':
  90. $status = '发射电路故障';
  91. $where = " AND data2 like '%6%'";
  92. break;
  93. case 'y12':
  94. $status = '设备自检';
  95. $where = " AND data2 like '%6%'";
  96. break;
  97. default:
  98. $status = '其他' . $Data['evt'];
  99. $where = " AND data2 like '%6%'";
  100. break;
  101. }
  102. $data = M()->query("select s.owner_name,s.unitinfo,s.company,c.owner_address,s.dwtype from sp_owner s ,sp_owner_company c where s.company=c.owner_id and s.owner_code ='" . $device_code . "'");
  103. $union_sql = M()->query("select phone from sp_owner_phone WHERE owner_code='" . $data[0]['company'] . "' " . $where . " union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='" . $data[0]['company'] . "') " . $where);
  104. if (count($union_sql) == 0) {
  105. echo "phone is null";
  106. exit;
  107. }
  108. $openids = $this->array_column1($union_sql, "phone");
  109. if (empty($openids)) {
  110. echo 'open is null';
  111. exit;
  112. }
  113. $status11 = M()->query("SELECT statustime FROM sp_devices_status where deviceid='" . $device_code . "'");
  114. $op = M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  115. $access_token = GetAccess_Token1();
  116. $address = '警报地址:' . $data[0]['owner_address'] . $data[0]['unitinfo'];
  117. $type = $status;
  118. //keyword3.DATA
  119. if (empty($time)) {
  120. $time = $status11[0]['statustime'];
  121. }
  122. //remark.DATA
  123. if (empty($remarks)) {
  124. $remarks = '设备名称:' . $data[0]['owner_name'];
  125. }
  126. $url = "https://iot.usky.cn/jdxf/wxapp2.php/Home/Fireinfo/index/type/1/id/" . $insert_id;
  127. // if ($if_push == 1) {
  128. foreach ($op as $o) {
  129. if (!empty($o['openid'])) {
  130. $R = $this->SendDeviceAlarm($access_token, $o['openid'], $address, $device_code, $type, $time, $remarks, $url);
  131. $filename_log = "/var/www/html/jdxf/log/smoke_sensation_t_log" . date("Y-m-d") . ".log";
  132. $this->printing_log($R, $filename_log);
  133. print_r($R);
  134. }
  135. }
  136. // }
  137. }
  138. }