WaterwarnController.class.bak01.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  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. case 'LL1':
  113. $status='低水位';
  114. $where=" AND data2 like '%3%'";
  115. break;
  116. case 'LL2':
  117. $status='高水位';
  118. $where=" AND data2 like '%3%'";
  119. break;
  120. default:
  121. $status='其他'.$Data['Status'];
  122. $where=" AND data2 like '%3%'";
  123. break;
  124. }
  125. print_r($status);
  126. $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."'");
  127. $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."");
  128. if(count($union_sql)==0){
  129. exit;
  130. }
  131. $openids=$this->array_column1($union_sql,"phone");
  132. if (empty($openids))
  133. {
  134. echo 'open is null';
  135. exit;
  136. }
  137. $status11=M()->query("SELECT statustime FROM sp_devices_status where deviceid='".$dataid."'");
  138. $op=M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  139. $access_token=GetAccess_Token();
  140. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  141. $deviceid=$dataid;
  142. $type= $status;
  143. $time=$status11[0]['statustime'];
  144. $remark='设备名称:'.$company[0]['owner_name'];
  145. foreach($op as $o){
  146. if (!empty($o['openid'])) {
  147. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  148. //{{first.DATA}}$address
  149. //设备号:{{keyword1.DATA}}$deviceid
  150. //报警类型:{{keyword2.DATA}}$type
  151. //时间:{{keyword3.DATA}}$time
  152. //{{remark.DATA}}$remark
  153. $this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  154. }
  155. }
  156. }
  157. public function message_electrical(){
  158. $Data=I('post.');
  159. if (empty($Data['phone']))
  160. {
  161. dump($Data['phone']);
  162. exit;
  163. }
  164. $dataid=$Data['device_code'];
  165. $openids =$Data['phone'];
  166. $Data['address']=$addr[0]['address'];
  167. switch ($Data['evt']) {
  168. case 'EF1':
  169. $status='欠压';
  170. $where=" AND data2 like '%7%'";
  171. break;
  172. case 'EF2':
  173. $status='过压';
  174. $where=" AND data2 like '%7%'";
  175. break;
  176. case 'EF3':
  177. $status='过流';
  178. $where=" AND data2 like '%7%'";
  179. break;
  180. case 'EF4':
  181. $status='漏电';
  182. $where=" AND data2 like '%7%'";
  183. break;
  184. case 'EF5':
  185. $status='温度1超高';
  186. $where=" AND data2 like '%7%'";
  187. break;
  188. case 'EF6':
  189. $status='温度2超高';
  190. $where=" AND data2 like '%7%'";
  191. break;
  192. case 'EF7':
  193. $status='温度2超高';
  194. $where=" AND data2 like '%7%'";
  195. break;
  196. case 'EF8':
  197. $status='温度3超高';
  198. $where=" AND data2 like '%7%'";
  199. break;
  200. case 'EF9':
  201. $status='离线';
  202. $where=" AND data2 like '%5%'";
  203. break;
  204. default:
  205. $status='其他'.$Data['evt'];
  206. $where=" AND data2 like '%3%'";
  207. break;
  208. }
  209. $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."'");
  210. $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."");
  211. if(count($union_sql)==0){
  212. exit;
  213. }
  214. $openids=$this->array_column1($union_sql,"phone");
  215. if (empty($openids))
  216. {
  217. echo 'open is null';
  218. exit;
  219. }
  220. $status11=M()->query("SELECT statustime FROM sp_devices_status where deviceid='".$dataid."'");
  221. $op=M()->query("SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)");
  222. $access_token=GetAccess_Token();
  223. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  224. $deviceid=$dataid;
  225. $type= $status;
  226. // $time=$status11[0]['statustime'];
  227. $time=date('Y-m-d H:i:s');
  228. $remark='设备名称:'.$company[0]['owner_name'];
  229. foreach($op as $o){
  230. if (!empty($o['openid'])) {
  231. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  232. //{{first.DATA}}$address
  233. //设备号:{{keyword1.DATA}}$deviceid
  234. //报警类型:{{keyword2.DATA}}$type
  235. //时间:{{keyword3.DATA}}$time
  236. //{{remark.DATA}}$remark
  237. $this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  238. }
  239. }
  240. }
  241. }