coreobject.cpp 65 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259
  1. #include "coreobject.h"
  2. #include <unistd.h>
  3. //公司这边生产环境的内网和外网ip
  4. #define iServerIP "172.19.198.166"
  5. #define oServerIP "47.103.74.123"
  6. //伍继158对应的内网和外网ip
  7. //#define iServerIP "192.168.0.31"
  8. //#define oServerIP "124.70.160.158"
  9. //伍继91对应的内网和外网ip
  10. //#define iServerIP "192.168.0.149"
  11. //#define oServerIP "124.71.175.91"
  12. #define UN_REFERENCED_PARAMETER(x) {(x) = (x);}
  13. extern BOOL CALLBACK RegisterCallBack(LONG lUserID, DWORD dwDataType, void *pOutBuffer, DWORD dwOutLen, void *pInBuffer, DWORD dwInLen, void *pUser);
  14. extern BOOL CALLBACK fnPREVIEW_NEWLINK_CB(LONG lPreviewHandle, NET_EHOME_NEWLINK_CB_MSG *pNewLinkCBMsg, void *pUserData);
  15. extern void CALLBACK fnPREVIEW_DATA_CB(LONG lPreviewHandle, NET_EHOME_PREVIEW_CB_MSG *pPreviewCBMsg, void *pUserData);
  16. extern BOOL InputStreamData(QString deviceid, BYTE byDataType, char* pBuffer, int iDataLen);
  17. extern BOOL CALLBACK AlarmMSGCallBack (LONG lHaldle, NET_EHOME_ALARM_MSG *pAlarmMsg, void *pUserData);
  18. extern QDateTime getFullTime(FullTime fTime);
  19. extern void setFullTime(FullTime *fTime, QDateTime qTime);
  20. extern QString getNewId();
  21. uint start_time;
  22. bool had_reg;
  23. int nopic_count;
  24. MyEHomeShm *ytShm;
  25. MyEHomeMQShm *ytMqShm;
  26. CoreObject::CoreObject(QObject *parent) :
  27. QObject(parent)
  28. {
  29. infomqttIdx=1;
  30. alarmmqttIdx=1;
  31. statusIdx=1;
  32. statusStr="";
  33. hour = 255;
  34. nopic_count = 0;
  35. processList.clear();
  36. sqlList.clear();
  37. reportList.clear();
  38. companyphoneList.clear();
  39. isWorking = false;
  40. alarmListenHandle = -1;
  41. start_time = QDateTime::currentDateTime().toTime_t();
  42. had_reg = false;
  43. netAccessManager = new QNetworkAccessManager(this);
  44. connect(netAccessManager,SIGNAL(finished(QNetworkReply*)),this,SLOT(finishedSlot(QNetworkReply*)));
  45. timer = new QTimer();
  46. //公司187生产环境对应的数据库配置
  47. db = QSqlDatabase::addDatabase("QMYSQL","conf_db");
  48. db.setDatabaseName("jdxf");
  49. db.setHostName("47.98.201.187");
  50. db.setUserName("root");
  51. db.setPassword("Yt2018IoT");
  52. //伍继158环境对应的数据库配置
  53. // db = QSqlDatabase::addDatabase("QMYSQL","conf_db");
  54. // db.setDatabaseName("smart_electricity");
  55. // db.setHostName("124.70.160.158");
  56. // db.setUserName("root");
  57. // db.setPassword("Y48hD&Eg");
  58. //伍继91环境对应的数据库配置
  59. // db = QSqlDatabase::addDatabase("QMYSQL","conf_db");
  60. // db.setDatabaseName("smart_electricity");
  61. // db.setHostName("192.168.0.206");
  62. // db.setUserName("electric");
  63. // db.setPassword("Y48hD&Eg");
  64. QString ip="",port="",name="",passwd="";
  65. db.open();
  66. QSqlQuery mqttqry = db.exec("select ip, port, username, passwd from yt_dataprocessservice_mqtt where type = 'YtCam';");
  67. while(mqttqry.next()){
  68. ip = mqttqry.value(0).toString();
  69. port = mqttqry.value(1).toString();
  70. name = mqttqry.value(2).toString();
  71. passwd = mqttqry.value(3).toString();
  72. }
  73. printf("ip= %s ,port= %s,username= %s,passwd= %s \n",ip.toUtf8().data(),port.toUtf8().data(),name.toUtf8().data(),passwd.toUtf8().data());
  74. db.close();
  75. m_client = new QMQTT::Client(QHostAddress(ip),static_cast<quint16>(port.toInt()),this);
  76. m_client->setUsername(name);
  77. m_client->setPassword(passwd.toLatin1());
  78. connect(m_client,&QMQTT::Client::connected,this,&CoreObject::mqconnected);
  79. m_client->connectToHost();
  80. NET_ESTREAM_Init();
  81. NET_EALARM_Init();
  82. NET_ECMS_Init();
  83. if(shm_load()){
  84. QDateTime zeroTime = QDateTime::fromTime_t(0);
  85. for(int i=0;i<DEVICES_COUNT;i++){
  86. alarmTime[i]=0;
  87. ytShm->eHomeDevice[i].LoginId = -1;
  88. ytShm->eHomeDevice[i].SessionId = -1;
  89. ytShm->eHomeDevice[i].listen_preview_handle = -1;
  90. ytShm->eHomeDevice[i].listen_alarm_handle = -1;
  91. ytShm->eHomeDevice[i].lLinkHandle = -1;
  92. ytShm->eHomeDevice[i].previewId = -1;
  93. ytShm->eHomeDevice[i].Connected = 0x00;
  94. ytShm->eHomeDevice[i].Inited = 0x00;
  95. ytShm->eHomeDevice[i].onLined = 0x00;
  96. ytShm->eHomeDevice[i].savetmp = 0x00;
  97. ytShm->eHomeDevice[i].transed = 0x00;
  98. for(int j=0;j<7;j++)
  99. ytShm->eHomeDevice[i].io[j] = 0x00;
  100. ytShm->eHomeDevice[i].time[0]=0;
  101. ytShm->eHomeDevice[i].time[1]=0;
  102. ytShm->eHomeDevice[i].tmpfile = NULL;
  103. setFullTime(&(ytShm->eHomeDevice[i].onLinetime),zeroTime);
  104. setFullTime(&(ytShm->eHomeDevice[i].transtime),zeroTime);
  105. QProcess *process = new QProcess(this);
  106. connect(process,SIGNAL(finished(int)),this,SLOT(process_stop()));
  107. connect(process,SIGNAL(destroyed()),this,SLOT(process_stop()));
  108. connect(process,SIGNAL(aboutToClose()),this,SLOT(process_stop()));
  109. processList.append(process);
  110. }
  111. printf("processList.length = %d\n",processList.length());
  112. for(quint16 i=0;i<8;i++){
  113. wxThreads[i] = new WechartThreads(this,i,"47.98.201.73","/jdxf/wxapp2.php/Home/GeneralPush/voice");
  114. wssThread[i] = new ttsThreads(this,i,"47.98.201.73","/report",55125);
  115. spThread[i] = new ttsThreads(this,i,"47.98.201.187","/report",55335);
  116. // connect(wxThreads[i],&WechartThreads::wxchart,this,&CoreObject::chartlog);
  117. // connect(wssThread[i],&ttsThreads::ttslog,this,&CoreObject::chartlog);
  118. // connect(spThread[i],&ttsThreads::ttslog,this,&CoreObject::chartlog);
  119. wxThreads[i]->start();
  120. wssThread[i]->start();
  121. spThread[i]->start();
  122. }
  123. repcur = 0;
  124. wxcur = 0;
  125. }
  126. logThread = new LogThread(this);
  127. logThread->start();
  128. chkPhoneList();
  129. connect(timer,SIGNAL(timeout()),this,SLOT(time_out()));
  130. time_out();
  131. }
  132. CoreObject::~CoreObject()
  133. {
  134. for(int i=0;i<processList.length();i++){
  135. if(processList.at(i)->pid()>0)
  136. processList.at(i)->close();
  137. if(ytShm->eHomeDevice[i].listen_preview_handle>=-1){
  138. NET_ESTREAM_StopListenPreview(ytShm->eHomeDevice[i].listen_preview_handle);
  139. }
  140. }
  141. if(alarmListenHandle>-1)
  142. NET_EALARM_StopListen(alarmListenHandle);
  143. NET_ECMS_Fini();
  144. NET_ESTREAM_Fini();
  145. NET_EALARM_Fini();
  146. netAccessManager->deleteLater();
  147. }
  148. void CoreObject::mqconnected()
  149. {
  150. printf("mqtt connected\n");
  151. }
  152. void CoreObject::chkPhoneList()
  153. {
  154. if(db.open()){
  155. QList<Company_Phone> tmpList;
  156. QSqlQuery qry = db.exec("select owner_code, phone from sp_owner_phone where phone<>''");
  157. while (qry.next()) {
  158. tmpList.append(Company_Phone(qry.value(0).toString(),qry.value(1).toString()));
  159. }
  160. db.close();
  161. companyphoneList.clear();
  162. if(tmpList.length()>0)
  163. companyphoneList.append(tmpList);
  164. synchour = QTime::currentTime().hour();
  165. }
  166. }
  167. void CoreObject::chartlog(quint16 idx, QDateTime t, QString data, bool dirflag){
  168. if((idx<DEVICES_COUNT)&&(QString(ytShm->eHomeDevice[idx].deviceID).length()>0))
  169. {
  170. QString log;
  171. if(dirflag)
  172. log = QString("[ %1 (%2) >>> ] %3").arg(t.toString("yyyy-MM-dd HH:mm:ss")).arg(ytShm->eHomeDevice[idx].deviceID).arg(data);
  173. else
  174. log = QString("[ %1 (%2) >>> ] %3").arg(t.toString("yyyy-MM-dd HH:mm:ss")).arg(ytShm->eHomeDevice[idx].deviceID).arg(data);
  175. logThread->appendData(log);
  176. }
  177. }
  178. bool CoreObject::shm_load()
  179. {
  180. int shmid;
  181. key_t key;
  182. if((key = ftok(SHM_PATH,(int)SHM_PORT))==-1)
  183. return false;
  184. if((shmid = shmget(key,sizeof(MyEHomeShm),IPC_CREAT|0666))==-1)
  185. return false;
  186. ytShm = (MyEHomeShm *)shmat(shmid,NULL,0);
  187. if((key = ftok(SHM_PATH,(int)(SHM_PORT+10)))==-1)
  188. return false;
  189. if((shmid = shmget(key,sizeof(MyEHomeMQShm),IPC_CREAT|0666))==-1)
  190. return false;
  191. ytMqShm = (MyEHomeMQShm *)shmat(shmid,NULL,0);
  192. return true;
  193. }
  194. QString getNewId()
  195. {
  196. return QUuid::createUuid().toString().replace("{","").replace("}","");
  197. }
  198. BOOL RegisterCallBack(LONG lUserID, DWORD dwDataType, void *pOutBuffer, DWORD dwOutLen, void *pInBuffer, DWORD dwInLen, void *pUser)
  199. {
  200. printf("enter into RegisterCallBack\n");
  201. int i,idx=0;
  202. bool found = false;
  203. had_reg = true;
  204. CoreObject *obj = (CoreObject *)pUser;
  205. QDateTime zeroTime = QDateTime::fromTime_t(0);
  206. QDateTime t_now = QDateTime::currentDateTime();
  207. ytShm->workingTime[0] = t_now.toTime_t();
  208. if (ENUM_DEV_ON == dwDataType)
  209. {
  210. NET_EHOME_DEV_REG_INFO *pDevInfo = (NET_EHOME_DEV_REG_INFO *)pOutBuffer;
  211. printf("pDevInfo = : %s\n",(char*)(pDevInfo->byDeviceID));
  212. // qDebug()<<"RegisterCallBack: "<<(char*)(pDevInfo->byDeviceID);
  213. if(pDevInfo!=NULL)
  214. {
  215. for(i=0;i<DEVICES_COUNT;i++){
  216. if(strcmp(ytShm->eHomeDevice[i].deviceID,QString((char*)(pDevInfo->byDeviceID)).replace(" ","_").toUtf8().data())==0){
  217. found = true;
  218. memcpy(ytShm->eHomeDevice[i].devIp,(char *)(pDevInfo->struDevAdd.szIP),sizeof(ytShm->eHomeDevice[i].devIp));
  219. obj->appendLog(QString("[ %1 (%2) online ]").arg(t_now.toString("yyyy-MM-dd HH:mm:ss")).arg(ytShm->eHomeDevice[i].deviceID));
  220. ytShm->eHomeDevice[i].LoginId = lUserID;
  221. ytShm->eHomeDevice[i].Connected = 0x00;
  222. ytShm->eHomeDevice[i].Inited = 0x01;
  223. ytShm->eHomeDevice[i].onLined = 0x00;
  224. ytShm->eHomeDevice[i].savetmp = 0x00;
  225. // if(ytShm->eHomeDevice[i].tmpfile!=NULL)
  226. // fclose(ytShm->eHomeDevice[i].tmpfile);
  227. ytShm->eHomeDevice[i].tmpfile = NULL;
  228. ytShm->eHomeDevice[i].transed = 0x00;
  229. ytShm->eHomeDevice[i].io[15]=0x00;
  230. ytShm->eHomeDevice[i].io[14]=0x03;
  231. setFullTime(&(ytShm->eHomeDevice[i].onLinetime),zeroTime);
  232. setFullTime(&(ytShm->eHomeDevice[i].transtime),zeroTime);
  233. idx=i;
  234. break;
  235. }
  236. }
  237. if(!found){
  238. return FALSE;
  239. }
  240. //输入参数
  241. NET_EHOME_SERVER_INFO *pServerInfo = (NET_EHOME_SERVER_INFO *)pInBuffer;
  242. pServerInfo->dwTimeOutCount = 6; //心跳超时次数
  243. pServerInfo->dwKeepAliveSec = 15; //心跳间隔
  244. memcpy(pServerInfo->struUDPAlarmSever.szIP, oServerIP, sizeof(oServerIP));
  245. memcpy(pServerInfo->struTCPAlarmSever.szIP, oServerIP, sizeof(oServerIP)); //报警服务器IP地址(TCP协议)
  246. pServerInfo->struUDPAlarmSever.wPort = 7669; //报警服务器端口(UDP协议),需要和报警服务器启动监听的端口一致
  247. pServerInfo->struTCPAlarmSever.wPort = 7668;
  248. pServerInfo->dwAlarmServerType = 1; //报警服务器类型:0- 只支持UDP协议上报,1- 支持UDP、TCP两种协议上报
  249. }
  250. }else if (ENUM_DEV_OFF == dwDataType){
  251. for(int i=0;i<DEVICES_COUNT;i++){
  252. if(ytShm->eHomeDevice[i].LoginId==lUserID){
  253. ytShm->eHomeDevice[i].io[15]=0x00;
  254. ytShm->eHomeDevice[i].io[14]=0x02;
  255. ytShm->eHomeDevice[i].LoginId = -1;
  256. obj->appendLog(QString("[ %1 (%2) offline ]").arg(t_now.toString("yyyy-MM-dd HH:mm:ss")).arg(ytShm->eHomeDevice[i].deviceID));
  257. if(ytShm->eHomeDevice[i].SessionId>=0){
  258. if(NET_ECMS_StopGetRealStream(lUserID,ytShm->eHomeDevice[i].SessionId)){
  259. ytShm->eHomeDevice[i].SessionId = -1;
  260. if(ytShm->eHomeDevice[i].previewId>=0){
  261. if(NET_ESTREAM_StopPreview(ytShm->eHomeDevice[i].previewId)){
  262. ytShm->eHomeDevice[i].previewId = -1;
  263. QString tmpfile = QString(ytShm->eHomeDevice[i].filename);
  264. QFile(tmpfile).remove();
  265. ytShm->eHomeDevice[i].Connected = 0x00;
  266. // bzero(ytShm->eHomeDevice[i].deviceID,sizeof(ytShm->eHomeDevice[i].deviceID));
  267. ytShm->eHomeDevice[i].Inited = 0x00;
  268. ytShm->eHomeDevice[i].onLined = 0x00;
  269. setFullTime(&(ytShm->eHomeDevice[i].onLinetime),zeroTime);
  270. setFullTime(&(ytShm->eHomeDevice[i].transtime),zeroTime);
  271. ytShm->eHomeDevice[i].savetmp = 0x00;
  272. // if(ytShm->eHomeDevice[i].tmpfile!=NULL)
  273. // fclose(ytShm->eHomeDevice[i].tmpfile);
  274. ytShm->eHomeDevice[i].tmpfile = NULL;
  275. ytShm->eHomeDevice[i].transed = 0x00;
  276. if(ytShm->eHomeDevice[i].lLinkHandle>0){
  277. if(NET_ESTREAM_StopListenPreview(ytShm->eHomeDevice[i].lLinkHandle)){
  278. ytShm->eHomeDevice[i].lLinkHandle = -1;
  279. }
  280. }
  281. }
  282. }
  283. }
  284. }else{
  285. QString tmpfile = QString(ytShm->eHomeDevice[i].filename);
  286. QFile(tmpfile).remove();
  287. ytShm->eHomeDevice[i].io[15]=0x00;
  288. ytShm->eHomeDevice[i].Connected = 0x00;
  289. // bzero(ytShm->eHomeDevice[i].deviceID,sizeof(ytShm->eHomeDevice[i].deviceID));
  290. ytShm->eHomeDevice[i].Inited = 0x00;
  291. ytShm->eHomeDevice[i].onLined = 0x00;
  292. ytShm->eHomeDevice[i].LoginId = -1;
  293. setFullTime(&(ytShm->eHomeDevice[i].onLinetime),zeroTime);
  294. setFullTime(&(ytShm->eHomeDevice[i].transtime),zeroTime);
  295. ytShm->eHomeDevice[i].lLinkHandle = -1;
  296. ytShm->eHomeDevice[i].savetmp = 0x00;
  297. // if(ytShm->eHomeDevice[i].transed==0x01)
  298. // fclose(ytShm->eHomeDevice[i].tmpfile);
  299. ytShm->eHomeDevice[i].tmpfile = NULL;
  300. ytShm->eHomeDevice[i].transed = 0x00;
  301. }
  302. break;
  303. }
  304. }
  305. NET_ECMS_ForceLogout(lUserID);
  306. }
  307. return TRUE;
  308. }
  309. BOOL CALLBACK fnPREVIEW_NEWLINK_CB(LONG lPreviewHandle, NET_EHOME_NEWLINK_CB_MSG *pNewLinkCBMsg, void *pUserData)
  310. {
  311. ytShm->workingTime[0] = QDateTime::currentDateTime().toTime_t();
  312. for(int i=0;i<DEVICES_COUNT;i++){
  313. if((ytShm->eHomeDevice[i].LoginId>-1)&&(ytShm->eHomeDevice[i].listen_preview_handle>-1)){
  314. if(strcmp(ytShm->eHomeDevice[i].deviceID,QString((char *)pNewLinkCBMsg->szDeviceID).replace(" ","_").toUtf8().data())==0){
  315. // if(ytShm->eHomeDevice[i].SessionId == pNewLinkCBMsg->iSessionID){
  316. // printf("fnPREVIEW_NEWLINK_CB:%s\n",ytShm->eHomeDevice[i].deviceID);
  317. ytShm->eHomeDevice[i].lLinkHandle = lPreviewHandle;
  318. NET_EHOME_PREVIEW_DATA_CB_PARAM struDataCB = {0};
  319. struDataCB.pUserData = &(ytShm->eHomeDevice[i]);
  320. struDataCB.fnPreviewDataCB = fnPREVIEW_DATA_CB;
  321. struDataCB.byStreamFormat = 0;//封装格式:0- PS
  322. if (!NET_ESTREAM_SetPreviewDataCB(lPreviewHandle, &struDataCB))
  323. {
  324. ytShm->eHomeDevice[i].SessionId = -1;
  325. ytShm->eHomeDevice[i].Connected = 0x00;;
  326. printf("NET_ESTREAM_SetPreviewDataCB set failed(%s)\n",ytShm->eHomeDevice[i].deviceID);
  327. return false;
  328. }
  329. printf("NET_ESTREAM_SetPreviewDataCB set pass(%s)\n",ytShm->eHomeDevice[i].deviceID);
  330. return true;
  331. }
  332. }
  333. }
  334. return false;
  335. }
  336. bool CoreObject::checkAlarmDevTime(QString deviceid){
  337. // return true;
  338. uint t = QDateTime::currentDateTime().toTime_t();
  339. for(int i=0;i<DEVICES_COUNT;i++){
  340. QString devId = QString(ytShm->eHomeDevice[i].deviceID);
  341. if(QString::compare(devId,deviceid)==0){
  342. if((t-alarmTime[i])>180){
  343. alarmTime[i] = t;
  344. return true;
  345. }
  346. }
  347. }
  348. return false;
  349. }
  350. void CoreObject::finishedSlot(QNetworkReply *reply)
  351. {
  352. QVariant status_code = reply->attribute(QNetworkRequest::HttpStatusCodeAttribute);
  353. if(status_code == 200){
  354. if(reply->error() == QNetworkReply::NoError){
  355. QString message = QString::fromUtf8(reply->readAll());
  356. QByteArray data = message.toLatin1();
  357. QJsonParseError json_err;
  358. QJsonDocument jsondoc(QJsonDocument::fromJson(data,&json_err));
  359. //printf("json_err.error = %d\n ",json_err.error);
  360. if(json_err.error==QJsonParseError::NoError){
  361. QJsonObject root = jsondoc.object();
  362. QJsonObject obj = root.value("RESULT").toObject();
  363. QString num = "";
  364. int t = 0;
  365. QJsonValue list_value = obj.value("LIST");
  366. if(list_value.isArray()){
  367. QJsonArray list_array = list_value.toArray();
  368. for(int i=0;i<list_array.size();i++){
  369. QJsonObject obj1 = list_array.at(i).toObject();
  370. QString devid = obj1.value("DEVICE").toString();
  371. int linevalue = obj1.value("ALIVEVALUE").toInt();
  372. printf("[%d] devid: %s, linevalue: %d\n",i,devid.toUtf8().data(),linevalue);
  373. QString companyCode="",deviceType="",deviceName="",value="";
  374. for(int i=0;i<DEVICES_COUNT;i++){
  375. QString devicecode = QString(ytShm->eHomeDevice[i].deviceID);
  376. if(QString::compare(devid,devicecode)==0){
  377. companyCode = QString(ytShm->eHomeDevice[i].rtsppath);
  378. //deviceType.append(QString("%1").arg((ytShm->eHomeDevice[i].io[8]&0xff),2,16,QChar('0')));
  379. //deviceName = QString(ytMqShm->eHomeDeviceMq[i].deviceName);
  380. //value = QString(ytShm->eHomeDeviceFtp[i].filePath);
  381. if(linevalue == 3){
  382. if((m_client->connectionState()==QMQTT::STATE_DISCONNECTED)||(m_client->connectionState()==QMQTT::STATE_INIT)){
  383. m_client->connectToHost();
  384. }
  385. if(m_client->connectionState()==QMQTT::STATE_CONNECTED){
  386. statusStr.append(QString("{\"devId\":\"%1\",\"devicestatus\":0,\"type\":\"STATUS\",\"timestamp\":\"%2\"}").arg(devid).arg(QDateTime::currentDateTime().toTime_t()));
  387. QString topic1 = QString("/usky/ytCamCore/%1/%2/status").arg(companyCode).arg(devid);
  388. m_client->publish(QMQTT::Message(statusIdx++,topic1,statusStr.toUtf8()));
  389. statusStr.clear();
  390. if(statusIdx>9999)
  391. statusIdx = 1;
  392. }
  393. }else{
  394. if((m_client->connectionState()==QMQTT::STATE_DISCONNECTED)||(m_client->connectionState()==QMQTT::STATE_INIT)){
  395. m_client->connectToHost();
  396. }
  397. if(m_client->connectionState()==QMQTT::STATE_CONNECTED){
  398. statusStr.append(QString("{\"devId\":\"%1\",\"devicestatus\":75,\"type\":\"STATUS\",\"timestamp\":\"%2\"}").arg(devid).arg(QDateTime::currentDateTime().toTime_t()));
  399. QString topic1 = QString("/usky/ytCamCore/%1/%2/status").arg(companyCode).arg(devid);
  400. m_client->publish(QMQTT::Message(statusIdx++,topic1,statusStr.toUtf8()));
  401. statusStr.clear();
  402. if(statusIdx>9999)
  403. statusIdx = 1;
  404. }
  405. }
  406. break;
  407. }
  408. }
  409. }
  410. }
  411. }
  412. }else{
  413. }
  414. }else{
  415. }
  416. reply->abort();
  417. reply->close();
  418. reply->deleteLater();
  419. }
  420. void CALLBACK fnPREVIEW_DATA_CB(LONG lPreviewHandle, NET_EHOME_PREVIEW_CB_MSG *pPreviewCBMsg, void *pUserData)
  421. {
  422. ytShm->workingTime[0] = QDateTime::currentDateTime().toTime_t();
  423. if (NULL == pPreviewCBMsg)
  424. {
  425. return ;
  426. }
  427. EHomeDevice *dev= (EHomeDevice *)pUserData;
  428. dev->Connected = 0x01;
  429. dev->previewId = lPreviewHandle;
  430. InputStreamData(QString(dev->deviceID).replace(" ","_"), pPreviewCBMsg->byDataType, (char*)pPreviewCBMsg->pRecvdata, pPreviewCBMsg->dwDataLen);
  431. }
  432. void ProcessHttpAlarmInfo(void *pXml, unsigned long dwLen, void *pUrl, unsigned long dwUrllen,void *pUserData){
  433. if((pXml==NULL)&&(pUrl==NULL))
  434. return;
  435. UN_REFERENCED_PARAMETER(dwLen);
  436. UN_REFERENCED_PARAMETER(pUrl);
  437. UN_REFERENCED_PARAMETER(dwUrllen);
  438. char deviceID[32] = {0};
  439. char eventTime[20] = {0};
  440. char eventType[128] = {0};
  441. char eventState[20] = {0};
  442. char pic[2][256]={0};
  443. CoreObject *obj = (CoreObject *)pUserData;
  444. LPNET_EHOME_ALARM_ISAPI_INFO pISAPIAlarm = (NET_EHOME_ALARM_ISAPI_INFO *)(pXml);
  445. NET_EHOME_ALARM_ISAPI_INFO struISAPIAlarm = {0};
  446. memcpy(&struISAPIAlarm,pISAPIAlarm, sizeof(NET_EHOME_ALARM_ISAPI_INFO));
  447. obj->appendLog(QString("{ligangceshi5:%1}")
  448. .arg(struISAPIAlarm.pAlarmData));
  449. if(struISAPIAlarm.pAlarmData)
  450. {
  451. if(struISAPIAlarm.byDataType==2){
  452. QByteArray data = QByteArray((const char *)(struISAPIAlarm.pAlarmData));
  453. QXmlStreamReader reader;
  454. int cur = data.indexOf("--boundary");
  455. reader.addData(data.mid(0,cur));
  456. while(!reader.atEnd()){
  457. if(reader.isStartElement()){
  458. if(reader.name()=="eventType"){
  459. sprintf(eventType,"%s",reader.readElementText().toUtf8().data());
  460. }else if(reader.name()=="deviceID"){
  461. sprintf(deviceID,"%s",reader.readElementText().toUtf8().data());
  462. }else if(reader.name()=="dateTime"){
  463. sprintf(eventTime,"%s",reader.readElementText().replace("T"," ").mid(0,19).toUtf8().data());
  464. }else if(reader.name()=="eventState"){
  465. sprintf(eventState,"%s",reader.readElementText().toUtf8().data());
  466. }
  467. }
  468. reader.readNext();
  469. }
  470. obj->appendLog(QString("{ligangceshi3:%1}")
  471. .arg(deviceID));
  472. }else if(struISAPIAlarm.byDataType==1){
  473. QByteArray data = QByteArray((const char *)(struISAPIAlarm.pAlarmData));
  474. int cur = data.indexOf("--boundary");
  475. if(cur>0){
  476. QXmlStreamReader reader;
  477. reader.addData(data.mid(0,cur));
  478. while(!reader.atEnd()){
  479. if(reader.isStartElement()){
  480. if(reader.name()=="eventType"){
  481. sprintf(eventType,"%s",reader.readElementText().toUtf8().data());
  482. }else if(reader.name()=="deviceID"){
  483. sprintf(deviceID,"%s",reader.readElementText().toUtf8().data());
  484. }else if(reader.name()=="dateTime"){
  485. sprintf(eventTime,"%s",reader.readElementText().replace("T"," ").mid(0,19).toUtf8().data());
  486. }else if(reader.name()=="eventState"){
  487. sprintf(eventState,"%s",reader.readElementText().toUtf8().data());
  488. }
  489. }
  490. reader.readNext();
  491. }
  492. obj->appendLog(QString("{ligangceshi4:%1}")
  493. .arg(deviceID));
  494. }
  495. }
  496. if(obj->checkAlarmDevTime(deviceID)){
  497. if(struISAPIAlarm.byPicturesNumber>0){
  498. time_t t = QDateTime::currentDateTime().toTime_t();
  499. for(int i=0;i<struISAPIAlarm.byPicturesNumber;i++){
  500. char fname[128];
  501. sprintf(fname,"/usr/local/nginx/html/VideoAlarmPics/pic_%d_%s_%d.jpg",t,deviceID,i);
  502. if(i<2)
  503. sprintf(pic[i],"http://47.103.74.123/VideoAlarmPics/pic_%d_%s_%d.jpg",t,deviceID,i);
  504. FILE *f = fopen(fname,"w");
  505. fwrite(((NET_EHOME_ALARM_ISAPI_PICDATA *)struISAPIAlarm.pPicPackData)[i].pPicData,1,((NET_EHOME_ALARM_ISAPI_PICDATA *)struISAPIAlarm.pPicPackData)[i].dwPicLen,f);
  506. fclose(f);
  507. }
  508. }
  509. obj->reportList.append(Alarm_Report(deviceID,eventTime,QString::fromUtf8("200001"),
  510. QString::fromUtf8("insert into sp_video2017 (id,port,device_code,time,status,address,ncmd,data1,data2,data3,data4,data5,clsj,clr,clnr,clwb,cllxr,cldh,clzt,cllx,video) values (NULL,'%1','%2','%3','%4','','%5','%6','%7','%8','火点/高温检测告警','','1970-01-01 08:00:00','','','','','',0,'','')")
  511. .arg(2).arg(deviceID).arg(eventTime).arg(1)
  512. .arg(2).arg(eventState).arg(pic[0]).arg(pic[1])));
  513. for(int k=0;k<DEVICES_COUNT;k++){
  514. QString devid = QString(ytShm->eHomeDevice[k].deviceID);
  515. if(QString::compare(deviceID,devid)==0){
  516. sprintf(ytShm->eHomeDeviceFtp[k].filePath,"%s",pic[0]);
  517. break;
  518. }
  519. }
  520. }
  521. }
  522. }
  523. BOOL CALLBACK AlarmMSGCallBack(LONG lHandle, NET_EHOME_ALARM_MSG *pAlarmMsg, void *pUserData)
  524. {
  525. int i,idx;
  526. QDateTime dt = QDateTime::currentDateTime();
  527. CoreObject *obj = (CoreObject *)pUserData;
  528. DWORD dwType = pAlarmMsg->dwAlarmType; //不同的报警类型(dwAlarmType),pAlarmInfo对应不同的报警信息类型
  529. ytShm->workingTime[0] = dt.toTime_t();
  530. if(pAlarmMsg->pHttpUrl!=NULL)
  531. dwType = EHOME_ISAPI_ALARM;
  532. switch(dwType)
  533. {
  534. case EHOME_ALARM_UNKNOWN://未知报警信息
  535. NET_EHOME_ALARM_INFO struAlarmInfo;
  536. obj->appendLog(QString("{ligangceshi1:%1,%2,%3}")
  537. .arg(dt.toString("yyyy-MM-dd HH:mm:ss")).arg(struAlarmInfo.dwAlarmType).arg(struAlarmInfo.szDeviceID));
  538. break;
  539. case EHOME_ALARM://基本报警信息:移动侦测、视频遮盖、视频丢失、PIR报警、人脸侦测、区域入侵等
  540. {
  541. NET_EHOME_ALARM_INFO struAlarmInfo;
  542. memcpy(&struAlarmInfo, pAlarmMsg->pAlarmInfo, sizeof(NET_EHOME_ALARM_INFO));
  543. if((struAlarmInfo.dwAlarmType==ALARM_TYPE_INTRUSION)||(struAlarmInfo.dwAlarmType==ALARM_TYPE_LEFT)||(struAlarmInfo.dwAlarmType==ALARM_TYPE_TAKE))
  544. {
  545. QString devId = QString(struAlarmInfo.szDeviceID);
  546. if(obj->checkAlarmDevTime(devId)){
  547. obj->appendLog(QString("[ %1 alm(%2) ] Basic Alarm: Device ID[%3], szAlarmTime[%4], Alarm Type[%5], Action[%6], VideoChannel[%7]!")
  548. .arg(dt.toString("yyyy-MM-dd HH:mm:ss")).arg(obj->alarmList.length())
  549. .arg(struAlarmInfo.szDeviceID).arg(struAlarmInfo.szAlarmTime).arg(struAlarmInfo.dwAlarmType).arg(struAlarmInfo.dwAlarmAction).arg(struAlarmInfo.dwVideoChannel));
  550. for(idx=0;idx<DEVICES_COUNT;idx++){
  551. if((strcmp(ytShm->eHomeDevice[idx].deviceID,(char*)(struAlarmInfo.szDeviceID))==0)
  552. &&((ytShm->eHomeDevice[idx].io[8]==0x02)||(ytShm->eHomeDevice[idx].io[8]==0x04)||(ytShm->eHomeDevice[idx].io[8]==0x08)||(ytShm->eHomeDevice[idx].io[8]==0x84))){
  553. for(i=0;i>obj->alarmList.length();i++){
  554. if(obj->alarmList.at(i).Device_Code.compare(devId)==0){
  555. if((struAlarmInfo.dwAlarmType==ALARM_TYPE_INTRUSION)&&(struAlarmInfo.dwAlarmAction!=0))
  556. obj->alarmList.removeAt(i);
  557. else if(struAlarmInfo.dwAlarmType==ALARM_TYPE_TAKE)
  558. obj->alarmList.removeAt(i);
  559. break;
  560. }
  561. }
  562. QString time1 = QString(struAlarmInfo.szAlarmTime);
  563. QString time2 = time1.mid(0,10)+" "+time1.mid(11,8);
  564. if(struAlarmInfo.dwAlarmType==ALARM_TYPE_INTRUSION)
  565. obj->alarmList.append(AlarmEvent(devId,time2,(struAlarmInfo.dwAlarmAction==0?1:0),dt.toTime_t()));
  566. else
  567. obj->alarmList.append(AlarmEvent(devId,time2,1,dt.toTime_t()));
  568. ytShm->eHomeDevice[idx].io[6]=0x01;
  569. }
  570. }
  571. }
  572. }else{
  573. obj->appendLog(QString("{ligangceshi2:%1,%2,%3}")
  574. .arg(dt.toString("yyyy-MM-dd HH:mm:ss")).arg(struAlarmInfo.dwAlarmType).arg(struAlarmInfo.szDeviceID));
  575. }
  576. }
  577. break;
  578. case EHOME_ISAPI_ALARM:
  579. ProcessHttpAlarmInfo(pAlarmMsg->pAlarmInfo,pAlarmMsg->dwAlarmInfoLen,pAlarmMsg->pHttpUrl,pAlarmMsg->dwHttpUrlLen,pUserData);
  580. break;
  581. default:
  582. NET_EHOME_ALARM_INFO struAlarmInfo1;
  583. obj->appendLog(QString("{ligangceshi:%1,%2,%3}")
  584. .arg(dt.toString("yyyy-MM-dd HH:mm:ss")).arg(struAlarmInfo1.dwAlarmType).arg(struAlarmInfo.szDeviceID));
  585. break;
  586. }
  587. return TRUE;
  588. }
  589. BOOL InputStreamData(QString deviceid, BYTE byDataType, char* pBuffer, int iDataLen)
  590. {
  591. int i;
  592. uint t = QDateTime::currentDateTime().toTime_t();
  593. ytShm->workingTime[0] = t;
  594. printf("InputStreamData test \n");
  595. if(iDataLen>0){
  596. nopic_count = 0;
  597. for(i=0;i<DEVICES_COUNT;i++){
  598. if(QString(ytShm->eHomeDevice[i].deviceID).compare(deviceid)==0){
  599. if(ytShm->eHomeDevice[i].io[0]==0x01){
  600. ytShm->eHomeDevice[i].time[0] = t;
  601. if(ytShm->eHomeDevice[i].savetmp==0x00){
  602. if(ytShm->eHomeDevice[i].tmpfile!=NULL){
  603. fclose(ytShm->eHomeDevice[i].tmpfile);
  604. ytShm->eHomeDevice[i].tmpfile = NULL;
  605. }
  606. QString tmpfile = QString("/tmp/%1.mp4").arg(ytShm->eHomeDevice[i].deviceID).replace(" ","_");
  607. sprintf(ytShm->eHomeDevice[i].filename,"%s",tmpfile.toUtf8().data());
  608. setFullTime(&(ytShm->eHomeDevice[i].onLinetime),QDateTime::currentDateTime());
  609. ytShm->eHomeDevice[i].savetmp = 0x01;
  610. ytShm->eHomeDevice[i].tmpfile = fopen(tmpfile.toUtf8().data(),"wb");
  611. fwrite(pBuffer,iDataLen,1,ytShm->eHomeDevice[i].tmpfile);
  612. }else{
  613. if(ytShm->eHomeDevice[i].tmpfile!=NULL){
  614. fwrite(pBuffer,iDataLen,1,ytShm->eHomeDevice[i].tmpfile);
  615. }else{
  616. QString tmpfile = QString("/tmp/%1.mp4").arg(ytShm->eHomeDevice[i].deviceID).replace(" ","_");
  617. sprintf(ytShm->eHomeDevice[i].filename,"%s",tmpfile.toUtf8().data());
  618. setFullTime(&(ytShm->eHomeDevice[i].onLinetime),QDateTime::currentDateTime());
  619. // ytShm->eHomeDevice[i].savetmp = 0x01;
  620. ytShm->eHomeDevice[i].tmpfile = fopen(tmpfile.toUtf8().data(),"wb");
  621. fwrite(pBuffer,iDataLen,1,ytShm->eHomeDevice[i].tmpfile);
  622. }
  623. }
  624. }else{
  625. NET_ECMS_StopGetRealStream(ytShm->eHomeDevice[i].LoginId,ytShm->eHomeDevice[i].SessionId);
  626. }
  627. return true;
  628. }
  629. }
  630. }
  631. return false;
  632. }
  633. void setFullTime(FullTime *fTime, QDateTime qTime){
  634. fTime->YEAR = qTime.date().year()&0xffff;
  635. fTime->MONTH = qTime.date().month()&0xff;
  636. fTime->DAY = qTime.date().day()&0xff;
  637. fTime->HOUR = qTime.time().hour()&0xff;
  638. fTime->MINUTE = qTime.time().minute()&0xff;
  639. fTime->SECOND = qTime.time().second()&0xff;
  640. fTime->TIMESTAMP = qTime.toTime_t();
  641. }
  642. QDateTime getFullTime(FullTime fTime){
  643. if((fTime.YEAR==0)||(fTime.MONTH==0)||(fTime.DAY==0))
  644. return QDateTime::fromTime_t(fTime.TIMESTAMP);
  645. else
  646. return QDateTime(QDate((int)fTime.YEAR,(int)fTime.MONTH,(int)fTime.DAY),QTime((int)fTime.HOUR,(int)fTime.MINUTE,(int)fTime.SECOND));
  647. }
  648. void CoreObject::appendLog(QString log)
  649. {
  650. logThread->appendData(log);
  651. }
  652. void CoreObject::start()
  653. {
  654. //预览监听参数
  655. timer->start(3000);
  656. NET_EHOME_LOCAL_GENERAL_CFG struGeneralCfg = {0};
  657. struGeneralCfg.byAlarmPictureSeparate = 1;
  658. if(!NET_EALARM_SetSDKLocalCfg(LOCAL_CFG_TYPE_GENERAL,&struGeneralCfg)){
  659. printf("NET_EALARM_SetSDKLocalCfg falied\n");
  660. NET_ECMS_Fini();
  661. return;
  662. }
  663. printf("NET_EALARM_SetSDKLocalCfg pass!\n");
  664. //报警监听参数
  665. NET_EHOME_ALARM_LISTEN_PARAM struTcpAlarmListenParam = {0};
  666. memcpy(struTcpAlarmListenParam.struAddress.szIP, iServerIP, sizeof(iServerIP));
  667. struTcpAlarmListenParam.byProtocolType = 0;
  668. struTcpAlarmListenParam.struAddress.wPort = 7668;
  669. struTcpAlarmListenParam.fnMsgCb = AlarmMSGCallBack;
  670. struTcpAlarmListenParam.pUserData = this;
  671. struTcpAlarmListenParam.byUseCmsPort = 0;
  672. struTcpAlarmListenParam.byUseThreadPool = 0;
  673. if((alarmListenHandle=NET_EALARM_StartListen(&struTcpAlarmListenParam))<-1){
  674. printf("NET_EALARM_StartListen TCP failed, error code: %d\n", NET_EALARM_GetLastError());
  675. NET_ECMS_Fini();
  676. NET_ESTREAM_Fini();
  677. NET_EALARM_Fini();
  678. exit(1);
  679. }
  680. printf("NET_EALARM_StartListen TCP!\n");
  681. //报警监听参数
  682. NET_EHOME_ALARM_LISTEN_PARAM struListen = {0};
  683. memcpy(struListen.struAddress.szIP, iServerIP, sizeof(iServerIP));
  684. struListen.struAddress.wPort = 7669; //报警服务器监听端口
  685. struListen.fnMsgCb = AlarmMSGCallBack; //报警回调函数
  686. struListen.pUserData = this;
  687. struListen.byUseCmsPort = 0;
  688. struListen.byUseThreadPool = 0;
  689. struListen.byProtocolType = 1; //0- TCP方式(保留,暂不支持),1- UDP方式
  690. //启动报警监听
  691. LONG lHandle = NET_EALARM_StartListen(&struListen);
  692. if(lHandle< -1)
  693. {
  694. printf("NET_EALARM_StartListen failed, error code: %d\n", NET_EALARM_GetLastError());
  695. NET_ECMS_Fini();
  696. NET_ESTREAM_Fini();
  697. NET_EALARM_Fini();
  698. exit(1);
  699. }
  700. printf("NET_EALARM_StartListen!\n");
  701. NET_ECMS_SetLogToFile(1,QString("/var/log/usky/").toUtf8().data(),true);
  702. for(int i=0;i<DEVICES_COUNT;i++){
  703. printf("NET_ESTREAM_StartListenPreview\n");
  704. ytShm->eHomeDevice[i].previewport = 58000+i;
  705. ytShm->eHomeDevice[i].listen_alarm_handle = lHandle;
  706. NET_EHOME_LISTEN_PREVIEW_CFG struListen = {0};
  707. memcpy(struListen.struIPAdress.szIP,iServerIP, sizeof(iServerIP));
  708. struListen.struIPAdress.wPort = ytShm->eHomeDevice[i].previewport; //流媒体服务器监听端口
  709. struListen.fnNewLinkCB = fnPREVIEW_NEWLINK_CB; //预览连接请求回调函数
  710. struListen.pUser =&(ytShm->eHomeDevice[i]);
  711. struListen.byLinkMode = 0; //0- TCP方式,1- UDP方式
  712. lHandle = NET_ESTREAM_StartListenPreview(&struListen);
  713. if(lHandle<-1){
  714. }else{
  715. ytShm->eHomeDevice[i].listen_preview_handle = lHandle;
  716. }
  717. }
  718. NET_EHOME_CMS_LISTEN_PARAM struCMSListenPara = {0};
  719. memcpy(struCMSListenPara.struAddress.szIP, "0.0.0.0", sizeof("0.0.0.0"));
  720. struCMSListenPara.struAddress.wPort = 7660;
  721. struCMSListenPara.fnCB = RegisterCallBack;
  722. struCMSListenPara.pUserData = this;
  723. printf("NET_ECMS_StartListen begin\n");
  724. LONG lListen = NET_ECMS_StartListen(&struCMSListenPara);
  725. if(lListen < -1)
  726. {
  727. printf("NET_ECMS_StartListen fail\n");
  728. NET_ECMS_Fini();
  729. NET_ESTREAM_Fini();
  730. NET_EALARM_Fini();
  731. exit(1);
  732. }
  733. printf("NET_ECMS_StartListen end\n");
  734. // qDebug()<<"start core";
  735. }
  736. void CoreObject::process_stop()
  737. {
  738. printf("process_stop \n");
  739. QProcess *p = (QProcess *)sender();
  740. for(int i=0;i<DEVICES_COUNT;i++){
  741. if(p==processList.at(i)){
  742. if(ytShm->eHomeDevice[i].Connected==0x01){
  743. ytShm->eHomeDevice[i].io[0]=0x00;
  744. }
  745. break;
  746. }
  747. }
  748. }
  749. void CoreObject::AlarmReport(QString addr, QString type, QString time, QString companyCode, quint64 insertid)
  750. {
  751. // if(type.toInt()==200104)
  752. // type="占道侦测报警";
  753. // else if(type.toInt()==200001)
  754. // type="火点侦测报警";
  755. // QString rep2 = QString("{\"SubType\":16,\"DeviceId\":\"%1\",\"InsertId\":%2,\"Confirmed\":0,\"CompanyCode\":\"%3\",\"evt_name\":\"%4\",\"evt\":0,\"alarm_time\":\"%5\"}")
  756. // .arg(addr).arg(insertid).arg(companyCode).arg(type).arg(time);
  757. // printf("%s\n",rep2.toUtf8().data());
  758. // repcur++;
  759. // repcur &= 0x07;
  760. // wssThread[repcur]->appendData(rep2);
  761. }
  762. QString CoreObject::getCompanyCode(QString addr){
  763. for(int i=0;i<DEVICES_COUNT;i++){
  764. QString devid = QString(ytShm->eHomeDevice[i].deviceID);
  765. if(QString::compare(addr,devid)==0){
  766. return QString(ytShm->eHomeDevice[i].rtsppath);
  767. }
  768. }
  769. return "";
  770. }
  771. void CoreObject::clear_devalarm(AlarmEvent devAlarm,bool isFtp)
  772. {
  773. for(int i=0;i<DEVICES_COUNT;i++){
  774. if(devAlarm.Device_Code.compare(QString(ytShm->eHomeDevice[i].deviceID))==0){
  775. if(processList.at(i)->pid()>0)
  776. processList.at(i)->close();
  777. ytShm->eHomeDevice[i].io[6]=0x00;
  778. ytShm->eHomeDevice[i].io[0]=0x00;
  779. QString tmpfile = QString(ytShm->eHomeDevice[i].filename);
  780. if(ytShm->eHomeDevice[i].tmpfile!=NULL)
  781. fclose(ytShm->eHomeDevice[i].tmpfile);
  782. ytShm->eHomeDevice[i].savetmp = 0x00;
  783. ytShm->eHomeDevice[i].tmpfile = NULL;
  784. QFile(tmpfile).remove();
  785. ytShm->eHomeDevice[i].transed = 0x00;
  786. sprintf(ytShm->eHomeDevice[i].filename,"");
  787. if(isFtp){
  788. if(ytShm->eHomeDevice[i].io[8]==0x08){
  789. reportList.append(Alarm_Report(devAlarm.Device_Code,devAlarm.Event_Time,QString::fromUtf8("200104"),
  790. QString::fromUtf8("insert into sp_video2017 (id,port,device_code,time,status,address,ncmd,data1,data2,data3,data4,data5,clsj,clr,clnr,clwb,cllxr,cldh,clzt,cllx,video) values (NULL,'%1','%2','%3','%4','','%5','%6','%7','%8','消防占道告警','','1970-01-01 08:00:00','','','','','',0,'','')")
  791. .arg(2).arg(devAlarm.Device_Code).arg(devAlarm.Event_Time).arg(1)
  792. .arg(104).arg(devAlarm.Event_Status).arg(ytShm->eHomeDeviceFtp[i].filePath).arg("")));
  793. }else if(ytShm->eHomeDevice[i].io[8]==0x84){
  794. reportList.append(Alarm_Report(devAlarm.Device_Code,devAlarm.Event_Time,QString::fromUtf8("200105"),
  795. QString::fromUtf8("insert into sp_video2017 (id,port,device_code,time,status,address,ncmd,data1,data2,data3,data4,data5,clsj,clr,clnr,clwb,cllxr,cldh,clzt,cllx,video) values (NULL,'%1','%2','%3','%4','','%5','%6','%7','%8','电动车禁入/区域入侵告警','','1970-01-01 08:00:00','','','','','',0,'','')")
  796. .arg(2).arg(devAlarm.Device_Code).arg(devAlarm.Event_Time).arg(1)
  797. .arg(106).arg(devAlarm.Event_Status).arg(ytShm->eHomeDeviceFtp[i].filePath).arg("")));
  798. }
  799. }else{
  800. if(ytShm->eHomeDevice[i].io[8]==0x02||ytShm->eHomeDevice[i].io[8]==0x08){
  801. reportList.append(Alarm_Report(devAlarm.Device_Code,devAlarm.Event_Time,QString::fromUtf8("200104"),
  802. QString::fromUtf8("insert into sp_video2017 (id,port,device_code,time,status,address,ncmd,data1,data2,data3,data4,data5,clsj,clr,clnr,clwb,cllxr,cldh,clzt,cllx,video) values (NULL,'%1','%2','%3','%4','','%5','%6','%7','%8','消防占道告警','','1970-01-01 08:00:00','','','','','',0,'','')")
  803. .arg(2).arg(devAlarm.Device_Code).arg(devAlarm.Event_Time).arg(1)
  804. .arg(104).arg(devAlarm.Event_Status).arg("").arg("")));
  805. }else if(ytShm->eHomeDevice[i].io[8]==0x04||ytShm->eHomeDevice[i].io[8]==0x84){
  806. reportList.append(Alarm_Report(devAlarm.Device_Code,devAlarm.Event_Time,QString::fromUtf8("200105"),
  807. QString::fromUtf8("insert into sp_video2017 (id,port,device_code,time,status,address,ncmd,data1,data2,data3,data4,data5,clsj,clr,clnr,clwb,cllxr,cldh,clzt,cllx,video) values (NULL,'%1','%2','%3','%4','','%5','%6','%7','%8','电动车禁入/区域入侵告警','','1970-01-01 08:00:00','','','','','',0,'','')")
  808. .arg(2).arg(devAlarm.Device_Code).arg(devAlarm.Event_Time).arg(1)
  809. .arg(106).arg(devAlarm.Event_Status).arg("").arg("")));
  810. }
  811. }
  812. break;
  813. }
  814. }
  815. for(int i=0;i<alarmList.length();i++){
  816. if(alarmList.at(i).Device_Code.compare(devAlarm.Device_Code)==0){
  817. alarmList.removeAt(i);
  818. // break;
  819. }
  820. }
  821. }
  822. void CoreObject::time_out()
  823. {
  824. printf("time_out start\n");
  825. uint ChkTime = 0;
  826. QDateTime t = QDateTime::currentDateTime();
  827. ytShm->workingTime[0] = t.toTime_t();
  828. if(!had_reg){
  829. if((ytShm->workingTime[0]-start_time)>30)
  830. exit(1);
  831. }
  832. if(isWorking)
  833. return;
  834. isWorking = true;
  835. if(synchour!=t.time().hour())
  836. chkPhoneList();
  837. if(hour != t.time().hour()){
  838. hour = t.time().hour();
  839. QByteArray post_data;
  840. post_data.append(QString("queryJson={\"CMD\":%1}").arg(1));
  841. QNetworkRequest *req = new QNetworkRequest();
  842. req->setUrl(QUrl("https://fire.usky.cn:8443/YtIoT/cgi-bin/demo2.cgi"));
  843. req->setHeader(QNetworkRequest::ContentTypeHeader,"application/x-www-form-urlencoded");
  844. req->setHeader(QNetworkRequest::ContentLengthHeader,post_data.length());
  845. QNetworkReply* reply = netAccessManager->post(*req,post_data);
  846. }
  847. t = QDateTime::currentDateTime();
  848. ytShm->workingTime[0] = t.toTime_t();
  849. for(int i=0;i<DEVICES_COUNT;i++){
  850. if(ytShm->eHomeDevice[i].Inited==0x01){
  851. t = QDateTime::currentDateTime();
  852. ytShm->workingTime[0] = t.toTime_t();
  853. if(ytShm->eHomeDevice[i].Connected==0x00){
  854. if(ytShm->eHomeDevice[i].io[8]==0x01)
  855. ytShm->eHomeDevice[i].io[0] = 0x01;
  856. else if(ytShm->eHomeDevice[i].io[7]==0x01){
  857. if((ytShm->eHomeDevice[i].time[1]>0)&&((t.toTime_t()-ytShm->eHomeDevice[i].time[1])>300)){
  858. printf("%s time over close\n",ytShm->eHomeDevice[i].deviceID);
  859. ytShm->eHomeDevice[i].io[0] = 0x00;
  860. ytShm->eHomeDevice[i].io[7] = 0x00;
  861. ytShm->eHomeDevice[i].time[1]=0;
  862. }else if(ytShm->eHomeDevice[i].io[0]==0x00){
  863. printf("%s io7 on\n",ytShm->eHomeDevice[i].deviceID);
  864. // ytShm->eHomeDevice[i].io[7] = 0x00;
  865. ytShm->eHomeDevice[i].io[0] = 0x01;
  866. }else if(ytShm->eHomeDevice[i].io[0]==0x01){
  867. if(ytShm->eHomeDevice[i].io[15]>2){
  868. printf("%s NET_ECMS_StopGetRealStream\n",ytShm->eHomeDevice[i].deviceID);
  869. if(NET_ECMS_StopGetRealStream(ytShm->eHomeDevice[i].LoginId,ytShm->eHomeDevice[i].SessionId)){
  870. // ytShm->eHomeDevice[i].io[0] = 0x00;
  871. // ytShm->eHomeDevice[i].io[7] = 0x00;
  872. }
  873. ytShm->eHomeDevice[i].time[1]=0;
  874. ytShm->eHomeDevice[i].SessionId=-1;
  875. }
  876. }
  877. }else if(ytShm->eHomeDevice[i].io[6]==0x01){
  878. printf("%s io6 on\n",ytShm->eHomeDevice[i].deviceID);
  879. ytShm->eHomeDevice[i].io[0] = 0x01;
  880. if(ytShm->eHomeDevice[i].io[8]==0x08||ytShm->eHomeDevice[i].io[8]==0x84){
  881. ytShm->eHomeDevice[i].io[0] = 0x00;
  882. QDateTime zeroTime = QDateTime::fromTime_t(0);
  883. uint t1 = QDateTime::currentDateTime().toTime_t();
  884. QDateTime start = QDateTime::currentDateTime();
  885. QDateTime now;
  886. do{
  887. now=QDateTime::currentDateTime();
  888. }while(start.secsTo(now)<=5);
  889. QString filePath = QString("/var/ftp/pub/%1").arg(QString(ytShm->eHomeDevice[i].deviceID));
  890. QDir qd(filePath);
  891. QFileInfo subFileList = qd.entryInfoList(QDir::Files | QDir::CaseSensitive).last();
  892. QString filePath1 = QString("%1/%2").arg(filePath).arg(subFileList.fileName());
  893. QString filePath2 = QString("/usr/local/nginx/html/VideoAlarmPics/%1_%2.jpg").arg(QString(ytShm->eHomeDevice[i].deviceID)).arg(t1);
  894. QFile file2(filePath1);
  895. uint fileTime = subFileList.created().toTime_t();
  896. file2.copy(filePath2);
  897. QFile::remove(filePath1);
  898. QString picturePath = QString("http://47.103.74.123/VideoAlarmPics/%1_%2.jpg").arg(QString(ytShm->eHomeDevice[i].deviceID)).arg(t1);
  899. uint timeDiff = t1-fileTime;
  900. appendLog(QString("{filePath1:%1,%2,%3,%4}").arg(filePath1).arg(timeDiff).arg(t1).arg(fileTime));
  901. if(timeDiff>120){
  902. for(int j=0;j<alarmList.length();j++){
  903. if(alarmList.at(j).Device_Code.compare(ytShm->eHomeDevice[i].deviceID)==0){
  904. AlarmEvent ftpae = alarmList.at(j);
  905. clear_devalarm(ftpae,false);
  906. break;
  907. }
  908. }
  909. }else{
  910. ytShm->eHomeDevice[i].io[0] = 0x00;
  911. if(QString(ytShm->eHomeDeviceFtp[i].deviceID).compare(QString(ytShm->eHomeDevice[i].deviceID))==0){
  912. sprintf(ytShm->eHomeDeviceFtp[i].fileName,"%s",subFileList.fileName().toUtf8().data());
  913. sprintf(ytShm->eHomeDeviceFtp[i].filePath,"%s",picturePath.toUtf8().data());
  914. setFullTime(&(ytShm->eHomeDeviceFtp[i].alarmTime),zeroTime);
  915. }else{
  916. sprintf(ytShm->eHomeDeviceFtp[i].deviceID,"%s",QString(ytShm->eHomeDevice[i].deviceID).toUtf8().data());
  917. sprintf(ytShm->eHomeDeviceFtp[i].fileName,"%s",subFileList.fileName().toUtf8().data());
  918. sprintf(ytShm->eHomeDeviceFtp[i].filePath,"%s",picturePath.toUtf8().data());
  919. setFullTime(&(ytShm->eHomeDeviceFtp[i].alarmTime),zeroTime);
  920. }
  921. for(int j=0;j<alarmList.length();j++){
  922. if(alarmList.at(j).Device_Code.compare(ytShm->eHomeDevice[i].deviceID)==0){
  923. AlarmEvent ftpae = alarmList.at(j);
  924. clear_devalarm(ftpae,true);
  925. break;
  926. }
  927. }
  928. }
  929. }
  930. }
  931. if(ytShm->eHomeDevice[i].io[0]==0x01){
  932. if(ytShm->eHomeDevice[i].SessionId>-1){
  933. NET_EHOME_PUSHSTREAM_IN struPushStreamIn = {0};
  934. struPushStreamIn.dwSize = sizeof(struPushStreamIn);
  935. struPushStreamIn.lSessionID = ytShm->eHomeDevice[i].SessionId; //SessionID,预览请求会话ID
  936. //预览请求推流输出参数
  937. NET_EHOME_PUSHSTREAM_OUT struPushStreamOut = {0};
  938. if(!NET_ECMS_StartPushRealStream(ytShm->eHomeDevice[i].LoginId, &struPushStreamIn, &struPushStreamOut)){
  939. printf("%s NET_ECMS_StartGetRealStreamV11 failed.\n",ytShm->eHomeDevice[i].deviceID);
  940. ytShm->eHomeDevice[i].io[15]++;
  941. }else{
  942. printf("%s start push real stream\n",ytShm->eHomeDevice[i].deviceID);
  943. ytShm->eHomeDevice[i].io[15]=0x00;
  944. }
  945. }
  946. else
  947. {
  948. ytShm->eHomeDevice[i].previewport = 58000+i;
  949. printf("actice %s at %d(loginId:%d)\n",ytShm->eHomeDevice[i].deviceID,ytShm->eHomeDevice[i].previewport,ytShm->eHomeDevice[i].LoginId);
  950. NET_EHOME_PREVIEWINFO_IN_V11 struPreviewIn = {0};
  951. struPreviewIn.iChannel = 1; //通道号
  952. struPreviewIn.dwLinkMode = 0; //0- TCP方式,1- UDP方式
  953. struPreviewIn.dwStreamType = 1; //码流类型:0- 主码流,1- 子码流, 2- 第三码流
  954. memcpy(struPreviewIn.struStreamSever.szIP, oServerIP, sizeof(oServerIP));//流媒体服务器IP地址
  955. struPreviewIn.struStreamSever.wPort = ytShm->eHomeDevice[i].previewport;
  956. //预览请求输出参数
  957. NET_EHOME_PREVIEWINFO_OUT struPreviewOut = {0};
  958. if(!NET_ECMS_StartGetRealStreamV11(ytShm->eHomeDevice[i].LoginId, &struPreviewIn, &struPreviewOut)){
  959. printf("%s NET_ECMS_StartGetRealStreamV11 failed.\n",ytShm->eHomeDevice[i].deviceID);
  960. }else{
  961. printf("active %s lSessionID:%d\n",ytShm->eHomeDevice[i].deviceID,struPreviewOut.lSessionID);
  962. ytShm->eHomeDevice[i].SessionId = struPreviewOut.lSessionID;
  963. NET_EHOME_PUSHSTREAM_IN struPushStreamIn = {0};
  964. struPushStreamIn.dwSize = sizeof(struPushStreamIn);
  965. struPushStreamIn.lSessionID = struPreviewOut.lSessionID; //SessionID,预览请求会话ID
  966. //预览请求推流输出参数
  967. NET_EHOME_PUSHSTREAM_OUT struPushStreamOut = {0};
  968. if(!NET_ECMS_StartPushRealStream(ytShm->eHomeDevice[i].LoginId, &struPushStreamIn, &struPushStreamOut)){
  969. printf("%s NET_ECMS_StartGetRealStreamV11 failed.\n",ytShm->eHomeDevice[i].deviceID);
  970. ytShm->eHomeDevice[i].io[15]++;
  971. }else{
  972. printf("%s start push real stream\n",ytShm->eHomeDevice[i].deviceID);
  973. ytShm->eHomeDevice[i].io[15]=0x00;
  974. }
  975. }
  976. }
  977. }
  978. }else if((ytShm->eHomeDevice[i].time[1]>0)&&((t.toTime_t()-ytShm->eHomeDevice[i].time[1])>300)){
  979. if((ytShm->eHomeDevice[i].io[7]==0x01)||(ytShm->eHomeDevice[i].io[8]==0x01)){
  980. if(NET_ECMS_StopGetRealStream(ytShm->eHomeDevice[i].LoginId,ytShm->eHomeDevice[i].SessionId)){
  981. ytShm->eHomeDevice[i].io[0] = 0x00;
  982. ytShm->eHomeDevice[i].io[7] = 0x00;
  983. ytShm->eHomeDevice[i].time[1]=0;
  984. ytShm->eHomeDevice[i].SessionId =-1;
  985. }
  986. }
  987. }else if((ytShm->eHomeDevice[i].Connected==0x01)&&(ytShm->eHomeDevice[i].io[0]==0x00)){
  988. if(NET_ECMS_StopGetRealStream(ytShm->eHomeDevice[i].LoginId,ytShm->eHomeDevice[i].SessionId)){
  989. ytShm->eHomeDevice[i].Connected=0x00;
  990. ytShm->eHomeDevice[i].SessionId=-1;
  991. ytShm->eHomeDevice[i].time[0]=0;
  992. ytShm->eHomeDevice[i].time[1]=0;
  993. if(processList.at(i)->pid()>0){
  994. processList.at(i)->close();
  995. }
  996. // qDebug()<<QString("%1 will close.(%2)").arg(ytShm->eHomeDevice[i].deviceID).arg(i).toUtf8().data();
  997. QString tmpfile = QString(ytShm->eHomeDevice[i].filename).replace(" ","_");
  998. if(ytShm->eHomeDevice[i].tmpfile!=NULL)
  999. fclose(ytShm->eHomeDevice[i].tmpfile);
  1000. ytShm->eHomeDevice[i].savetmp = 0x00;
  1001. ytShm->eHomeDevice[i].tmpfile = NULL;
  1002. QFile(tmpfile).remove();
  1003. if(ytShm->eHomeDevice[i].io[8]==0x01){
  1004. tmpfile = QString("/tmp/%1.mp4").arg(ytShm->eHomeDevice[i].deviceID);
  1005. sprintf(ytShm->eHomeDevice[i].filename,"%s",tmpfile.toUtf8().data());
  1006. ytShm->eHomeDevice[i].tmpfile = fopen(tmpfile.toUtf8().data(),"wb");
  1007. setFullTime(&(ytShm->eHomeDevice[i].onLinetime),t);
  1008. sprintf(ytShm->eHomeDevice[i].filename,"");
  1009. }
  1010. ytShm->eHomeDevice[i].transed = 0x00;
  1011. }
  1012. }else if((ytShm->eHomeDevice[i].savetmp==0x01)&&(ytShm->eHomeDevice[i].transed==0x00)&&(ytShm->eHomeDevice[i].onLinetime.TIMESTAMP>0)&&((t.toTime_t()-ytShm->eHomeDevice[i].onLinetime.TIMESTAMP)>3)){
  1013. if(ytShm->eHomeDevice[i].io[6]==0x01){
  1014. ytShm->eHomeDevice[i].io[6]=0x00;
  1015. ytShm->eHomeDevice[i].io[0]=0x00;
  1016. for(int j=0;j<alarmList.length();j++){
  1017. if(alarmList.at(j).Device_Code.compare(QString(ytShm->eHomeDevice[i].deviceID))==0){
  1018. QString tmpfile = QString(ytShm->eHomeDevice[i].filename).replace(" ","_");
  1019. QString pic1name = QString("http://47.103.74.123/VideoAlarmPics/pic_%1_%2_0.jpg").arg(QDateTime::fromString(alarmList.at(j).Event_Time,"yyyy-MM-dd HH:mm:ss").toTime_t()).arg(QString(alarmList.at(j).Device_Code).replace(" ","_"));
  1020. QString picname = QString("/usr/local/nginx/html/VideoAlarmPics/pic_%1_%2_0.jpg").arg(QDateTime::fromString(alarmList.at(j).Event_Time,"yyyy-MM-dd HH:mm:ss").toTime_t()).arg(QString(alarmList.at(j).Device_Code).replace(" ","_"));
  1021. QString cmd1 = QString("ffmpeg -ss 00:00:00 -i \"%1\" -f image2 -y \"%2\"").arg(tmpfile).arg(picname);
  1022. if(ytShm->eHomeDevice[i].io[8]==0x02){
  1023. reportList.append(Alarm_Report(alarmList.at(j).Device_Code,alarmList.at(j).Event_Time,QString::fromUtf8("200104"),
  1024. QString::fromUtf8("insert into sp_video2017 (id,port,device_code,time,status,address,ncmd,data1,data2,data3,data4,data5,clsj,clr,clnr,clwb,cllxr,cldh,clzt,cllx,video) values (NULL,'%1','%2','%3','%4','','%5','%6','%7','%8','消防占道告警','','1970-01-01 08:00:00','','','','','',0,'','')")
  1025. .arg(2).arg(alarmList.at(j).Device_Code).arg(alarmList.at(j).Event_Time).arg(1)
  1026. .arg(104).arg(alarmList.at(j).Event_Status).arg(pic1name).arg("")));
  1027. sprintf(ytShm->eHomeDeviceFtp[i].filePath,"%s",pic1name.toUtf8().data());
  1028. }else if(ytShm->eHomeDevice[i].io[8]==0x04){
  1029. reportList.append(Alarm_Report(alarmList.at(j).Device_Code,alarmList.at(j).Event_Time,QString::fromUtf8("200105"),
  1030. QString::fromUtf8("insert into sp_video2017 (id,port,device_code,time,status,address,ncmd,data1,data2,data3,data4,data5,clsj,clr,clnr,clwb,cllxr,cldh,clzt,cllx,video) values (NULL,'%1','%2','%3','%4','','%5','%6','%7','%8','电动车禁入/区域入侵告警','','1970-01-01 08:00:00','','','','','',0,'','')")
  1031. .arg(2).arg(alarmList.at(j).Device_Code).arg(alarmList.at(j).Event_Time).arg(1)
  1032. .arg(106).arg(alarmList.at(j).Event_Status).arg(pic1name).arg("")));
  1033. sprintf(ytShm->eHomeDeviceFtp[i].filePath,"%s",pic1name.toUtf8().data());
  1034. }
  1035. if(processList.at(i)->pid()>0)
  1036. processList.at(i)->close();
  1037. processList.at(i)->start(cmd1);
  1038. alarmList.removeAt(j);
  1039. break;
  1040. }
  1041. }
  1042. }else{
  1043. setFullTime(&(ytShm->eHomeDevice[i].transtime),t);
  1044. QString tmpfile = QString(ytShm->eHomeDevice[i].filename).replace(" ","_");
  1045. ytShm->eHomeDevice[i].transed = 0x01;
  1046. sprintf(ytShm->eHomeDevice[i].filename,"%s",tmpfile.toUtf8().data());
  1047. system(QString("rm -f /usr/local/nginx/html/hls/%1*").arg(ytShm->eHomeDevice[i].deviceID).toUtf8().data());
  1048. QString cmd1 = QString("ffmpeg -re -i \"%1\" -c:v libx264 -an -strict -2 -s 352x278 -g 15 -f flv -v quiet \"rtmp://%2/hls/%3\" -c:v libx264 -an -strict -2 -s 352x278 -g 15 -f flv -v quiet \"rtmp://%4/live/%5\" ").arg(tmpfile).arg(iServerIP).arg(ytShm->eHomeDevice[i].deviceID).arg(iServerIP).arg(ytShm->eHomeDevice[i].deviceID);
  1049. if(processList.at(i)->pid()>0)
  1050. processList.at(i)->close();
  1051. processList.at(i)->start(cmd1);
  1052. ytShm->eHomeDevice[i].time[1] = t.toTime_t();
  1053. }
  1054. }else if((ytShm->eHomeDevice[i].transed==0x01)&&(ytShm->eHomeDevice[i].time[1]>0)&&((t.toTime_t()-ytShm->eHomeDevice[i].time[1])>600)){
  1055. if(NET_ECMS_StopGetRealStream(ytShm->eHomeDevice[i].LoginId,ytShm->eHomeDevice[i].SessionId)){
  1056. ytShm->eHomeDevice[i].Connected=0x00;
  1057. ytShm->eHomeDevice[i].SessionId=-1;
  1058. ytShm->eHomeDevice[i].time[0]=0;
  1059. ytShm->eHomeDevice[i].time[1]=0;
  1060. // qDebug()<<QString("%1 will close.(%2)").arg(ytShm->eHomeDevice[i].deviceID).arg(i).toUtf8().data();
  1061. processList.at(i)->close();
  1062. QString tmpfile = QString(ytShm->eHomeDevice[i].filename);
  1063. if(ytShm->eHomeDevice[i].tmpfile!=NULL)
  1064. fclose(ytShm->eHomeDevice[i].tmpfile);
  1065. ytShm->eHomeDevice[i].savetmp = 0x00;
  1066. ytShm->eHomeDevice[i].tmpfile = NULL;
  1067. QFile(tmpfile).remove();
  1068. ytShm->eHomeDevice[i].transed = 0x00;
  1069. }
  1070. }
  1071. }
  1072. }
  1073. if(reportList.length()>0){
  1074. if(db.open()){
  1075. while (reportList.length()>0) {
  1076. t = QDateTime::currentDateTime();
  1077. ytShm->workingTime[0] = t.toTime_t();
  1078. QString phonelist = "";
  1079. Alarm_Report rep = reportList.first();
  1080. appendLog(QString("[ %1 sql(%2) ] %3").arg(t.toString("yyyy-MM-dd HH:mm:ss")).arg(alarmList.length()).arg(rep.Sql));
  1081. printf("[ %s sql(%d) ] %s\n",t.toString("yyyy-MM-dd HH:mm:ss").toUtf8().data(),alarmList.length(),rep.Sql.toUtf8().data());
  1082. QSqlQuery qry = db.exec(rep.Sql);
  1083. quint64 insertId = qry.lastInsertId().toULongLong();
  1084. QString type="",point="";
  1085. //QString companyCode = getCompanyCode(rep.Device_Code);
  1086. QString companyCode="",deviceType="",deviceName="",value="";
  1087. for(int i=0;i<DEVICES_COUNT;i++){
  1088. QString devid = QString(ytShm->eHomeDevice[i].deviceID);
  1089. if(QString::compare(rep.Device_Code,devid)==0){
  1090. companyCode = QString(ytShm->eHomeDevice[i].rtsppath);
  1091. //deviceType.append(QString("%1").arg((ytShm->eHomeDevice[i].io[8]&0xff),2,16,QChar('0')));
  1092. deviceName = QString(ytMqShm->eHomeDeviceMq[i].deviceName);
  1093. value = QString(ytShm->eHomeDeviceFtp[i].filePath);
  1094. break;
  1095. }
  1096. }
  1097. if(rep.Event_Name.toInt()==200104){
  1098. type=QString::fromUtf8("占道侦测报警");
  1099. point.append("1602");
  1100. }else if(rep.Event_Name.toInt()==200001){
  1101. type=QString::fromUtf8("火点侦测报警");
  1102. point.append("1601");
  1103. }else if(rep.Event_Name.toInt()==200105){
  1104. type=QString::fromUtf8("电动车禁入/区域入侵告警");
  1105. point.append("1603");
  1106. }
  1107. printf("device code:%s\nget company code:%s\n",rep.Device_Code.toUtf8().data(),companyCode.toUtf8().data());
  1108. if(companyCode.length()>0){
  1109. QString alarmTopic = QString("/usky/ytCamCore/%1/%2/alarm").arg(companyCode).arg(rep.Device_Code);
  1110. QString alarmStr = "";
  1111. alarmStr.append(QString("{\"devId\":\"%1\",\"connType\":\"G\",\"deviceName\":\"%2\",\"alarams\":[{\"dp\":[{\"property\":\"%3\",\"serial\":\"%4\",\"value\":\"%5\",\"status\":\"0\"}],\"deviceName\":\"%6\",\"timeStamp\":\"%7\",\"deviceModel\":\"\",\"deviceType\":\"16\",\"devId\":\"%8\"}],\"type\":\"ALARM\",\"timeStamp\":\"%9\"}").arg(rep.Device_Code).arg(deviceName).arg(type).arg(point).arg(value).arg(deviceName).arg((QDateTime::fromString(rep.Event_Time,"yyyy-MM-dd hh:mm:ss")).toTime_t()).arg(rep.Device_Code).arg((QDateTime::fromString(rep.Event_Time,"yyyy-MM-dd hh:mm:ss")).toTime_t()));
  1112. if((m_client->connectionState()==QMQTT::STATE_DISCONNECTED) ||(m_client->connectionState()==QMQTT::STATE_INIT)){
  1113. m_client->connectToHost();
  1114. }
  1115. if(m_client->connectionState()==QMQTT::STATE_CONNECTED){
  1116. m_client->publish(QMQTT::Message(alarmmqttIdx++,alarmTopic,alarmStr.toUtf8()));
  1117. if(alarmmqttIdx>9999)
  1118. alarmmqttIdx=1;
  1119. }
  1120. QString rep1 = QString("{\"SubType\":16,\"DeviceId\":\"%1\",\"InsertId\":%2,\"Confirmed\":false}").arg(rep.Device_Code).arg(insertId);
  1121. spThread[repcur]->appendData(rep1);
  1122. QString rep2 = QString("{\"SubType\":16,\"DeviceId\":\"%1\",\"InsertId\":%2,\"Confirmed\":0,\"CompanyCode\":\"%3\",\"evt_name\":\"%4\",\"evt\":0,\"alarm_time\":\"%5\"}")
  1123. .arg(rep.Device_Code).arg(insertId).arg(companyCode).arg(type).arg(rep.Event_Time);
  1124. printf("1234 --- %s\n",rep2.toUtf8().data());
  1125. wssThread[repcur]->appendData(rep2);
  1126. for(int i=0;i<companyphoneList.length();i++){
  1127. if(QString::compare(companyphoneList.at(i).CompanyCode,companyCode)==0){
  1128. if(phonelist.length()==0)
  1129. phonelist = companyphoneList.at(i).Phone;
  1130. else
  1131. phonelist.append(","+companyphoneList.at(i).Phone);
  1132. }
  1133. }
  1134. repcur++;
  1135. repcur &= 0x07;
  1136. if(phonelist.length()>0){
  1137. QString data = QString("evt_name=%1&device_code=%2&phone=%3&insert_id=%4&time=%5&bz=%1").arg(type).arg(rep.Device_Code).arg(phonelist).arg(insertId).arg(rep.Event_Time)
  1138. .replace(",","%2C").replace(":","%3A").replace(" ","+");
  1139. wxThreads[wxcur]->appendData(data);
  1140. wxcur++;
  1141. wxcur &= 0x07;
  1142. }
  1143. }
  1144. reportList.removeFirst();
  1145. }
  1146. db.close();
  1147. }
  1148. }
  1149. if(sqlList.length()>0){
  1150. if(db.open()){
  1151. while(sqlList.length()>0){
  1152. db.exec(sqlList.first());
  1153. appendLog(QString("[ %1 sql ] %2").arg(t.toString("yyyy-MM-dd HH:mm:ss")).arg(sqlList.first()));
  1154. sqlList.removeFirst();
  1155. }
  1156. db.close();
  1157. }
  1158. }
  1159. int a_count=0;
  1160. t = QDateTime::currentDateTime();
  1161. if((t.toTime_t()-ChkTime)>60)
  1162. {
  1163. ChkTime = t.toTime_t();
  1164. QListIterator<AlarmEvent> AlaList(alarmList);
  1165. while(AlaList.hasNext()){
  1166. AlarmEvent ae = AlaList.next();
  1167. if((t.toTime_t()-ae.t_stamp)>120){
  1168. nopic_count++;
  1169. a_count++;
  1170. appendLog(QString("[ %1 out(%2:%3) ] %4 %5").arg(t.toString("yyyy-MM-dd HH:mm:ss")).arg(alarmList.length()).arg(a_count).arg(ae.Device_Code).arg(ae.Event_Time));
  1171. clear_devalarm(ae,false);
  1172. if(nopic_count>5)
  1173. exit(1);
  1174. }
  1175. }
  1176. }
  1177. isWorking = false;
  1178. }