Order.php.bak.20211104 88 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645
  1. <?php
  2. namespace app\admin\controller;
  3. use think\Controller;
  4. use think\Session;
  5. use think\Db;
  6. use think\Request;
  7. use think\Log;
  8. class Order extends Controller
  9. {
  10. private $host="https://device.api.ct10649.com:8743/";
  11. private $appId="wvdOfp7JVe0ULwnFKwBF0edfbcAa";
  12. private $secret="Bihoe_rY9vebXMw6sFfpQy0jiRca";
  13. public function index(){
  14. $data_list =Db::name('order')->paginate();
  15. $pages = $data_list->render();
  16. $this->assign('data_list', $data_list);
  17. $this->assign('pages', $pages);
  18. return $this->fetch();
  19. }
  20. public function add(){
  21. $res=Db::name('order')->where('notifyType',input('notifyType'))->find();
  22. if(!$res){
  23. if ($this->request->isPost()) {
  24. $data=$_POST;
  25. //验证数据
  26. if(empty($data['notifyType'])||empty($data['callbackUrl'])){
  27. return $this->error("请填写好必要内容");
  28. }
  29. $token=json_decode(gettoken(),true);
  30. $sendata=[
  31. "notifyType"=>$data['notifyType'],
  32. "callbackUrl"=>$data['callbackUrl'],
  33. "appId"=>$this->appId,
  34. ];
  35. $header=[
  36. "Content-Type:application/json",
  37. "app_key:".$this->appId,
  38. "Authorization:Bearer ".$token["accessToken"]
  39. ];
  40. //https://server:port/iocm/app/sub/v1.2.0/subscriptions?ownerFlag={ownerFlag}
  41. $rescurl=curl($this->host."iocm/app/sub/v1.2.0/subscriptions",json_encode($sendata),$header);
  42. dump($rescurl);
  43. if($rescurl[0]==201){//成功
  44. $res1=json_decode($rescurl[1],true);
  45. }else{//失败
  46. // $res2=json_decode($res1[1],true);
  47. return $this->error($rescurl[1]);
  48. }
  49. //添加
  50. $list=array();
  51. $list['notifyType']= $data['notifyType'];
  52. $list['callbackUrl']= $data['callbackUrl'];
  53. $list['subscriptionId']= $res1['subscriptionId'];
  54. $list['addtime']= date('Y-m-d H:i:s');
  55. $list['updatetime']= date('Y-m-d H:i:s');
  56. $res = Db::name('order')->insertGetId($list);
  57. if($res) {
  58. return $this->success('添加成功','index');
  59. }else{
  60. return $this->error("添加失败,请稍后再试");
  61. }
  62. }
  63. }else{
  64. return $this->error("该订阅类型已经填写");
  65. }
  66. $notifyType=Db::table('notifyType')->select();
  67. $this->assign('notifyType', $notifyType);
  68. return $this->fetch();
  69. }
  70. /* public function edit(){
  71. if ($this->request->isPost()) {
  72. $data=$_POST;
  73. //验证数据
  74. if(empty($data['callbackUrl'])){
  75. return $this->error("请填写好必要内容");
  76. }
  77. $token=json_decode(gettoken(),true);
  78. $sendata=[
  79. "notifyType"=>$data['notifyType'],
  80. "callbackUrl"=>$data['callbackUrl'],
  81. "appId"=>$this->appId,
  82. ];
  83. $header=[
  84. "Content-Type:application/json",
  85. "app_key:".$this->appId,
  86. "Authorization:Bearer ".$token["accessToken"]
  87. ];
  88. //https://server:port/iocm/app/sub/v1.2.0/subscriptions?ownerFlag={ownerFlag}
  89. $res1=curl($this->host."iocm/app/sub/v1.2.0/subscriptions",json_encode($sendata),$header);
  90. $res1=json_decode($res1,true);
  91. $list=array();
  92. $list['notifyType']= $data['notifyType'];
  93. $list['callbackUrl']= $data['callbackUrl'];
  94. $list['subscriptionId']= $res1['subscriptionId'];
  95. $list['updatetime']= date('Y-m-d H:i:s');
  96. $res = Db::name('order')->where('id',$data['id'])->update($list);
  97. if($res) {
  98. return $this->success('编辑成功','index');
  99. }else{
  100. return $this->error("编辑失败,请稍后再试");
  101. }
  102. }
  103. $notifyType=Db::table('notifyType')->select();
  104. $this->assign('notifyType', $notifyType);
  105. $res=Db::name('order')->where('id',input('id'))->find();
  106. $this->assign('data', $res);
  107. return $this->fetch();
  108. }*/
  109. //删除订阅
  110. public function delete(){
  111. if ($this->request->isPost()) {
  112. $data=$_POST;
  113. $token=json_decode(gettoken(),true);
  114. $header=[
  115. "Content-Type:application/json",
  116. "app_key:".$this->appId,
  117. "Authorization:Bearer ".$token["accessToken"]
  118. ];
  119. //https://server:port/iocm/app/sub/v1.2.0/subscriptions/{subscriptionId}
  120. $rescurl=curl($this->host."iocm/app/sub/v1.2.0/subscriptions/".$data['subscriptionId'],"",$header,"DELETE");
  121. if($rescurl[0]==204){//成功
  122. Db::name('order')->where('subscriptionId',$data['subscriptionId'])->delete();
  123. return "1111";
  124. //将数据库的订阅数据也删掉
  125. }else{//失败
  126. return $this->error($rescurl[1]);//
  127. }
  128. }
  129. }
  130. public function adddata(){
  131. if ($this->request->isPost()) {
  132. $data = input('');
  133. /* $rand=rand(0,2);
  134. $header=["Content-Type:application/json"];
  135. //将数据分配给不同的服务
  136. $httpserver=["http://47.98.153.212:1101","http://47.98.153.212:1102","http://47.98.153.212:1103"];
  137. $server=$httpserver[$rand];
  138. //将数据随机转发到别的平台做处理
  139. $res=curltest($server,$data,$header);
  140. */
  141. $list = array();
  142. if (is_array($data)) {
  143. $list['data'] = json_encode($data, 320);
  144. $getdata = json_decode($list['data'], true);//转成数组
  145. $list['type'] = 1;
  146. } else {
  147. $list['data'] = $data;
  148. $getdata = json_decode($list['data'], true);//转成数组
  149. $list['type'] = 2;
  150. }
  151. // $list['data']=11;
  152. $list['response'] = "111";
  153. $list['notifyType'] = $getdata["notifyType"];
  154. $list['deviceId'] = $getdata["deviceId"];
  155. $list['addtime'] = date('Y-m-d H:i:s');
  156. $res = Db::name('noticedata')->insertGetId($list);//将推送的数据存入总表
  157. Log::record('deviceId' . ':' . $getdata["service"]["eventTime"]);
  158. //在详细表里插入数据
  159. //根据设备id查找到device里的device_id
  160. if (trim($getdata["notifyType"]) == "deviceDataChanged") {
  161. $device = Db::name('device')->where('iot_id', trim($getdata["deviceId"]))->find();
  162. $datainfo = array();
  163. $datainfo['notifyType'] = $getdata["notifyType"];
  164. $datainfo['device_id'] = $device["device_id"];
  165. $datainfo['iot_id'] = $getdata["deviceId"];
  166. $datainfo['service'] = json_encode($getdata["service"]);
  167. $datainfo['addtime'] = date('Y-m-d H:i:s');
  168. $res1 = Db::table('dev_' . $device["device_id"])->insertGetId($datainfo);
  169. $data2=array();
  170. $data2['devicestatus'] = 0;
  171. $data2['true_status'] = '0';
  172. $data2['lastcommtime'] = date('Y-m-d H:i:s');
  173. $sql2="UPDATE sp_devices_status SET statustime = {$data2['lastcommtime']} devicestatus = {$data2['devicestatus']},true_status={$data2['true_status']},lastcommtime='{$data2['lastcommtime']}' WHERE deviceid='{$device['device_id']}'";
  174. $res2 = addDataInfo($sql2);
  175. if ($device['deviceType']=='Smoke') {
  176. $data3 = array();
  177. $data3['device_id'] = $device["device_id"];
  178. $data3['RSRQ'] = $getdata["service"]['data']['RSRQ'];
  179. $data3['CSQ'] = $getdata["service"]['data']["CSQ"];
  180. $data3['DeviceType'] = $getdata["service"]['data']["DeviceType"];
  181. $data3['DeviceStatus'] = $getdata["service"]['data']["DeviceStatus"];
  182. $data3['BatteryLevel'] = $getdata["service"]['data']["BatteryLevel"];
  183. $data3['SensorLevel'] = $getdata["service"]['data']["SensorLevel"];
  184. $data3['eventTime'] = $getdata["service"]["eventTime"];
  185. $data3['storeTime'] = date('Y-m-d H:i:s');
  186. $sql = "INSERT INTO sp_y{$data3['device_id']} VALUES ('','{$data3['device_id']}',
  187. '{$data3['RSRQ']}', '{$data3['CSQ']}', '{$data3['DeviceType']}','{$data3['DeviceStatus']}','{$data3['BatteryLevel']}','{$data3['SensorLevel']}','{$data3['eventTime']}','{$data3['storeTime']}')";
  188. $res3 = addDataInfo($sql);
  189. } elseif($device['deviceType']=='MultiSensor') {
  190. $data3 = array();
  191. $data3['device_id'] = $device["device_id"];
  192. $data3['port'] = 'tp_water_pressure';
  193. $data3['storeTime'] = date('Y-m-d H:i:s');
  194. $data3['unit'] =$getdata["service"]['data']["unit"];
  195. // $data3['messageId'] = $getdata["service"]['data']["messageId"];
  196. $data3['batteyValue'] = $getdata["service"]['data']["batteyValue"];
  197. $data3['alarmBoolean'] = $getdata["service"]['data']["alarmBoolean"];
  198. $unit=dechex($getdata["service"]['data']["unit"]);
  199. Log::record('sql1234'.':'.$unit);
  200. $sql11="SELECT dwtype FROM sp_owner WHERE owner_code ='{$device["device_id"]}'";
  201. $dwtype = add($sql11);
  202. $arr_y=array('10','11','20','21','22');
  203. if ($dwtype[0]['dwtype'] == 5){
  204. if ($data3['unit']== 1){
  205. $data3['data1']='LL2';
  206. }elseif($data3['unit']== 2){
  207. $data3['data1']='LL1';
  208. }else{
  209. $data3['data1']='LL0';
  210. }
  211. }else {
  212. if ($data3['unit']== 1){
  213. $data3['data1']='WP2';
  214. }elseif($data3['unit']== 2){
  215. $data3['data1']='WP1';
  216. }else{
  217. $data3['data1']='WP0';
  218. }
  219. }
  220. switch ($unit){
  221. case '10':
  222. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  223. break;
  224. case '11':
  225. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  226. break;
  227. case '20':
  228. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  229. break;
  230. case '21':
  231. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  232. break;
  233. case '22':
  234. $data3['data4'] = $getdata["service"]['data']["data"];
  235. break;
  236. case '30':
  237. $data3['data4'] = $getdata["service"]['data']["data"]*0.0000001;
  238. break;
  239. case '31':
  240. $data3['data4'] = $getdata["service"]['data']["data"]*0.000001;
  241. break;
  242. case '40':
  243. $data3['data4'] = $getdata["service"]['data']["data"]*0.00001;
  244. break;
  245. case '41':
  246. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  247. break;
  248. case '42':
  249. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  250. break;
  251. case '50':
  252. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  253. break;
  254. case '51':
  255. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  256. break;
  257. case '52':
  258. $data3['data4'] = $getdata["service"]['data']["data"];
  259. break;
  260. case '2':
  261. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  262. break;
  263. case '1':
  264. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  265. break;
  266. }
  267. $data3['data'] = $getdata["service"]['data']["data"];
  268. $sql = "INSERT INTO sp_d{$data3['device_id']} VALUES ('','{$data3['device_id']}','{$data3['port']}','{$data3['storeTime']}',
  269. '','','','{$data3['data1']}','{$data3['batteyValue']}','5','{$data3['data4']}','11111111111')";
  270. // Log::record('sql1234'.':'.$sql);
  271. $res4 = addDataInfo($sql);
  272. }elseif ($device['deviceType']=='WaterMeter'){
  273. //宇洁容情
  274. Log::record('xinshuibiaozhi'.':'.$getdata["service"]['data']['data']);
  275. $data3 = array();
  276. $data3['device_id'] = $device["device_id"];
  277. $data3['port'] = 'tp_water_pressure';
  278. $data3['storeTime'] = date('Y-m-d H:i:s');
  279. $data3['batteyValue'] = dechex($getdata["service"]['data']["battery"]);
  280. $data3['unit'] =dechex($getdata["service"]['data']['data']);
  281. $data3['device_type'] =dechex($getdata["service"]['data']['device_type']);
  282. $data3['address'] = '180.101.147.89';
  283. $data3['alarmBoolean'] = $getdata["service"]['data']["alarm"];
  284. $alarm=dechex($data3['alarmBoolean']);
  285. $data3['sign'] = round($getdata["service"]['data']["signal"]/6);
  286. $data3['coeffice'] = dechex($getdata["service"]['data']["coeffice"]);
  287. if ($data3['alarmBoolean']!== 0){
  288. if ($data3['alarmBoolean']== 161){
  289. $data3['data1']='WP1';
  290. }else{
  291. $data3['data1']='WP2';
  292. }
  293. }else {
  294. $data3['data1'] = 'WP0';
  295. }
  296. if ($data3['device_type']=='ae'){
  297. switch ($data3['coeffice']){
  298. case 'd3':
  299. $data3['data4'] = $data3['unit']*0.001;
  300. break;
  301. case 'd2':
  302. $data3['data4'] = $data3['unit']*0.01;
  303. break;
  304. case 'd1':
  305. $data3['data4'] = $data3['unit']*0.1;
  306. break;
  307. case 'e0':
  308. $data3['data4'] = $data3['unit'];
  309. break;
  310. case 'e1':
  311. $data3['data4'] = $data3['unit']*10;
  312. break;
  313. case 'e2':
  314. $data3['data4'] = $data3['unit']*100;
  315. break;
  316. }
  317. $sql = "INSERT INTO sp_d{$data3['device_id']} VALUES ('','{$data3['device_id']}','{$data3['port']}','{$data3['storeTime']}',
  318. '','','','{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','11111111111')";
  319. $res5 = addDataInfo($sql);
  320. if ($data3['alarmBoolean']!== 0){
  321. $sql = "INSERT INTO sp_sj2017 VALUES ('','tp_water_pressure','{$data3['device_id']}','{$data3['storeTime']}','$alarm','{$data3['address']}', ''
  322. ,'{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','','','','','','','','','','')";
  323. $insert_id = addDataInfo($sql);
  324. // $sql66="update sp_devices_status set statustime=".$data3['storeTime'];
  325. Log::record('yujie'.':'.$insert_id);
  326. // $update_id = addDataInfo($sql66);
  327. $insert_id_sql="select id from sp_sj2017 where device_code='".$data3['device_id']."' and time='".$data3['storeTime']."'";
  328. Log::record('sql987'.':'.$insert_id_sql);
  329. $insert_id66=add($insert_id_sql);
  330. Log::record('sql253232'.':'.$insert_id66[0]['id']);
  331. if ($data3['alarmBoolean']== 161){
  332. $msg['evt'] = "WP1";
  333. $msg['msg'] = "低压";
  334. }else{ // high
  335. $msg['evt'] = "WP2";
  336. $msg['msg'] = "高压";
  337. }
  338. if ( $msg['evt']=='WP1' || $msg['evt']=='WP2' ) {
  339. $sql3="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["device_id"]}'";
  340. $company = add($sql3);
  341. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%3%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%3%'";
  342. $union_sql=add($sql4);
  343. // Log::record('sql12345'.':'.$sql4);
  344. $openids=$this->array_column1($union_sql,"phone");
  345. if (empty($openids))
  346. {
  347. echo 'open is null';
  348. exit;
  349. }
  350. // Log::record('data666_phone'.':'.$openids);
  351. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  352. $op=add($sql5);
  353. $access_token=GetAccess_Token();
  354. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  355. $deviceid=$device["device_id"];
  356. $type=$msg['msg'];
  357. $time=$data3['storeTime'];
  358. $remark='设备名称:'.$company[0]['owner_name'];
  359. $url_wx_push2 = "https://iot.usky.cn/jdxf/wxapp2.php/Home/Waterwarn/message_water";
  360. Log::record('data666_url_wx_push2'.':'. $url_wx_push2);
  361. $data666['IMEI']=$device["device_id"];
  362. Log::record('data666_IMET'.':'.$data666['IMEI']);
  363. $data666['phone']=$openids;
  364. Log::record('data666_phone'.':'.$data666['phone']);
  365. $data666['evt']=$data3['data1'];
  366. Log::record('data666_evt'.':'.$data666['evt']);
  367. $data666['insert_id']=$insert_id66[0]['id'];
  368. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  369. $data666['time']=$data3['storeTime'];
  370. // Log::record('data666'.':'.$data666);
  371. $sql88="UPDATE sp_devices_status SET statustime ='".$data3['storeTime']."' where deviceid='".$data666['IMEI']."'";
  372. addDataInfo($sql88);
  373. $this->curl($url_wx_push2,$data666);
  374. $waterData["SubType"] = 2;
  375. $waterData["DeviceId"] = $data666['IMEI'];
  376. $waterData["InsertId"] = $insert_id66[0]['id'];
  377. $waterData["Confirmed"] = false;
  378. $data6 = json_encode($waterData);
  379. $rep_url = "http://47.98.201.187:55335/report";
  380. $res = $this->curl($rep_url, $data6);
  381. // $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  382. foreach($op as $key => $o){
  383. if (!empty($o['openid']))
  384. {
  385. // $data88['openid']=$o['openid'];
  386. // $data88['address']=$address;
  387. // $data88['deviceid']=$deviceid;
  388. // $data88['type']=$type;
  389. // $data88['time']=$time;
  390. // $data88['remark']=$remark;
  391. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  392. //{{first.DATA}}$address
  393. //设备号:{{keyword1.DATA}}$deviceid
  394. //报警类型:{{keyword2.DATA}}$type
  395. //时间:{{keyword3.DATA}}$time
  396. //{{remark.DATA}}$remark
  397. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  398. // s_curl($url_wx_push2,$data88);
  399. $Message['openid']=$o['openid'];
  400. $arr[$key]=$Message;
  401. }
  402. }
  403. }
  404. }
  405. }
  406. }elseif ($device['deviceType']=='topsailSensor'){
  407. //拓普索尔
  408. Log::record('tuopusuoershuibiao'.':'.$getdata["service"]['data']['Imei']);
  409. $data3 = array();
  410. $data4 = array();
  411. $data5 = array();
  412. $sensorList = array();
  413. $sensorListArray = array();
  414. $data4['provider'] = 'Usky';
  415. $data3['device_id'] = $device["device_id"];
  416. $data3['port'] = 'TuoPuSuoEr-TSM-04P';
  417. $data3['storeTime'] = date('Y-m-d H:i:s');
  418. $data3['batteyValue'] = $getdata["service"]['data']["batteryLevel"];
  419. $data3['data'] =substr($getdata["service"]['data']["sampleData"],-5);
  420. $data3['unit'] =substr($getdata["service"]['data']["sampleData"],0,1);
  421. $data3['device_type'] =$getdata["service"]['data']['deviceType'];
  422. $data3['sendTime'] =$getdata["service"]['data']['sendTime'];
  423. $data3['address'] = '180.101.147.89';
  424. $data3['alarmBoolean'] = $getdata["service"]['data']["alarmType"];
  425. $data3['sign'] = round($getdata["service"]['data']["signalStrength"]/6);
  426. $sql6="select * from sp_owner where owner_code ='{$device["device_id"]}'";
  427. $longHuCompany = add($sql6);
  428. $sensorList['sensorId'] = (int)$longHuCompany[0]['id'];
  429. if($data3['device_type']==1 || $data3['device_type']==4){
  430. if ($data3['alarmBoolean']!== '0'){
  431. if ($data3['alarmBoolean']== '1'){
  432. $data3['data1']='WP1';
  433. $sensorList['status'] = 3;
  434. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-压力低于下限';
  435. }elseif ($data3['alarmBoolean']== '2'){
  436. $data3['data1']='WP2';
  437. $sensorList['status'] = 4;
  438. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-压力超过上限';
  439. }
  440. }else {
  441. $data3['data1'] = 'WP0';
  442. $sensorList['status'] = 0;
  443. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-压力正常';
  444. }
  445. $data4['deviceType'] = 'XiaoFangShuiYa';
  446. $sensorList['unit'] = 'MPa';
  447. }elseif ($data3['device_type']==2){
  448. if ($data3['alarmBoolean']!== '0'){
  449. if ($data3['alarmBoolean']== '1'){
  450. $data3['data1']='LL1';
  451. $sensorList['status'] = 3;
  452. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-液位低于下限';
  453. }elseif ($data3['alarmBoolean']== '2'){
  454. $data3['data1']='LL2';
  455. $sensorList['status'] = 4;
  456. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-液位超过上限';
  457. }
  458. }else {
  459. $data3['data1'] = 'LL0';
  460. $sensorList['status'] = 0;
  461. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-液位正常';
  462. }
  463. $data4['deviceType'] = 'YeWei';
  464. $sensorList['unit'] = 'm-米';
  465. }
  466. if (!empty($data3['sendTime'])) {
  467. switch ($data3['unit']) {
  468. case '0':
  469. $data3['data4'] = $data3['data'] * 1;
  470. break;
  471. case '1':
  472. $data3['data4'] = $data3['data'] * 0.1;
  473. break;
  474. case '2':
  475. $data3['data4'] = $data3['data'] * 0.01;
  476. break;
  477. case '3':
  478. $data3['data4'] = $data3['data'] * 0.001;
  479. break;
  480. case '4':
  481. $data3['data4'] = $data3['data'] * 0.0001;
  482. break;
  483. }
  484. $sql = "INSERT INTO sp_d{$data3['device_id']} VALUES ('','{$data3['device_id']}','{$data3['port']}','{$data3['storeTime']}',
  485. '','','','{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','11111111111')";
  486. $res5 = addDataInfo($sql);
  487. if ($longHuCompany[0]['company']=='10232'|| $longHuCompany[0]['company']=='10318'){
  488. $data4['dataType'] = 'deviceInfo';
  489. $data4['softVersion'] = '1.00.00';
  490. $data4['hardVersion'] = '0.1';
  491. $sensorList['pointValue'] = $data3['data4'];
  492. $deviceConfigure = Db::name('deviceConfigure')->where('device_code', trim($device["device_id"]))->find();
  493. if(!empty($deviceConfigure)){
  494. $sensorList['lowThreshold'] = (double)$deviceConfigure['low_threshold'];
  495. $sensorList['highThreshold'] = (double)$deviceConfigure['high_threshold'];
  496. $sensorList['sendTime'] = (int)$deviceConfigure['send_time'];
  497. }else{
  498. $sensorList['lowThreshold'] = 0;
  499. $sensorList['highThreshold'] = 0;
  500. $sensorList['sendTime'] = 1800;
  501. }
  502. $sensorListArray[0] = $sensorList;
  503. $data4['sensorList'] = $sensorListArray;
  504. if ($longHuCompany[0]['company']=='10232'){
  505. $data5['mqttId'] = 'a71c40bb-5b02-4741-881b-24449f699db5';
  506. }else{
  507. $data5['mqttId'] = 'a71c40bb-5b02-4741-881b-24449f699db6';
  508. }
  509. $data5['action'] = 'transpush';
  510. $data5['data'] = $data4;
  511. $data6 = json_encode($data5);
  512. $rep_url = "http://47.98.201.73:55126/report";
  513. $res = $this->curl($rep_url,$data6);
  514. Log::record('minhanglonghuduijie'.':'.$res);
  515. }
  516. if ($data3['alarmBoolean']!== '0'){
  517. $sql = "INSERT INTO sp_sj2017 VALUES ('','TuoPuSuoEr-TSM-04P','{$data3['device_id']}','{$data3['storeTime']}','{$data3['alarmBoolean']}','{$data3['address']}', ''
  518. ,'{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','','','','','','','','','','')";
  519. $insert_id = addDataInfo($sql);
  520. // $sql66="update sp_devices_status set statustime=".$data3['storeTime'];
  521. // Log::record('sql66'.':'.$sql66);
  522. // $update_id = addDataInfo($sql66);
  523. $insert_id_sql="select id from sp_sj2017 where device_code='".$data3['device_id']."' and time='".$data3['storeTime']."'";
  524. Log::record('sql98725'.':'.$insert_id_sql);
  525. $insert_id66=add($insert_id_sql);
  526. if($data3['device_type']==1 || $data3['device_type']==4){
  527. if ($data3['alarmBoolean']== '1'){
  528. $msg['evt'] = "WP1";
  529. $msg['msg'] = "低压";
  530. }elseif ($data3['alarmBoolean']== '2'){ // high
  531. $msg['evt'] = "WP2";
  532. $msg['msg'] = "高压";
  533. }
  534. }elseif ($data3['device_type']==2){
  535. if ($data3['alarmBoolean']== '1'){
  536. $msg['evt'] = "LL1";
  537. $msg['msg'] = "低水位";
  538. }elseif ($data3['alarmBoolean']== '2'){ // high
  539. $msg['evt'] = "LL2";
  540. $msg['msg'] = "高水位";
  541. }
  542. }
  543. if ( $msg['evt']=='WP1' || $msg['evt']=='WP2' || $msg['evt']=='LL2' || $msg['evt']=='LL1') {
  544. $sql3="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["device_id"]}'";
  545. $company = add($sql3);
  546. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%3%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%3%'";
  547. $union_sql=add($sql4);
  548. // Log::record('sql12345'.':'.$sql4);
  549. $openids=$this->array_column1($union_sql,"phone");
  550. if (empty($openids))
  551. {
  552. echo 'open is null';
  553. exit;
  554. }
  555. // Log::record('data666_phone'.':'.$openids);
  556. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  557. $op=add($sql5);
  558. $access_token=GetAccess_Token();
  559. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  560. $deviceid=$device["device_id"];
  561. $type=$msg['msg'];
  562. $time=$data3['storeTime'];
  563. $remark='设备名称:'.$company[0]['owner_name'];
  564. $url_wx_push2 = "https://iot.usky.cn/jdxf/wxapp2.php/Home/Waterwarn/message_water";
  565. Log::record('data666_url_wx_push2'.':'. $url_wx_push2);
  566. $data666['IMEI']=$device["device_id"];
  567. Log::record('data666_IMET'.':'.$data666['IMEI']);
  568. $data666['phone']=$openids;
  569. Log::record('data666_phone'.':'.$data666['phone']);
  570. $data666['evt']=$data3['data1'];
  571. Log::record('data666_evt'.':'.$data666['evt']);
  572. $data666['insert_id']=$insert_id66[0]['id'];
  573. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  574. $data666['time']=$data3['storeTime'];
  575. // Log::record('data666'.':'.$data666);
  576. $sql88="UPDATE sp_devices_status SET statustime ='".$data3['storeTime']."' where deviceid='".$data666['IMEI']."'";
  577. addDataInfo($sql88);
  578. $this->curl($url_wx_push2,$data666);
  579. $rep['SubType']=2;
  580. $rep['DeviceId']=$device["device_id"];
  581. $rep['InsertId']=$insert_id66[0]['id'];
  582. $rep['Confirmed']=0;
  583. $rep['CompanyCode']=$company[0]['company'];
  584. $rep['evt_name']=$data3['data1'];
  585. $rep['evt']=0;
  586. $rep['alarm_time']=$data3['storeTime'];
  587. $rep2 = json_encode($rep);
  588. $rep_url = "http://47.98.201.73:55125/report";
  589. $res = $this->curl($rep_url,$rep2);
  590. Log::record('TuoPuSuoEr-TSM-04P'.':'.$res);
  591. // $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  592. foreach($op as $key => $o){
  593. if (!empty($o['openid']))
  594. {
  595. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  596. // s_curl($url_wx_push2,$data88);
  597. $Message['openid']=$o['openid'];
  598. $arr[$key]=$Message;
  599. }
  600. }
  601. }
  602. }
  603. }
  604. }
  605. if ($device['deviceType']=='Smoke') {
  606. if ($getdata["service"]['data']["DeviceStatus"]!== 7){
  607. $arr_bit = array(
  608. "","报警","报警静音","保留","低压","故障","保留"
  609. );
  610. $deviceStatus=$getdata["service"]['data']["DeviceStatus"];
  611. $data3 = array();
  612. $data3['device_code'] = $device["device_id"];
  613. $data3['time'] = date('Y-m-d H:i:s');
  614. $data3['status'] = 'y'.'0'.$deviceStatus;
  615. $data3['address'] = '180.101.147.89';
  616. $data3['compartment'] = '';
  617. $data3['fireprocess'] = '';
  618. $data3['flowendtime'] = '0000-00-00 00:00:00';
  619. $data3['ncmd'] = 'y'.'0'.$deviceStatus;
  620. $data3['data1'] = 'y'.'0'.$deviceStatus;
  621. $data3['data2'] = $arr_bit["{$deviceStatus}"];
  622. $data3['data3'] = '';
  623. $data3['data4'] = '烟雾'.$arr_bit["{$deviceStatus}"];
  624. $data3['data5'] = '';
  625. $sql = "INSERT INTO sp_hj2017 VALUES ('','','{$data3['device_code']}','{$data3['time']}','{$data3['status']}','{$data3['address']}','{$data3['compartment']}',
  626. '{$data3['fireprocess']}', '{$data3['flowendtime']}', '{$data3['ncmd']}','{$data3['data1']}','{$data3['data2']}','{$data3['data3']}','{$data3['data4']}','{$data3['data5']}','','',''
  627. ,'','','','','','')";
  628. $res5 = addDataInfo($sql);
  629. $insert_id_sql="select id from sp_hj2017 where device_code='".$data3['device_code']."' and time='".$data3['time']."'";
  630. Log::record('sql66886688'.':'.$insert_id_sql);
  631. $insert_id66=add($insert_id_sql);
  632. // $sql66="update sp_devices_status set statustime=".$data3['time'];
  633. // Log::record('sql66'.':'.$sql66);
  634. // $update_id = addDataInfo($sql66);
  635. }
  636. $arr_h=array(1,2);
  637. if (in_array($getdata["service"]['data']["DeviceStatus"],$arr_h)){
  638. $sql3="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["device_id"]}'";
  639. Log::record('sql3'.':'.$sql3);
  640. $company = add($sql3);
  641. Log::record('company'.':'.$company[0]['company']);
  642. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%6%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%6%'";
  643. Log::record('sql4'.':'.$sql4);
  644. $union_sql=add($sql4);
  645. $openids=$this->array_column1($union_sql,"phone");
  646. if (empty($openids))
  647. {
  648. echo 'open is null';
  649. exit;
  650. }
  651. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  652. $op=add($sql5);
  653. $access_token=GetAccess_Token();
  654. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  655. $deviceid=$device["device_id"];
  656. $type='烟雾';
  657. $time=$data3['time'];
  658. $remark='设备名称:'.$company[0]['owner_name'];
  659. $url_wx_push2 = "https://iot.usky.cn/jdxf/wxapp2.php/Home/Waterwarn/bj";
  660. Log::record('data666_url_wx_push2'.':'.$url_wx_push2);
  661. $data666['phone']=$openids;
  662. Log::record('data666_phone'.':'.$data666['phone']);
  663. $data666['IMEI']=$device["device_id"];
  664. Log::record('data666_IMEI'.':'.$data666['IMEI']);
  665. $data666['time']=$data3['time'];
  666. Log::record('data666_time'.':'.$data666['time']);
  667. $data666['evt']=$data3['data1'];
  668. Log::record('data666_evt'.':'.$data666['evt']);
  669. $data666['insert_id']=$insert_id66[0]['id'];
  670. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  671. $this->curl($url_wx_push2,$data666);
  672. foreach($op as $key => $o){
  673. if (!empty($o['openid']))
  674. {
  675. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  676. // s_curl($url_wx_push2,$data88);
  677. $Message['openid']=$o['openid'];
  678. $arr[$key]=$Message;
  679. }
  680. }
  681. }
  682. } elseif($device['deviceType']=='MultiSensor') {
  683. if($getdata["service"]['data']["alarmBoolean"]== 17){
  684. // $sql1="SELECT * from 'dev_' . {$device["device_id"]} where addtime=(select max(addtime) from 'dev_' . {$device["device_id"]})";
  685. // $Model = M();
  686. // $result = $Model->query($sql1);
  687. // $service=json_decode($result['']['service']);
  688. $unit=dechex($getdata["service"]['data']["unit"]);
  689. $data3 = array();
  690. $data3['device_code'] = $device["device_id"];
  691. $data3['time'] = date('Y-m-d H:i:s');
  692. $data3['status'] = $getdata["service"]['data']["alarmBoolean"];
  693. $data3['address'] = '180.101.147.89';
  694. $data3['ncmd'] = '';
  695. $data3['unit'] =$getdata["service"]['data']["unit"];
  696. $arr_y=array('10','11','20','21','22');
  697. $sql11="SELECT dwtype FROM sp_owner WHERE owner_code ='{$device["device_id"]}'";
  698. $dwtype = add($sql11);
  699. if ($dwtype[0]['dwtype'] == 5){
  700. if ($data3['unit']== 1){
  701. $data3['data1']='LL2';
  702. }elseif($data3['unit']== 2){
  703. $data3['data1']='LL1';
  704. }else{
  705. $data3['data1']='LL0';
  706. }
  707. }else {
  708. if ($data3['unit']== 1){
  709. $data3['data1']='WP2';
  710. }elseif($data3['unit']== 2){
  711. $data3['data1']='WP1';
  712. }else{
  713. $data3['data1']='WP0';
  714. }
  715. }
  716. $data3['data2'] = $getdata["service"]['data']["batteyValue"];
  717. $data3['data3'] = '';
  718. switch ($unit){
  719. case '10':
  720. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  721. break;
  722. case '11':
  723. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  724. break;
  725. case '20':
  726. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  727. break;
  728. case '21':
  729. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  730. break;
  731. case '22':
  732. $data3['data4'] = $getdata["service"]['data']["data"];
  733. break;
  734. case '30':
  735. $data3['data4'] = $getdata["service"]['data']["data"]*0.0000001;
  736. break;
  737. case '31':
  738. $data3['data4'] = $getdata["service"]['data']["data"]*0.000001;
  739. break;
  740. case '40':
  741. $data3['data4'] = $getdata["service"]['data']["data"]*0.00001;
  742. break;
  743. case '41':
  744. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  745. break;
  746. case '42':
  747. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  748. break;
  749. case '50':
  750. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  751. break;
  752. case '51':
  753. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  754. break;
  755. case '52':
  756. $data3['data4'] = $getdata["service"]['data']["data"];
  757. break;
  758. case '2':
  759. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  760. break;
  761. case '1':
  762. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  763. break;
  764. }
  765. $data3['data5'] = '';
  766. $sql = "INSERT INTO sp_sj2017 VALUES ('','tp_water_pressure','{$data3['device_code']}','{$data3['time']}','{$data3['status']}','{$data3['address']}', '{$data3['ncmd']}'
  767. ,'{$data3['data1']}','{$data3['data2']}','{$data3['data3']}','{$data3['data4']}','{$data3['data5']}','','','','','','','','','')";
  768. // Log::record('sql123'.':'.$sql);
  769. $insert_id = addDataInfo($sql);
  770. $insert_id_sql="select id from sp_sj2017 where device_code='".$data3['device_id']."' and time='".$data3['time']."'";
  771. Log::record('sql987253232'.':'.$insert_id_sql);
  772. $insert_id66=add($insert_id_sql);
  773. if ($dwtype[0]['dwtype'] == 5) {
  774. if ($getdata["service"]['data']["unit"] == '1') {
  775. $msg['evt'] = "WP2";
  776. $msg['msg'] = "高水位";
  777. } elseif ($getdata["service"]['data']["unit"] == '2') { // high
  778. $msg['evt'] = "WP1";
  779. $msg['msg'] = "低水位";
  780. }
  781. }else{
  782. if ($getdata["service"]['data']["unit"] == '1') {
  783. $msg['evt'] = "WP2";
  784. $msg['msg'] = "高压";
  785. } elseif ($getdata["service"]['data']["unit"] == '2') { // high
  786. $msg['evt'] = "WP1";
  787. $msg['msg'] = "低压";
  788. }
  789. }
  790. if ( $msg['evt']=='WP1' || $msg['evt']=='WP2' ) {
  791. $sql3="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["device_id"]}'";
  792. $company = add($sql3);
  793. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%3%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%3%'";
  794. $union_sql=add($sql4);
  795. Log::record('sql12345'.':'.$sql4);
  796. $openids=$this->array_column1($union_sql,"phone");
  797. if (empty($openids))
  798. {
  799. echo 'open is null';
  800. exit;
  801. }
  802. Log::record('data666_phone'.':'.$openids);
  803. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  804. $op=add($sql5);
  805. $access_token=GetAccess_Token();
  806. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  807. $deviceid=$device["device_id"];
  808. $type=$msg['msg'];
  809. $time=$data3['time'];
  810. $remark='设备名称:'.$company[0]['owner_name'];
  811. //
  812. $url_wx_push2 = "https://iot.usky.cn/jdxf/wxapp2.php/Home/Waterwarn/message_water";
  813. Log::record('data666_url_wx_push2'.':'. $url_wx_push2);
  814. $data666['IMEI']=$device["device_id"];
  815. Log::record('data666_IMET'.':'.$data666['IMEI']);
  816. $data666['phone']=$openids;
  817. Log::record('data666_phone'.':'.$data666['phone']);
  818. $data666['evt']=$data3['data1'];
  819. Log::record('data666_evt'.':'.$data666['evt']);
  820. $data666['insert_id']=$insert_id66[0]['id'];
  821. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  822. $data666['time']=$data3['time'];
  823. // Log::record('data666'.':'.$data666);
  824. $sql88="UPDATE sp_devices_status SET statustime ='".$data3['time']."' where deviceid='".$data666['IMEI']."'";
  825. addDataInfo($sql88);
  826. $this->curl($url_wx_push2,$data666);
  827. // $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  828. foreach($op as $key => $o){
  829. if (!empty($o['openid']))
  830. {
  831. // $data88['openid']=$o['openid'];
  832. // $data88['address']=$address;
  833. // $data88['deviceid']=$deviceid;
  834. // $data88['type']=$type;
  835. // $data88['time']=$time;
  836. // $data88['remark']=$remark;
  837. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  838. //{{first.DATA}}$address
  839. //设备号:{{keyword1.DATA}}$deviceid
  840. //报警类型:{{keyword2.DATA}}$type
  841. //时间:{{keyword3.DATA}}$time
  842. //{{remark.DATA}}$remark
  843. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  844. // s_curl($url_wx_push2,$data88);
  845. $Message['openid']=$o['openid'];
  846. $arr[$key]=$Message;
  847. }
  848. }
  849. }
  850. }
  851. }
  852. }
  853. return json_encode($data, 320);
  854. }
  855. }
  856. public function addtuobaodata(){
  857. if ($this->request->isPost()) {
  858. $data = input('');
  859. $list = array();
  860. if (is_array($data)) {
  861. $list['data'] = json_encode($data, 320);
  862. $getdata = json_decode($list['data'], true);//转成数组
  863. $list['type'] = 1;
  864. } else {
  865. $list['data'] = $data;
  866. $getdata = json_decode($list['data'], true);//转成数组
  867. $list['type'] = 2;
  868. }
  869. // $list['data']=11;
  870. $list['response'] = "222";
  871. $list['notifyType'] = $getdata["notifyType"];
  872. $list['deviceId'] = $getdata["deviceId"];
  873. $list['addtime'] = date('Y-m-d H:i:s');
  874. $res = Db::name('noticedata')->insertGetId($list);//将推送的数据存入总表
  875. if (trim($getdata["notifyType"]) == "deviceDataChanged") {
  876. $device = Db::name('device')->where('iot_id', trim($getdata["deviceId"]))->find();
  877. Log::record('tuobaoceshi123' . ':' . $device["device_id"]);
  878. $datainfo = array();
  879. $datainfo['notifyType'] = $getdata["notifyType"];
  880. $datainfo['device_id'] = $device["device_id"];
  881. $datainfo['iot_id'] = $getdata["deviceId"];
  882. $datainfo['service'] = json_encode($getdata["service"]);
  883. $datainfo['addtime'] = date('Y-m-d H:i:s');
  884. $res1 = Db::table('dev_' . $device["device_id"])->insertGetId($datainfo);
  885. if ($device['deviceType']=='SaiTeSmoke') {
  886. $data3 = array();
  887. $data3['device_id'] = $device["device_id"];
  888. $data3['RSRQ'] = $getdata["service"]['data']['RSRP'];
  889. $data3['CSQ'] = $getdata["service"]['data']["CSQ"];
  890. $data3['DeviceType'] = 1;
  891. if ($getdata["service"]['data']["Alarm_Status"]!== 7) {
  892. $data3['DeviceStatus'] = 1;
  893. }else{
  894. $data3['DeviceStatus'] = 7;
  895. }
  896. $data3['BatteryLevel'] = $getdata["service"]['data']["Battery_Level"];
  897. $data3['SensorLevel'] = $getdata["service"]['data']["AlarmLevel"];
  898. $data3['TData'] = $getdata["service"]['data']["TData"];
  899. $data3['eventTime'] = $getdata["service"]["eventTime"];
  900. $data3['storeTime'] = date('Y-m-d H:i:s');
  901. $sql = "INSERT INTO sp_y{$data3['device_id']} VALUES ('','{$data3['device_id']}',
  902. '{$data3['RSRQ']}', '{$data3['CSQ']}', '{$data3['DeviceType']}','{$data3['DeviceStatus']}','{$data3['BatteryLevel']}','{$data3['SensorLevel']}','{$data3['eventTime']}','{$data3['storeTime']}','{$data3['TData']}')";
  903. $res3 = addDataInfo($sql);
  904. if ($getdata["service"]['data']["Alarm_Status"]!== 7){
  905. $arr_bit = array(
  906. "","报警","静音","保留","低压","故障","数据异常","","设备收到单次静音指令","设备收到连续静音指令","拆卸报警","拆卸恢复","","","模拟报警"
  907. );
  908. $deviceStatus=$getdata["service"]['data']["Alarm_Status"];
  909. $data3 = array();
  910. $data3['device_code'] = $device["device_id"];
  911. $data3['time'] = date('Y-m-d H:i:s');
  912. $data3['status'] = 'y'.'0'.$deviceStatus;
  913. $data3['address'] = '180.101.147.89';
  914. $data3['compartment'] = '';
  915. $data3['fireprocess'] = '';
  916. $data3['flowendtime'] = '0000-00-00 00:00:00';
  917. $data3['ncmd'] = 'y'.'01';
  918. $data3['data1'] = 'y'.'01';
  919. $data3['data2'] = $arr_bit["{$deviceStatus}"];
  920. $data3['data3'] = '';
  921. $data3['data4'] = '烟雾'.$arr_bit["{$deviceStatus}"];
  922. $data3['data5'] = '';
  923. $sql = "INSERT INTO sp_hj2017 VALUES ('','','{$data3['device_code']}','{$data3['time']}','{$data3['status']}','{$data3['address']}','{$data3['compartment']}',
  924. '{$data3['fireprocess']}', '{$data3['flowendtime']}', '{$data3['ncmd']}','{$data3['data1']}','{$data3['data2']}','{$data3['data3']}','{$data3['data4']}','{$data3['data5']}','','',''
  925. ,'','','','','','')";
  926. $res5 = addDataInfo($sql);
  927. $insert_id_sql="select id from sp_hj2017 where device_code='".$data3['device_code']."' and time='".$data3['time']."'";
  928. Log::record('sql6688668866'.':'.$insert_id_sql);
  929. $insert_id66=add($insert_id_sql);
  930. $arr_h=array(1,2,6,8,9,10,11,14);
  931. if (in_array($getdata["service"]['data']["Alarm_Status"],$arr_h)){
  932. $sql3="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["device_id"]}'";
  933. Log::record('sql3'.':'.$sql3);
  934. $company = add($sql3);
  935. Log::record('company'.':'.$company[0]['company']);
  936. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%6%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%6%'";
  937. Log::record('sql4'.':'.$sql4);
  938. $union_sql=add($sql4);
  939. $openids=$this->array_column1($union_sql,"phone");
  940. if (empty($openids))
  941. {
  942. echo 'open is null';
  943. exit;
  944. }
  945. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  946. $op=add($sql5);
  947. $access_token=GetAccess_Token();
  948. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  949. $deviceid=$device["device_id"];
  950. $type='烟雾';
  951. $time=$data3['time'];
  952. $remark='设备名称:'.$company[0]['owner_name'];
  953. if($getdata["service"]['data']["Alarm_Status"]==5){
  954. $deviceStatus1='y05';
  955. }elseif ($getdata["service"]['data']["Alarm_Status"]==1){
  956. $deviceStatus1='y01';
  957. }elseif ($getdata["service"]['data']["Alarm_Status"]==10){
  958. $deviceStatus1='y10';
  959. }elseif ($getdata["service"]['data']["Alarm_Status"]==14){
  960. $deviceStatus1='y12';
  961. }
  962. $url_wx_push2 = "https://iot.usky.cn/jdxf/wxapp2.php/Home/Waterwarn/bj";
  963. Log::record('data666_url_wx_push2'.':'.$url_wx_push2);
  964. $data666['phone']=$openids;
  965. Log::record('data666_phone'.':'.$data666['phone']);
  966. $data666['IMEI']=$device["device_id"];
  967. Log::record('data666_IMEI'.':'.$data666['IMEI']);
  968. $data666['time']=$data3['time'];
  969. Log::record('data666_time'.':'.$data666['time']);
  970. $data666['evt']=$deviceStatus1;
  971. Log::record('data666_evt'.':'.$data666['evt']);
  972. $data666['insert_id']=$insert_id66[0]['id'];
  973. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  974. $this->curl($url_wx_push2,$data666);
  975. foreach($op as $key => $o){
  976. if (!empty($o['openid']))
  977. {
  978. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  979. // s_curl($url_wx_push2,$data88);
  980. $Message['openid']=$o['openid'];
  981. $arr[$key]=$Message;
  982. }
  983. }
  984. }
  985. }
  986. }
  987. }
  988. }
  989. }
  990. public function jingan(){
  991. if ($this->request->isPost()) {
  992. Log::record('jinganxiaofang' . ':ceshi');
  993. $data = input('');
  994. /* $rand=rand(0,2);
  995. $header=["Content-Type:application/json"];
  996. //将数据分配给不同的服务
  997. $httpserver=["http://47.98.153.212:1101","http://47.98.153.212:1102","http://47.98.153.212:1103"];
  998. $server=$httpserver[$rand];
  999. //将数据随机转发到别的平台做处理
  1000. $res=curltest($server,$data,$header);
  1001. */
  1002. $list = array();
  1003. if (is_array($data)) {
  1004. $list['data'] = json_encode($data, 320);
  1005. $getdata = json_decode($list['data'], true);//转成数组
  1006. } else {
  1007. $list['data'] = $data;
  1008. $getdata = json_decode($list['data'], true);//转成数组
  1009. }
  1010. // $list['data']=11;
  1011. // $list['response'] = "111";
  1012. //
  1013. // $list['notifyType'] = $getdata["notifyType"];
  1014. // $list['deviceId'] = $getdata["deviceId"];
  1015. // $list['addtime'] = date('Y-m-d H:i:s');
  1016. $res = Db::name('jingandata')->insertGetId($list);//将推送的数据存入总表
  1017. Log::record('jinganxiaofang' . ':' . $res);
  1018. $Data = array();
  1019. $Data['app_key'] = $getdata["app_key"];
  1020. $Data['timestamp'] = date('Y-m-d H:i:s',$getdata["timestamp"]);
  1021. $Data['format'] = $getdata["format"];
  1022. $Data['v'] = $getdata["v"];
  1023. $Data['sign_method'] = $getdata["sign_method"];
  1024. $Data['pid'] = $getdata["pid"];
  1025. $Data['bid'] = $getdata["bid"];
  1026. $Data['fid'] = $getdata["fid"];
  1027. $Data['supervise_id'] = $getdata["supervise_id"];
  1028. if (empty($getdata["supervise_code"])){
  1029. $Data['supervise_code']="";
  1030. }else{
  1031. $Data['supervise_code'] = $getdata["supervise_code"];
  1032. }
  1033. $Data['status'] = $getdata["status"];
  1034. $Data['content'] = $getdata["content"];
  1035. $Data['type'] = $getdata["type"];
  1036. if (empty($getdata["device_id"])){
  1037. $Data['device_id']="";
  1038. }else{
  1039. $Data['device_id'] = $getdata["device_id"];
  1040. }
  1041. if (empty($getdata["aid"])){
  1042. $Data['aid']="";
  1043. }else{
  1044. $Data['aid'] = $getdata["aid"];
  1045. }
  1046. if (empty($getdata["loop_number"])){
  1047. $Data['loop_number']="";
  1048. }else{
  1049. $Data['loop_number'] = $getdata["loop_number"];
  1050. }
  1051. if (empty($getdata["position_number"])){
  1052. $Data['position_number']="";
  1053. }else{
  1054. $Data['position_number'] = $getdata["position_number"];
  1055. }
  1056. if (empty($getdata["mainframe_id"])){
  1057. $Data['mainframe_id']="";
  1058. }else{
  1059. $Data['mainframe_id'] = $getdata["mainframe_id"];
  1060. }
  1061. $Data['sign'] = $getdata["sign"];
  1062. if ($Data['app_key']=="f8bdea7926bcc7cb827d2eccf67fa559"){
  1063. $sql3="select device_name,company_code from sp_huangpu_share where pid='{$getdata["pid"]}' GROUP BY company_code";
  1064. }else if ($Data['app_key']=="9e555b8b2244ebc1f59695824b86c5a0"){
  1065. $sql3="select device_name,company_code from sp_jingan_share where pid='{$getdata["pid"]}' and bid='{$getdata["bid"]}' and fid='{$getdata["fid"]}' GROUP BY company_code";
  1066. }
  1067. $company = add($sql3);
  1068. $Data['company_code'] = $company[0]['company_code'];
  1069. $res1 = Db::name('jinganAnalysisData')->insertGetId($Data);
  1070. $url_wx_data = "https://iot.usky.cn/jdxf/wxapp2.php/Home/WorkOrderNotice/message_workordernotice";
  1071. $data_wx['company_code'] = $company[0]['company_code'];
  1072. $data_wx['time']=$Data['timestamp'];
  1073. $data_wx['title']=$Data['content'];
  1074. $data_wx['id']=$res1;
  1075. $data_wx['types']=2;
  1076. if($getdata["status"]==0){
  1077. $this->s_curl($url_wx_data,$data_wx);
  1078. }
  1079. return "success";
  1080. }
  1081. }
  1082. public function jinganPerson(){
  1083. if ($this->request->isPost()) {
  1084. Log::record('jinganxiaofangren' . ':ceshi');
  1085. $data = input('');
  1086. $list = array();
  1087. $data_list = array();
  1088. if (is_array($data)) {
  1089. $list['data'] = json_encode($data, 320);
  1090. $getdata = json_decode($list['data'], true);//转成数组
  1091. } else {
  1092. $list['data'] = $data;
  1093. $getdata = json_decode($list['data'], true);//转成数组
  1094. }
  1095. // $list['data']=11;
  1096. // $list['response'] = "111";
  1097. $res = Db::name('jinganperson')->insertGetId($list);//将推送的数据存入总表
  1098. Log::record('jinganxiaofangren' . ':' . $res);
  1099. $data_list['app_key'] = $getdata["app_key"];
  1100. $data_list['timestamp'] = date('Y-m-d H:i:s',$getdata["timestamp"]);
  1101. $data_list['format'] = $getdata["format"];
  1102. $data_list['version'] = $getdata["v"];
  1103. $data_list['sign_method'] = $getdata["sign_method"];
  1104. $data_list['artificial_id'] = $getdata["artificial_id"];
  1105. $data_list['pid'] = $getdata["pid"];
  1106. $data_list['artificial_code'] = $getdata["artificial_code"];
  1107. $data_list['company_id'] = $getdata["company_id"];
  1108. $data_list['content'] = $getdata["content"];
  1109. $data_list['status'] = $getdata["status"];
  1110. $data_list['sign'] = $getdata["sign"];
  1111. $device = Db::name('person_data')->where('artificial_id', trim( $data_list['artificial_id']))->find();
  1112. if($device){
  1113. return "success";
  1114. }else{
  1115. if ($data_list['app_key']=="f8bdea7926bcc7cb827d2eccf67fa559"){
  1116. $sql3="select device_name,company_code from sp_huangpu_share where pid='{$getdata["pid"]}' GROUP BY company_code";
  1117. }else if ($data_list['app_key']=="9e555b8b2244ebc1f59695824b86c5a0"){
  1118. $sql3="select device_name,company_code from sp_jingan_share where pid='{$getdata["pid"]}' GROUP BY company_code";
  1119. }
  1120. $company = add($sql3);
  1121. $data_list['company_code'] = $company[0]['company_code'];
  1122. $res1 = Db::name('person_data')->insertGetId($data_list);//将推送的数据存入解析表
  1123. Log::record('person_data_list'.':'.$getdata["content"]);
  1124. $url_wx_data = "https://iot.usky.cn/jdxf/wxapp2.php/Home/WorkOrderNotice/message_workordernotice";
  1125. $data_wx['company_code']=$company[0]['company_code'];
  1126. $data_wx['time']=$data_list['timestamp'];
  1127. $data_wx['title']=$data_list['content'];
  1128. $data_wx['id']=$res1;
  1129. $data_wx['types']=1;
  1130. $this->s_curl($url_wx_data,$data_wx);
  1131. return "success";
  1132. }
  1133. }
  1134. }
  1135. public function aepceshi(){
  1136. if ($this->request->isPost()) {
  1137. Log::record('aep' . ':ceshi');
  1138. $data = input('');
  1139. /* $rand=rand(0,2);
  1140. $header=["Content-Type:application/json"];
  1141. //将数据分配给不同的服务
  1142. $httpserver=["http://47.98.153.212:1101","http://47.98.153.212:1102","http://47.98.153.212:1103"];
  1143. $server=$httpserver[$rand];
  1144. //将数据随机转发到别的平台做处理
  1145. $res=curltest($server,$data,$header);
  1146. */
  1147. $list = array();
  1148. if (is_array($data)) {
  1149. $list['data'] = json_encode($data, 320);
  1150. $getdata = json_decode($list['data'], true);//转成数组
  1151. } else {
  1152. $list['data'] = $data;
  1153. $getdata = json_decode($list['data'], true);//转成数组
  1154. }
  1155. // $list['data']=11;
  1156. // $list['response'] = "111";
  1157. //
  1158. // $list['notifyType'] = $getdata["notifyType"];
  1159. // $list['deviceId'] = $getdata["deviceId"];
  1160. // $list['addtime'] = date('Y-m-d H:i:s');
  1161. $res = Db::name('nb_aep')->insertGetId($list);//将推送的数据存入总表
  1162. Log::record('aep' . ':' . $res);
  1163. return json_encode($data, 320);
  1164. }
  1165. }
  1166. public function longHuConfigure(){
  1167. if ($this->request->isPost()) {
  1168. $data = input('');
  1169. $list = array();
  1170. $set_data = array();
  1171. if (is_array($data)) {
  1172. $list['data'] = json_encode($data, 320);
  1173. $getdata = json_decode($list['data'], true);//转成数组
  1174. } else {
  1175. $list['data'] = $data;
  1176. $getdata = json_decode($list['data'], true);//转成数组
  1177. }
  1178. if ($getdata["dataType"]=="setting"){
  1179. $sql="SELECT owner_code FROM sp_owner WHERE id ={$getdata["sensorId"]}";
  1180. $owner_code = add($sql);
  1181. $imei='&imei='.$owner_code[0]['owner_code'];
  1182. if ($getdata["deviceType"]=="XiaoFangShuiYa"){
  1183. $deviceType='&deviceType='.'1';
  1184. }elseif ($getdata["deviceType"]=="YeWei"){
  1185. $deviceType='&deviceType='.'2';
  1186. }
  1187. $sendingGap = '';
  1188. if (!empty($getdata["sendTime"])){
  1189. $sendingGap = '&sendingGap='.$getdata["sendTime"];
  1190. }
  1191. $unipathThresholdLimit = '';
  1192. if (!empty($getdata["lowThreshold"])){
  1193. $unipathThresholdLimit = '&unipathThresholdLimit='.$getdata["lowThreshold"]*1000;
  1194. }
  1195. $unipathThresholdUpper = '';
  1196. if (!empty($getdata["highThreshold"])){
  1197. $unipathThresholdUpper = '&unipathThresholdUpper='.$getdata["highThreshold"]*1000;
  1198. }
  1199. $data6 = json_encode($set_data);
  1200. $rep_url = "https://api.topsailiot.com/dmp/deviceConfig?appkey=3a3e533818a9604dfec0388b2d817dbc2f9f7b05dd4b153c403897cd93a9c04d0edfe3d86ebd3ad0&userid=TS2020120110122980052".$imei.$deviceType.$sendingGap.$unipathThresholdLimit.$unipathThresholdUpper;
  1201. $res = $this->s_curl($rep_url,'');
  1202. Log::record('longhu' . ':' . $rep_url);
  1203. return $res;
  1204. }else{
  1205. $res_arr = array();
  1206. $res_arr['code'] = 60001;
  1207. $res_arr['msg'] = "dataType参数有误";
  1208. $res_arr['data'] = "";
  1209. $res = json_encode($res_arr);
  1210. Log::record('longhuerror' . ':' . $res);
  1211. return $res;
  1212. }
  1213. }
  1214. }
  1215. public function longhudata(){
  1216. if ($this->request->isPost()) {
  1217. $data = input('');
  1218. $list = array();
  1219. $set_data = array();
  1220. if (is_array($data)) {
  1221. $list['data'] = json_encode($data, 320);
  1222. $getdata = json_decode($list['data'], true);//转成数组
  1223. } else {
  1224. $list['data'] = $data;
  1225. $getdata = json_decode($list['data'], true);//转成数组
  1226. }
  1227. if ($getdata["user_from"]=="longHuWater"){
  1228. $sql6="select * from sp_owner where owner_code ='{$getdata["device_code"]}'";
  1229. $longHuCompany = add($sql6);
  1230. $sensorList['sensorId'] = (int)$longHuCompany[0]['id'];
  1231. $sensorList['status'] = 0;
  1232. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-压力正常';
  1233. $data4['deviceType'] = 'XiaoFangShuiYa';
  1234. $sensorList['unit'] = 'MPa';
  1235. $data4['dataType'] = 'deviceInfo';
  1236. $data4['provider'] = 'Usky';
  1237. $data4['softVersion'] = '1.00.00';
  1238. $data4['hardVersion'] = '0.1';
  1239. $sensorList['pointValue'] = (double)$getdata['device_value'];
  1240. $deviceConfigure = Db::name('deviceConfigure')->where('device_code', trim($getdata["device_code"]))->find();
  1241. if (!empty($deviceConfigure)) {
  1242. $sensorList['lowThreshold'] = (double)$deviceConfigure['low_threshold'];
  1243. $sensorList['highThreshold'] = (double)$deviceConfigure['high_threshold'];
  1244. $sensorList['sendTime'] = (int)$deviceConfigure['send_time'];
  1245. } else {
  1246. $sensorList['lowThreshold'] = 0;
  1247. $sensorList['highThreshold'] = 0;
  1248. $sensorList['sendTime'] = 1800;
  1249. }
  1250. $sensorListArray[0] = $sensorList;
  1251. $data4['sensorList'] = $sensorListArray;
  1252. if ($longHuCompany[0]['company']=='10232'){
  1253. $data5['mqttId'] = 'a71c40bb-5b02-4741-881b-24449f699db5';
  1254. }else{
  1255. $data5['mqttId'] = 'a71c40bb-5b02-4741-881b-24449f699db6';
  1256. }
  1257. $data5['action'] = 'transpush';
  1258. $data5['data'] = $data4;
  1259. $data6 = json_encode($data5);
  1260. $rep_url = "http://47.98.201.73:55126/report";
  1261. $res = $this->curl($rep_url, $data6);
  1262. Log::record('minhanglonghuduijie' . ':' . $res);
  1263. $res_arr = array();
  1264. $res_arr['code'] = 200;
  1265. $res_arr['msg'] = "操作成功";
  1266. $res_arr['data'] = "";
  1267. $res1 = json_encode($res_arr);
  1268. return $res1;
  1269. }else if ($getdata["user_from"]=="longHuWaterAlarm"){
  1270. $sql6="select * from sp_owner where owner_code ='{$getdata["device_code"]}'";
  1271. $longHuCompany = add($sql6);
  1272. $sensorList['sensorId'] = (int)$longHuCompany[0]['id'];
  1273. $sql7="select * from sp_sj2017 where id ={$getdata['device_value']}";
  1274. $longHuAlarm = add($sql7);
  1275. if ($longHuAlarm[0]['data1']=='WP1'){
  1276. $sensorList['status'] = 3;
  1277. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-压力低于下限';
  1278. }elseif ($longHuAlarm[0]['data1']=='WP2'){
  1279. $sensorList['status'] = 4;
  1280. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-压力超过上限';
  1281. }elseif ($longHuAlarm[0]['data1']=='WP3'){
  1282. $sensorList['status'] = 1;
  1283. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$longHuCompany[0]['owner_name'].'-设备故障';
  1284. }
  1285. $data4['deviceType'] = 'XiaoFangShuiYa';
  1286. $sensorList['unit'] = 'MPa';
  1287. $data4['dataType'] = 'deviceInfo';
  1288. $data4['softVersion'] = '1.00.00';
  1289. $data4['hardVersion'] = '0.1';
  1290. $sensorList['pointValue'] = (double)$longHuAlarm[0]['data4'];
  1291. $deviceConfigure = Db::name('deviceConfigure')->where('device_code', trim($getdata["device_code"]))->find();
  1292. if (!empty($deviceConfigure)) {
  1293. $sensorList['lowThreshold'] = (double)$deviceConfigure['low_threshold'];
  1294. $sensorList['highThreshold'] = (double)$deviceConfigure['high_threshold'];
  1295. $sensorList['sendTime'] = (int)$deviceConfigure['send_time'];
  1296. } else {
  1297. $sensorList['lowThreshold'] = 0;
  1298. $sensorList['highThreshold'] = 0;
  1299. $sensorList['sendTime'] = 1800;
  1300. }
  1301. $sensorListArray[0] = $sensorList;
  1302. $data4['sensorList'] = $sensorListArray;
  1303. $data5['mqttId'] = 'a71c40bb-5b02-4741-881b-24449f699db5';
  1304. $data5['action'] = 'transpush';
  1305. $data5['data'] = $data4;
  1306. $data6 = json_encode($data5);
  1307. $rep_url = "http://47.98.201.73:55126/report";
  1308. $res = $this->curl($rep_url, $data6);
  1309. Log::record('minhanglonghuduijie' . ':' . $res);
  1310. $res_arr = array();
  1311. $res_arr['code'] = 200;
  1312. $res_arr['msg'] = "操作成功";
  1313. $res_arr['data'] = "";
  1314. $res1 = json_encode($res_arr);
  1315. return $res1;
  1316. }else if ($getdata["user_from"]=="xingYueHuiRtuWater"){
  1317. Log::record('xingyuehui' . ':' . $getdata["device_code"]);
  1318. $sql6="select * from sp_owner where owner_code ='{$getdata["device_code"]}'";
  1319. $longHuCompany = add($sql6);
  1320. $sensorList['sensorId'] = (int)$longHuCompany[0]['id'].(int)$getdata["port"];
  1321. $sensorList['status'] = 0;
  1322. $sensorList['desc'] = $longHuCompany[0]['unitinfo'].'-'.$getdata["port_name"].'-压力正常';
  1323. $data4['deviceType'] = 'XiaoFangShuiYa';
  1324. $sensorList['unit'] = 'MPa';
  1325. $data4['dataType'] = 'deviceInfo';
  1326. $data4['provider'] = 'Usky';
  1327. $data4['softVersion'] = '1.00.00';
  1328. $data4['hardVersion'] = '0.1';
  1329. $sensorList['pointValue'] = (double)$getdata['device_value'];
  1330. $deviceConfigure = Db::name('deviceConfigure')->where('device_code', trim($getdata["device_code"]))->find();
  1331. if (!empty($deviceConfigure)) {
  1332. $sensorList['lowThreshold'] = (double)$deviceConfigure['low_threshold'];
  1333. $sensorList['highThreshold'] = (double)$deviceConfigure['high_threshold'];
  1334. $sensorList['sendTime'] = (int)$deviceConfigure['send_time'];
  1335. } else {
  1336. $sensorList['lowThreshold'] = 0;
  1337. $sensorList['highThreshold'] = 0;
  1338. $sensorList['sendTime'] = 1800;
  1339. }
  1340. $sensorListArray[0] = $sensorList;
  1341. $data4['sensorList'] = $sensorListArray;
  1342. if ($longHuCompany[0]['company']=='10232'){
  1343. $data5['mqttId'] = 'a71c40bb-5b02-4741-881b-24449f699db5';
  1344. }else{
  1345. $data5['mqttId'] = 'a71c40bb-5b02-4741-881b-24449f699db6';
  1346. }
  1347. $data5['action'] = 'transpush';
  1348. $data5['data'] = $data4;
  1349. $data6 = json_encode($data5);
  1350. $rep_url = "http://47.98.201.73:55126/report";
  1351. $res = $this->curl($rep_url, $data6);
  1352. Log::record('minhanglonghuduijie' . ':' . $res);
  1353. $res_arr = array();
  1354. $res_arr['code'] = 200;
  1355. $res_arr['msg'] = "操作成功";
  1356. $res_arr['data'] = "";
  1357. $res1 = json_encode($res_arr);
  1358. return $res1;
  1359. }else{
  1360. $res_arr = array();
  1361. $res_arr['code'] = 60001;
  1362. $res_arr['msg'] = "user_from参数有误";
  1363. $res_arr['data'] = "";
  1364. $res = json_encode($res_arr);
  1365. Log::record('longhuerror' . ':' . $res);
  1366. return $res;
  1367. }
  1368. }
  1369. }
  1370. public function testdata1(){
  1371. $rand=rand(0,2);
  1372. $data=[
  1373. '{"notifyType":"deviceDataChanged","deviceId":"a1d88da9-5156-4507-995a-bb20af09001a","gatewayId":"a1d88da9-5156-4507-995a-bb20af09001a","requestId":null,"service":{"serviceId":"hxkcnbdtu","serviceType":"hxkcnbdtu","data":{"deviceAddress":"868744030057305","framenumber":0,"framenum":0,"frameser":0,"voltage":3.6,"rsrp":-99.9,"snr":67,"ecl":0,"csq":11,"cellid":"0125145939","reportway":0,"cycle":1600,"setmode":3,"settime":"3-00","freezday":"28-02","nbtime":"18-09-21 10:30:15","pressure":0.7455,"alarm_en":0,"alarm_time":60,"down_alarm_pre":0,"up_alarm_pre":0,"pre_status":0,"log":"7E64E7834300000011395914250100064003030028021809211030151811112222011F1D0000003C00000000000000000000000000","eventTime":"2018-09-21 10:30:17"},"eventTime":"20180921T023017Z"}}',
  1374. '{"notifyType":"deviceDataChanged","deviceId":"a1d88da9-5156-4507-995a-bb20af09001a","gatewayId":"a1d88da9-5156-4507-995a-bb20af09001a","requestId":null,"service":{"serviceId":"hxkcnbdtu","serviceType":"hxkcnbdtu","data":{"deviceAddress":"868744030057305","framenumber":0,"framenum":0,"frameser":0,"voltage":3.6,"rsrp":-99.9,"snr":67,"ecl":0,"csq":11,"cellid":"0125145939","reportway":0,"cycle":1600,"setmode":3,"settime":"3-00","freezday":"28-02","nbtime":"18-09-21 10:30:15","pressure":0.7455,"alarm_en":0,"alarm_time":60,"down_alarm_pre":0,"up_alarm_pre":0,"pre_status":0,"log":"7E64E7834300000011395914250100064003030028021809211030151811112222011F1D0000003C00000000000000000000000000","eventTime":"2018-09-21 10:30:17"},"eventTime":"20180921T023017Z"}}',
  1375. '{"notifyType":"deviceDataChanged","deviceId":"a1d88da9-5156-4507-995a-bb20af09001a","gatewayId":"a1d88da9-5156-4507-995a-bb20af09001a","requestId":null,"service":{"serviceId":"hxkcnbdtu","serviceType":"hxkcnbdtu","data":{"deviceAddress":"868744030057305","framenumber":0,"framenum":0,"frameser":0,"voltage":3.6,"rsrp":-99.9,"snr":67,"ecl":0,"csq":11,"cellid":"0125145939","reportway":0,"cycle":1600,"setmode":3,"settime":"3-00","freezday":"28-02","nbtime":"18-09-21 10:30:15","pressure":0.7455,"alarm_en":0,"alarm_time":60,"down_alarm_pre":0,"up_alarm_pre":0,"pre_status":0,"log":"7E64E7834300000011395914250100064003030028021809211030151811112222011F1D0000003C00000000000000000000000000","eventTime":"2018-09-21 10:30:17"},"eventTime":"20180921T023017Z"}}',
  1376. ];
  1377. $header=["Content-Type:application/json"];
  1378. //将数据分配给不同的服务
  1379. $httpserver=["http://47.98.153.212:1101","http://47.98.153.212:1102","http://47.98.153.212:1103"];
  1380. $senddata=$data[$rand];
  1381. $server=$httpserver[$rand];
  1382. $res=curltest($server,$senddata,$header);
  1383. dump($res);
  1384. /* //设备所属公司
  1385. $owner=Db::name('device')->field("owner_id")->where('iot_id',$iot_id)->find();
  1386. $ownerhost=Db::name('owner')->where('id',$owner["owner_id"])->find();
  1387. $ipaddr=$ownerhost['host'].":".$ownerhost['port'];
  1388. $res=curltest($ipaddr,$senddata);
  1389. dump($res);*/
  1390. //将数据转发到不同的接口中
  1391. /* $sendapi="senddata".$rand;
  1392. echo $this->$sendapi($data[$rand],$devies[$rand]);*/
  1393. }
  1394. public function tuoBaoUrl(){
  1395. if ($this->request->isPost()) {
  1396. $data = input('');
  1397. $list = array();
  1398. if (is_array($data)) {
  1399. $list['data'] = json_encode($data, 320);
  1400. $getdata = json_decode($list['data'], true);//转成数组
  1401. } else {
  1402. $list['data'] = $data;
  1403. $getdata = json_decode($list['data'], true);//转成数组
  1404. }
  1405. $res = Db::name('tuobao_data')->insertGetId($list);//将推送的数据存入总表
  1406. Log::record('tuoBaoLora' . ':' . $res);
  1407. $tuoBaoData['deviceId'] = $getdata['deviceId'];
  1408. if(!empty($getdata['parseMsg'])){
  1409. Log::record('tuoBaoLoraParseMsg' . ':' . $getdata['parseMsg'][0]['method']);
  1410. }
  1411. $tuoBaoData['deviceId'] = $getdata['deviceId'];
  1412. return json_encode($data, 320);
  1413. }else{
  1414. $msg = input('msg');
  1415. return $msg;
  1416. }
  1417. }
  1418. public function senddata0($data){
  1419. //将数据存到总表
  1420. //将数据存到设备详细表
  1421. //查看当前设备属于哪家业主
  1422. //查找业主的服务器
  1423. //给服务器发数据
  1424. }
  1425. public function senddata1($data){
  1426. echo "m2".$data;
  1427. }
  1428. public function senddata2($data){
  1429. echo "m3".$data;
  1430. }
  1431. public function array_column1($rows, $column_key, $index_key = null) {
  1432. $data = array();
  1433. if (empty($index_key)) {
  1434. foreach ($rows as $row) {
  1435. $data[] = $row[$column_key];
  1436. }
  1437. $data=implode(",",$data);
  1438. } else {
  1439. foreach ($rows as $row) {
  1440. $data[$row[$index_key]] = $row[$column_key];
  1441. }
  1442. }
  1443. return $data;
  1444. }
  1445. public function SendDeviceAlarm($access_token,$openid,$address,$deviceid,$type,$time,$remark,$url){
  1446. $data = array(
  1447. "touser"=> $openid,
  1448. "template_id"=>"JkQYUiScfIuH9O4vvUgtgYxPIOBOY7Zh9w2DcWTgm50",
  1449. //"url" =>"http://zt-iot.com/ztxf/weixin.php/Home/Fire/water",
  1450. "data"=> array(
  1451. "first"=> array(
  1452. "value"=> $address,
  1453. "color"=>"#44b549"
  1454. ),
  1455. "keyword1"=>array(
  1456. "value"=> $deviceid,
  1457. "color"=>"#173177"
  1458. ),
  1459. "keyword2"=> array(
  1460. "value"=> $type,
  1461. "color"=>"#173177"
  1462. ),
  1463. "keyword3"=> array(
  1464. "value"=> $time,
  1465. "color"=>"#173177"
  1466. ),
  1467. "remark"=>array(
  1468. "value"=> $remark,
  1469. "color"=>"#aaaaaa"
  1470. )
  1471. )
  1472. );
  1473. //{{first.DATA}}
  1474. //设备号:{{keyword1.DATA}}
  1475. //报警类型:{{keyword2.DATA}}
  1476. //时间:{{keyword3.DATA}}
  1477. //{{remark.DATA}}
  1478. $data = json_encode($data);
  1479. $QUEST_URL = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=".$access_token;
  1480. $res = $this->curl($QUEST_URL,$data);
  1481. return json_decode($res,true);
  1482. }
  1483. public function curl($url,$data=''){
  1484. $ch = curl_init();
  1485. curl_setopt($ch, CURLOPT_URL, $url);
  1486. curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
  1487. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
  1488. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
  1489. curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');
  1490. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
  1491. curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
  1492. curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
  1493. curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
  1494. $info = curl_exec($ch);
  1495. if (curl_errno($ch)) {
  1496. $info = 'ERROR: ' . curl_error($ch);
  1497. }
  1498. curl_close($ch);
  1499. return $info;
  1500. }
  1501. public function s_curl($url, $data = '')
  1502. {
  1503. $ch = curl_init();
  1504. curl_setopt($ch, CURLOPT_URL, $url);
  1505. curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
  1506. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
  1507. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
  1508. curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');
  1509. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
  1510. curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
  1511. curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
  1512. curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
  1513. $info = curl_exec($ch);
  1514. if (curl_errno($ch)) {
  1515. $info = 'ERROR: ' . curl_error($ch);
  1516. }
  1517. curl_close($ch);
  1518. return $info;
  1519. }
  1520. public function get_curl($url, $data = '')
  1521. {
  1522. $ch = curl_init();
  1523. curl_setopt($ch, CURLOPT_URL, $url);
  1524. curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "GET");
  1525. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
  1526. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
  1527. curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');
  1528. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
  1529. curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
  1530. curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
  1531. curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
  1532. $info = curl_exec($ch);
  1533. if (curl_errno($ch)) {
  1534. $info = 'ERROR: ' . curl_error($ch);
  1535. }
  1536. curl_close($ch);
  1537. return $info;
  1538. }
  1539. }