ElectricwarnController.class.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. use Think\Cache\Driver;
  5. include '../Common/function.php';
  6. class ElectricwarnController extends PushWarnController
  7. {
  8. public function message_electric()
  9. {
  10. $Data = I('post.');
  11. //日志打印
  12. $filename_log = "/var/www/html/jdxf/log/electric_b_log" . date("Y-m-d") . ".log";
  13. $this->printing_log($Data, $filename_log);
  14. //需要用到的参数
  15. $device_code = $Data['device_code'];
  16. $unique_number = $device_code;
  17. $insert_id = $Data['insert_id'];
  18. $remarks = $Data['bz'];
  19. $time = $Data['time'];
  20. $evt = $Data['evt'];
  21. if (empty($insert_id) || empty($device_code) || empty($evt) || empty($unique_number)) {
  22. echo '缺少重要参数,请检查推送代码!';
  23. exit();
  24. }
  25. //3小时以内相同设备报警未处理则不推送
  26. $redis = new \Redis();
  27. $result = $redis->connect('127.0.0.1', 6379);
  28. $if_push = 1;
  29. if ($result == 1) {
  30. $res = $redis->get("$unique_number");
  31. if ($res == 1) {
  32. $if_push = 1;
  33. } else if (!empty($res)) {
  34. if (floor((strtotime($Data['time']) - strtotime($res)) / 3600) > 3) {
  35. $if_push = 1;
  36. } else {
  37. $if_push = 0;
  38. }
  39. } else {
  40. $if_push = 1;
  41. }
  42. $redis->get("$unique_number");
  43. $redis->set("$unique_number", "$time");
  44. $redis->close();
  45. }
  46. switch ($evt) {
  47. case 'EF1':
  48. $status = '欠压报警';
  49. $where = " AND data2 like '%7%'";
  50. break;
  51. case 'EF2':
  52. $status = '过压报警';
  53. $where = " AND data2 like '%7%'";
  54. break;
  55. case 'EF3':
  56. $status = '过流报警';
  57. $where = " AND data2 like '%7%'";
  58. break;
  59. case 'EF4':
  60. $status = '漏电报警';
  61. $where = " AND data2 like '%7%'";
  62. break;
  63. case 'EF5':
  64. $status = '回路1温度超限报警';
  65. $where = " AND data2 like '%7%'";
  66. break;
  67. case 'EF6':
  68. $status = '回路2温度超限报警';
  69. $where = " AND data2 like '%7%'";
  70. break;
  71. case 'EF7':
  72. $status = '回路3温度超限报警';
  73. $where = " AND data2 like '%7%'";
  74. break;
  75. // case 'EF8':
  76. // $status='温度4超高';
  77. // $where=" AND data2 like '%7%'";
  78. // break;
  79. case 'EF9':
  80. $status = '离线';
  81. $where = " AND data2 like '%5%'";
  82. break;
  83. default:
  84. $status = '其他' . $Data['evt'];
  85. $where = " AND data2 like '%3%'";
  86. break;
  87. }
  88. $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 . "'");
  89. $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 . " ");
  90. if (count($union_sql) == 0) {
  91. echo "phone is null";
  92. exit;
  93. }
  94. $openids = $this->array_column1($union_sql, "phone");
  95. if (empty($openids)) {
  96. echo 'open is null';
  97. exit;
  98. }
  99. $status11 = M()->query("SELECT statustime FROM sp_devices_status where deviceid='" . $device_code . "'");
  100. $op = M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  101. $access_token = GetAccess_Token1();
  102. $address = '警报地址:' . $data[0]['owner_address'] . $data[0]['unitinfo'];
  103. $type = $status;
  104. //keyword3.DATA
  105. if (empty($time)) {
  106. $time = $status11[0]['statustime'];
  107. }
  108. //remark.DATA
  109. if (empty($remarks)) {
  110. $remarks = '设备名称:' . $data[0]['owner_name'];
  111. }
  112. $url = "https://iot.usky.cn/jdxf/wxapp2.php/Home/Fireinfo/index/type/7/id/" . $insert_id;
  113. if ($if_push == 1) {
  114. foreach ($op as $o) {
  115. if (!empty($o['openid'])) {
  116. $R = $this->SendDeviceAlarm($access_token, $o['openid'], $address, $device_code, $type, $time, $remarks, $url);
  117. $filename_log = "/var/www/html/jdxf/log/electric_t_log" . date("Y-m-d") . ".log";
  118. $this->printing_log($R, $filename_log);
  119. print_r($R);
  120. }
  121. }
  122. }
  123. }
  124. }