WaterwarnController.class.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. use Think\Cache\Driver;
  5. include '../Common/function.php';
  6. class WaterwarnController extends PushWarnController
  7. {
  8. /**
  9. * "evt" => "09",
  10. * "IMEI" => 设备编号,
  11. * "DateTime" => 时间,
  12. * "Interval" => 间隔时间,
  13. * "Status" => 状态,
  14. * "Battery" => 电量,
  15. * "Signal" => 信号,
  16. * "Unit" => 单位,
  17. * "Pressure" => 水压值,
  18. * "phone" => 电话,
  19. * "insert_id" => 插入表id
  20. * @return [type] [description]
  21. */
  22. public function message_water()
  23. {
  24. $Data = I('post.');
  25. //日志打印
  26. $filename_log = "/var/www/html/jdxf/log/water_b_log" . date("Y-m-d") . ".log";
  27. $this->printing_log($Data, $filename_log);
  28. //需要用到的参数
  29. if (!empty($Data['IMEI'])) {
  30. $device_code = $Data['IMEI'];
  31. } else if (!empty($Data['IEMI'])) {
  32. $device_code = $Data['IEMI'];
  33. }
  34. $unique_number = $device_code;
  35. $insert_id = $Data['insert_id'];
  36. $remarks = $Data['bz'];
  37. $types = $Data['types'];
  38. $time = $Data['time'];
  39. $evt_name = $Data['evt_c'];
  40. $evt = $Data['evt'];
  41. if (empty($insert_id) || empty($device_code) || empty($types) || empty($unique_number)) {
  42. echo '缺少重要参数,请检查推送代码!';
  43. exit();
  44. }
  45. //3小时以内相同设备报警未处理则不推送
  46. $redis = new \Redis();
  47. $result = $redis->connect('127.0.0.1', 6379);
  48. $if_push = 1;
  49. if ($result == 1) {
  50. $res = $redis->get("$unique_number");
  51. if ($res == 1) {
  52. $if_push = 1;
  53. } else if (!empty($res)) {
  54. if (floor((strtotime($Data['time']) - strtotime($res)) / 3600) > 3) {
  55. $if_push = 1;
  56. } else {
  57. $if_push = 0;
  58. }
  59. } else {
  60. $if_push = 1;
  61. }
  62. $redis->get("$unique_number");
  63. $redis->set("$unique_number", "$time");
  64. $redis->close();
  65. }
  66. switch ($evt) {
  67. case 'WP1':
  68. $status = '低压';
  69. $where = " AND data2 like '%3%'";
  70. break;
  71. case 'WP2':
  72. $status = '高压';
  73. $where = " AND data2 like '%3%'";
  74. break;
  75. case 'WP3':
  76. $status = '故障';
  77. $where = " AND data2 like '%3%'";
  78. break;
  79. case 'WP4':
  80. $status = '离线';
  81. $where = " AND data2 like '%5%'";
  82. break;
  83. case 'LL1':
  84. $status = '低水位';
  85. $where = " AND data2 like '%3%'";
  86. break;
  87. case 'LL2':
  88. $status = '高水位';
  89. $where = " AND data2 like '%3%'";
  90. break;
  91. default:
  92. $status = '其他' . $Data['Status'];
  93. $where = " AND data2 like '%3%'";
  94. break;
  95. }
  96. if (!empty($evt_name)) {
  97. $status = $evt_name;
  98. $where = " AND data2 like '%3%'";
  99. }
  100. $data = M()->query("select s.owner_name,s.unitinfo,s.company,c.owner_address from sp_owner s ,sp_owner_company c where s.company=c.owner_id and s.owner_code ='" . $device_code . "'");
  101. $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);
  102. if (count($union_sql) == 0) {
  103. echo "phone is null";
  104. exit;
  105. }
  106. $openids = $this->array_column1($union_sql, "phone");
  107. if (empty($openids)) {
  108. echo 'open is null';
  109. exit;
  110. }
  111. $status11 = M()->query("SELECT statustime FROM sp_devices_status where deviceid='" . $device_code . "'");
  112. $op = M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  113. $access_token = GetAccess_Token1();
  114. //first.DATA
  115. $address = '警报地址:' . $data[0]['owner_address'] . $data[0]['unitinfo'];
  116. //keyword2.DATA
  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/2/id/" . $insert_id;
  127. //判断是否推送
  128. if ($if_push == 1) {
  129. foreach ($op as $o) {
  130. if (!empty($o['openid'])) {
  131. $R = $this->SendDeviceAlarm($access_token, $o['openid'], $address, $device_code, $type, $time, $remarks, $url);
  132. $filename_log = "/var/www/html/jdxf/log/water_t_log" . date("Y-m-d") . ".log";
  133. $this->printing_log($R, $filename_log);
  134. print_r($R);
  135. }
  136. }
  137. }
  138. }
  139. }