WaterwarnController.bak.class.php 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. class WaterwarnController extends PushWarnController {
  5. public function bj(){
  6. $Data=I('post.');
  7. if (empty($Data['phone']))
  8. {
  9. dump($Data['phone']);
  10. exit;
  11. }
  12. $dataid=$Data['IMEI'];
  13. $time1=$Data['time'];
  14. switch ($Data['evt']) {
  15. case 'y01':
  16. $status='报警';
  17. $where=" AND data2 like '%6%'";
  18. break;
  19. case 'yo2':
  20. $status='报警静音';
  21. $where=" AND data2 like '%6%'";
  22. break;
  23. case 'y03':
  24. $status='保留';
  25. $where=" AND data2 like '%6%'";
  26. break;
  27. case 'y04':
  28. $status='低压';
  29. $where=" AND data2 like '%6%'";
  30. break;
  31. case 'y05':
  32. $status='故障';
  33. $where=" AND data2 like '%6%'";
  34. break;
  35. case 'y06':
  36. $status='保留';
  37. $where=" AND data2 like '%6%'";
  38. break;
  39. default:
  40. $status='其他'.$Data['evt'];
  41. $where=" AND data2 like '%6%'";
  42. break;
  43. }
  44. $company=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 ='".$dataid."'");
  45. $union_sql=M()->query("select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' ".$where." union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') ".$where."");
  46. if(count($union_sql)==0){
  47. exit;
  48. }
  49. $openids=$this->array_column1($union_sql,"phone");
  50. if (empty($openids))
  51. {
  52. echo 'open is null';
  53. exit;
  54. }
  55. $status11=M()->query("SELECT statustime FROM sp_devices_status where deviceid='".$dataid."'");
  56. $op=M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  57. $access_token=GetAccess_Token();
  58. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  59. $deviceid=$dataid;
  60. $type= $status;
  61. $time=$time1;
  62. $remark='设备名称:'.$company[0]['owner_name'];
  63. foreach($op as $o){
  64. if (!empty($o['openid'])) {
  65. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  66. //{{first.DATA}}$address
  67. //设备号:{{keyword1.DATA}}$deviceid
  68. //报警类型:{{keyword2.DATA}}$type
  69. //时间:{{keyword3.DATA}}$time
  70. //{{remark.DATA}}$remark
  71. $this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  72. }
  73. }
  74. }
  75. /**
  76. * "evt" => "09",
  77. * "IMEI" => 设备编号,
  78. * "DateTime" => 时间,
  79. * "Interval" => 间隔时间,
  80. * "Status" => 状态,
  81. * "Battery" => 电量,
  82. * "Signal" => 信号,
  83. * "Unit" => 单位,
  84. * "Pressure" => 水压值,
  85. * "phone" => 电话,
  86. * "insert_id" => 插入表id
  87. * @return [type] [description]
  88. */
  89. public function message_water(){
  90. $Data=I('post.');
  91. if (empty($Data['phone']))
  92. {
  93. dump($Data['phone']);
  94. exit;
  95. }
  96. $dataid=$Data['IMEI'];
  97. $openids =$Data['phone'];
  98. $Data['address']=$addr[0]['address'];
  99. switch ($Data['evt']) {
  100. case 'WP1':
  101. $status='低压';
  102. $where=" AND data2 like '%3%'";
  103. break;
  104. case 'WP2':
  105. $status='高压';
  106. $where=" AND data2 like '%3%'";
  107. break;
  108. case 'WP4':
  109. $status='离线';
  110. $where=" AND data2 like '%5%'";
  111. break;
  112. default:
  113. $status='其他'.$Data['Status'];
  114. $where=" AND data2 like '%3%'";
  115. break;
  116. }
  117. $company=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 ='".$dataid."'");
  118. $union_sql=M()->query("select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' ".$where." union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') ".$where."");
  119. if(count($union_sql)==0){
  120. exit;
  121. }
  122. $openids=$this->array_column1($union_sql,"phone");
  123. if (empty($openids))
  124. {
  125. echo 'open is null';
  126. exit;
  127. }
  128. $status11=M()->query("SELECT statustime FROM sp_devices_status where deviceid='".$dataid."'");
  129. $op=M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  130. $access_token=GetAccess_Token();
  131. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  132. $deviceid=$dataid;
  133. $type= $status;
  134. $time=$status11[0]['statustime'];
  135. $remark='设备名称:'.$company[0]['owner_name'];
  136. foreach($op as $o){
  137. if (!empty($o['openid'])) {
  138. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  139. //{{first.DATA}}$address
  140. //设备号:{{keyword1.DATA}}$deviceid
  141. //报警类型:{{keyword2.DATA}}$type
  142. //时间:{{keyword3.DATA}}$time
  143. //{{remark.DATA}}$remark
  144. $this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  145. }
  146. }
  147. }
  148. public function message_electrical(){
  149. $Data=I('post.');
  150. if (empty($Data['phone']))
  151. {
  152. dump($Data['phone']);
  153. exit;
  154. }
  155. $dataid=$Data['device_code'];
  156. $openids =$Data['phone'];
  157. $Data['address']=$addr[0]['address'];
  158. switch ($Data['evt']) {
  159. case 'EF1':
  160. $status='欠压';
  161. $where=" AND data2 like '%7%'";
  162. break;
  163. case 'EF2':
  164. $status='过压';
  165. $where=" AND data2 like '%7%'";
  166. break;
  167. case 'EF3':
  168. $status='过流';
  169. $where=" AND data2 like '%7%'";
  170. break;
  171. case 'EF4':
  172. $status='漏电';
  173. $where=" AND data2 like '%7%'";
  174. break;
  175. case 'EF5':
  176. $status='温度1超高';
  177. $where=" AND data2 like '%7%'";
  178. break;
  179. case 'EF6':
  180. $status='温度2超高';
  181. $where=" AND data2 like '%7%'";
  182. break;
  183. case 'EF7':
  184. $status='温度2超高';
  185. $where=" AND data2 like '%7%'";
  186. break;
  187. case 'EF8':
  188. $status='温度3超高';
  189. $where=" AND data2 like '%7%'";
  190. break;
  191. case 'EF9':
  192. $status='离线';
  193. $where=" AND data2 like '%5%'";
  194. break;
  195. default:
  196. $status='其他'.$Data['evt'];
  197. $where=" AND data2 like '%3%'";
  198. break;
  199. }
  200. $company=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 ='".$dataid."'");
  201. $union_sql=M()->query("select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' ".$where." union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') ".$where."");
  202. if(count($union_sql)==0){
  203. exit;
  204. }
  205. $openids=$this->array_column1($union_sql,"phone");
  206. if (empty($openids))
  207. {
  208. echo 'open is null';
  209. exit;
  210. }
  211. $status11=M()->query("SELECT statustime FROM sp_devices_status where deviceid='".$dataid."'");
  212. $op=M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  213. $access_token=GetAccess_Token();
  214. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  215. $deviceid=$dataid;
  216. $type= $status;
  217. // $time=$status11[0]['statustime'];
  218. $time=date('Y-m-d H:i:s');
  219. $remark='设备名称:'.$company[0]['owner_name'];
  220. foreach($op as $o){
  221. if (!empty($o['openid'])) {
  222. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  223. //{{first.DATA}}$address
  224. //设备号:{{keyword1.DATA}}$deviceid
  225. //报警类型:{{keyword2.DATA}}$type
  226. //时间:{{keyword3.DATA}}$time
  227. //{{remark.DATA}}$remark
  228. $this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  229. }
  230. }
  231. }
  232. }