ManholeCoverwarnController.class.php 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. include '../Common/function.php';
  5. class ManholeCoverwarnController extends PushWarnController
  6. {
  7. public function message_manhole_cover()
  8. {
  9. $Data = I('post.');
  10. //日志打印
  11. $filename_log = "/var/www/html/jdxf/log/manhole_cover_b_log" . date("Y-m-d") . ".log";
  12. $this->printing_log($Data, $filename_log);
  13. if (!empty($Data['device_code'])) {
  14. $device_code = $Data['device_code'];
  15. }
  16. $insert_id = $Data['insert_id'];
  17. $remarks = $Data['bz'];
  18. $time = $Data['time'];
  19. $evt = $Data['evt'];
  20. switch ($evt) {
  21. case 'JG01':
  22. $evt_name = '恢复';
  23. $where = " AND data2 like '%a%'";
  24. break;
  25. case 'JG02':
  26. $evt_name = '打开告警';
  27. $where = " AND data2 like '%a%'";
  28. break;
  29. case 'JG03':
  30. $evt_name = '角度传感器异常';
  31. $where = " AND data2 like '%a%'";
  32. break;
  33. case 'JG04':
  34. $evt_name = '温湿度传感器异常';
  35. $where = " AND data2 like '%a%'";
  36. break;
  37. default:
  38. $evt_name = '其他' . $evt;
  39. $where = " AND data2 like '%a%'";
  40. break;
  41. }
  42. $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 . "'");
  43. $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 . " ");
  44. if (count($union_sql) == 0) {
  45. echo "phone is null";
  46. exit;
  47. }
  48. $openids = $this->array_column1($union_sql, "phone");
  49. if (empty($openids)) {
  50. echo 'open is null';
  51. exit;
  52. }
  53. $status11 = M()->query("SELECT statustime FROM sp_devices_status where deviceid='" . $device_code . "'");
  54. $op = M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  55. $access_token = GetAccess_Token1();
  56. $address = '警报地址:' . $data[0]['owner_address'] . $data[0]['unitinfo'];
  57. $type = $evt_name;
  58. //keyword3.DATA
  59. if (empty($time)) {
  60. $time = $status11[0]['statustime'];
  61. }
  62. //remark.DATA
  63. if (empty($remarks)) {
  64. $remarks = '设备名称:' . $data[0]['owner_name'];
  65. }
  66. $url = "https://iot.usky.cn/jdxf/wxapp2.php/Home/Fireinfo/index/type/128/id/" . $insert_id;;
  67. foreach ($op as $o) {
  68. if (!empty($o['openid'])) {
  69. $R = $this->SendDeviceAlarm($access_token, $o['openid'], $address, $device_code, $type, $time, $remarks, $url);
  70. //日志打印
  71. $filename_log = "/var/www/html/jdxf/log/manhole_cover_t_log" . date("Y-m-d") . ".log";
  72. $this->printing_log($R, $filename_log);
  73. print_r($R);
  74. }
  75. }
  76. }
  77. }