ElevatorwarnController.class.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. include '../Common/function.php';
  5. class ElevatorwarnController extends PushWarnController
  6. {
  7. public function message_elevator()
  8. {
  9. $Data = I('post.');
  10. //日志打印
  11. $filename_log = "/var/www/html/jdxf/log/elevator_b_log" . date("Y-m-d") . ".log";
  12. $this->printing_log($Data, $filename_log);
  13. //需要用到的参数
  14. if (!empty($Data['IMEI'])) {
  15. $device_code = $Data['IMEI'];
  16. } else if (!empty($Data['IEMI'])) {
  17. $device_code = $Data['IEMI'];
  18. }
  19. $insert_id = $Data['insert_id'];
  20. $remarks = $Data['bz'];
  21. $time = $Data['time'];
  22. $evt_name = $Data['evt_name'];
  23. $evt = $Data['evt'];
  24. if (empty($insert_id) || empty($device_code)) {
  25. echo '缺少重要参数,请检查推送代码!';
  26. exit();
  27. }
  28. switch ($evt) {
  29. case 'LF01':
  30. $status = '声音报警';
  31. $where = " AND data2 like '%9%'";
  32. break;
  33. case 'LF03':
  34. $status = '电梯检修';
  35. $where = " AND data2 like '%9%'";
  36. break;
  37. case 'LF04':
  38. $status = '电梯检修恢复';
  39. $where = " AND data2 like '%9%'";
  40. break;
  41. case 'LF05':
  42. $status = '电梯故障';
  43. $where = " AND data2 like '%9%'";
  44. break;
  45. case 'LF0501':
  46. $status = '电梯异常停留';
  47. $where = " AND data2 like '%9%'";
  48. break;
  49. case 'LF0502':
  50. $status = '电梯异常开门';
  51. $where = " AND data2 like '%9%'";
  52. break;
  53. case 'LF0503':
  54. $status = '电梯异常关门';
  55. $where = " AND data2 like '%9%'";
  56. break;
  57. case 'LF0504':
  58. $status = '电梯异常走梯';
  59. $where = " AND data2 like '%9%'";
  60. break;
  61. case 'LF06':
  62. $status = '电梯故障恢复';
  63. $where = " AND data2 like '%9%'";
  64. break;
  65. default:
  66. $status = '其他' . $Data['Status'];
  67. $where = " AND data2 like '%9%'";
  68. break;
  69. }
  70. if (!empty($evt_name)) {
  71. $status = $evt_name;
  72. $where = " AND data2 like '%9%'";
  73. }
  74. $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 . "'");
  75. $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 . " ");
  76. if (count($union_sql) == 0) {
  77. echo "phone is null";
  78. exit;
  79. }
  80. $openids = $this->array_column1($union_sql, "phone");
  81. if (empty($openids)) {
  82. echo 'open is null';
  83. exit;
  84. }
  85. $status11 = M()->query("SELECT statustime FROM sp_devices_status where deviceid='" . $device_code . "'");
  86. $op = M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  87. $access_token = GetAccess_Token1();
  88. $address = '警报地址:' . $data[0]['owner_address'] . $data[0]['unitinfo'];
  89. $type = $status;
  90. //keyword3.DATA
  91. if (empty($time)) {
  92. $time = $status11[0]['statustime'];
  93. }
  94. //remark.DATA
  95. if (empty($remarks)) {
  96. $remarks = '设备名称:' . $data[0]['owner_name'];
  97. }
  98. $url = "https://iot.usky.cn/jdxf/wxapp2.php/Home/Fireinfo/index/type/17/id/" . $insert_id;
  99. foreach ($op as $o) {
  100. if (!empty($o['openid'])) {
  101. $R = $this->SendDeviceAlarm($access_token, $o['openid'], $address, $device_code, $type, $time, $remarks, $url);
  102. $filename_log = "/var/www/html/jdxf/log/elevator_t_log" . date("Y-m-d") . ".log";
  103. $this->printing_log($R, $filename_log);
  104. print_r($R);
  105. }
  106. }
  107. }
  108. }