coreobject.cpp 66 KB

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