HeartBeatFSM.cpp 58 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876
  1. #include "stdafx.h"
  2. #include <string.h>
  3. #include "HeartBeatFSM.h"
  4. #ifdef RVC_OS_WIN
  5. #pragma comment (lib, "Ws2_32.lib")
  6. #pragma comment (lib, "Mswsock.lib")
  7. #pragma comment (lib, "AdvApi32.lib")
  8. #pragma comment(lib, "pdh.lib")
  9. #endif //RVC_OS_WIN
  10. using namespace CardIssuer;
  11. using namespace PinPad;
  12. using namespace CardReadAdapter;
  13. using namespace IDCertificate;
  14. #include "EventCode.h"
  15. #include "DeviceCrossHelper.h"
  16. const int DEFAULT_BUFLEN = 2048;
  17. const int MAX_SEND_FAILED_TIMES = 5;
  18. const int MAX_INIT_TIMES = 5;
  19. //#define DEFAULT_PORT "408"
  20. // Termainal Performance Counter Component [Josephus in 9:31:27 2016/4/23]
  21. CONST ULONG COUNTER_INTERVAL_MS = 1000;
  22. const char * AvailMemoryQuery = "\\Memory\\Available MBytes";
  23. const char * HandleNumQuery = "\\Process(_Total)\\Handle Count";
  24. const char * ThreadNumQuery = "\\Process(_Total)\\Thread Count";
  25. const char * ProcessNumQuery = "\\System\\Processes";
  26. const char * SystemElapsedQuery = "\\System\\System Up Time";
  27. const char * ProcessTimeQuery = "\\Processor Information(_Total)\\% Processor Time";
  28. #define DIV (1024 * 1024)
  29. #define DAY_DIV (24 * 60 * 60)
  30. #define HOURS_DIV (60 * 60)
  31. #define MINUS_DIV (60)
  32. // End Performance Component [Josephus in 9:32:05 2016/4/23]
  33. //oiltmp need to move together?
  34. int StrBuf2HexBuf(LPCTSTR strBuf, PBYTE* hexBuf)
  35. {
  36. int len = strlen(strBuf);
  37. if (len == 0 || len % 2 != 0)
  38. return 0;
  39. BYTE* buf = new BYTE[len / 2];
  40. if (buf == NULL)
  41. return 0;
  42. int j = 0;
  43. for (int i = 0; i < len;)
  44. {
  45. int tmpVal;
  46. sscanf(strBuf + i, "%2X", &tmpVal);
  47. buf[j] = tmpVal;
  48. //buf[j] = char2int(strBuf[i])*16 + char2int(strBuf[i+1]);
  49. i += 2;
  50. j++;
  51. }
  52. //memcpy(buf,strBuf,len);
  53. *hexBuf = buf;
  54. return j;
  55. }
  56. int HexBuf2StrBuf(PBYTE hexBuf, char** strBuf, DWORD len)
  57. {
  58. char* tmpStr = *strBuf;
  59. int count = 0;
  60. for (int i = 0; i < len; ++i)
  61. {
  62. sprintf(tmpStr + count, "%0.2X", hexBuf[i]);
  63. count += 2;
  64. }
  65. return count;
  66. }
  67. ErrorCodeEnum CHeartBeatFSM::OnInit()
  68. {
  69. LOG_FUNCTION();
  70. GetEntityBase()->GetFunction()->SetSysVar("HeartbeatState","S");
  71. ErrorCodeEnum Error;
  72. CSmartPointer<IEntityFunction> spEntityFunction = GetEntityBase()->GetFunction();
  73. CSmartPointer<IConfigInfo> spConfig;
  74. CSystemStaticInfo sysInfo;
  75. Error = GetEntityBase()->GetFunction()->GetSystemStaticInfo(sysInfo);
  76. if(Error == Error_Succeed) {
  77. m_bJBMachine = !sysInfo.strMachineType.Compare("RVC.IL", true);
  78. m_localDeviceNo = sysInfo.strTerminalID;
  79. }
  80. Error = spEntityFunction->OpenConfig(Config_CenterSetting, spConfig);
  81. if (Error != Error_Succeed) {
  82. LOG_TRACE("open cfg file failed!");
  83. //logwarn oiltest
  84. return Error_DevLoadFileFailed;
  85. }
  86. m_tmpTestFlag = 0;
  87. spConfig->ReadConfigValue(GetEntityBase()->GetEntityName(),"Server",m_servStr);
  88. spConfig->ReadConfigValue(GetEntityBase()->GetEntityName(),"Server_Backup",m_servStrB);
  89. if (!m_servStr.IsNullOrEmpty())
  90. {
  91. CAutoArray<CSimpleStringA> aaServ = m_servStr.Split(' ');
  92. if (aaServ.GetCount() >= 2)
  93. {
  94. m_servIP = aaServ[0];
  95. m_port = atoi(aaServ[1]);
  96. }
  97. else
  98. {
  99. Dbg("cfg error!");
  100. GetEntityBase()->GetFunction()->ShowFatalError("实体HeartBeat找不到对应的配置,请检查集中配置");
  101. return Error_Param;
  102. }
  103. }
  104. if (!m_servStrB.IsNullOrEmpty())
  105. {
  106. CAutoArray<CSimpleStringA> aaServB = m_servStrB.Split(' ');
  107. if (aaServB.GetCount() >= 2)
  108. {
  109. m_servIPB = aaServB[0];
  110. m_portB = atoi(aaServB[1]);
  111. }
  112. else
  113. {
  114. Dbg("no backup(%s).",(LPCSTR)m_servStrB);
  115. m_servIPB = m_servIP;
  116. m_portB = m_port;
  117. }
  118. }
  119. Dbg("%s,%d;%s,%d",(LPCTSTR)m_servIP,m_port,(LPCTSTR)m_servIPB,m_portB);
  120. spConfig->ReadConfigValueInt(GetEntityBase()->GetEntityName(),"TestFlag",m_tmpTestFlag);
  121. //网络字节序
  122. //由于双活改造,改成固定ip,分行服务有处理
  123. m_servIP = "99.1.100.215";
  124. m_dwServIP = inet_addr(m_servIP);
  125. m_csServerIP = m_servIP;
  126. CSimpleStringA csRunDiskName("C:\\");
  127. Error = GetEntityBase()->GetFunction()->GetPath("Run", csRunDiskName);
  128. Dbg("GetPath of run is %s 0x%x", (LPCTSTR)csRunDiskName, Error);
  129. CAutoArray<CSimpleStringA> arrays = csRunDiskName.Split('\\');
  130. if(arrays.GetCount() > 0)
  131. {
  132. m_csRunDiskName = arrays[0] + "\\";
  133. Dbg("m_csRunDiskName is %s", (LPCTSTR)m_csRunDiskName);
  134. }
  135. else
  136. {
  137. Dbg("Split rundisk file string(%s) failed", (LPCTSTR)csRunDiskName);
  138. return Error_Unexpect;
  139. }
  140. //CSimpleStringA csTradeState("B");
  141. //Error = GetEntityBase()->GetFunction()->GetSysVar("TradeManageState",csTradeState);
  142. //if (Error == Error_Succeed)
  143. //{
  144. // Dbg("First get TradeManageState:%s",(const char*)csTradeState);
  145. // if (csTradeState.Compare("L",true) == 0)
  146. // m_tradeState = 8;
  147. //}
  148. return Error_Succeed;
  149. }
  150. ErrorCodeEnum CHeartBeatFSM::OnExit()
  151. {
  152. return Error_NotImpl;
  153. }
  154. //Init(Stop)
  155. void CHeartBeatFSM::s0_on_entry()
  156. {
  157. //LOG_FUNCTION();
  158. {
  159. //check if can start to work(handshake...)
  160. //1.check if AccessAuthorization have finished
  161. //2.check if network connected
  162. //3.check if framework on Exitting or Terminating
  163. //all of above have checked,start to work
  164. if (m_pHandShakeConn != NULL)
  165. {
  166. Dbg("init connection.");
  167. m_pHandShakeConn->Close();
  168. m_pHandShakeConn->DecRefCount();
  169. m_pHandShakeConn = NULL;
  170. }
  171. FSMEvent *e = new FSMEvent(USER_EVT_START);
  172. PostEventFIFO(e);
  173. m_initTimes++;
  174. if (m_initTimes > 1)
  175. Sleep(30000);
  176. if (m_initTimes > MAX_INIT_TIMES)
  177. {
  178. Dbg("have try to init x times,give up!");
  179. //logwarn oiltest
  180. m_initTimes = 0;
  181. }
  182. }
  183. }
  184. void CHeartBeatFSM::s0_on_exit()
  185. {
  186. }
  187. unsigned int CHeartBeatFSM::s0_on_event(FSMEvent* pEvt)
  188. {
  189. switch(pEvt->iEvt)
  190. {
  191. case USER_EVT_START:
  192. {
  193. StartTask* task = new StartTask(this);
  194. GetEntityBase()->GetFunction()->PostThreadPoolTask(task);
  195. pEvt->SetHandled();
  196. }
  197. return 0;
  198. default:
  199. break;
  200. }
  201. return 0;
  202. }
  203. //Starting
  204. void CHeartBeatFSM::s1_on_entry()
  205. {
  206. //LOG_FUNCTION();
  207. }
  208. void CHeartBeatFSM::s1_on_exit()
  209. {
  210. }
  211. unsigned int CHeartBeatFSM::s1_on_event(FSMEvent* pEvt)
  212. {
  213. switch(pEvt->iEvt)
  214. {
  215. case USER_EVT_STARTFINISHED:
  216. pEvt->SetHandled();
  217. if (pEvt->param1 == 0)
  218. {
  219. HandShakeTask* task = new HandShakeTask(this);
  220. GetEntityBase()->GetFunction()->PostThreadPoolTask(task);
  221. pEvt->SetHandled();
  222. return 0;
  223. }
  224. else
  225. {
  226. // SetFlag for MobileDial entity. [Josephus in 11:40:29 2016/8/16]
  227. GetEntityBase()->GetFunction()->SetSysVar("HeartbeatState","D");
  228. return 1;
  229. }
  230. break;
  231. default:
  232. break;
  233. }
  234. return 0;
  235. }
  236. //Connnected
  237. void CHeartBeatFSM::s2_on_entry()
  238. {
  239. LOG_FUNCTION();
  240. m_initTimes = 0;
  241. m_testResult = Error_Succeed;
  242. LogEvent(Severity_Middle, LOG_EVT_HEARTBEAT_CONNECTED, "Branch heartbeat service connected.");
  243. }
  244. void CHeartBeatFSM::s2_on_exit()
  245. {
  246. }
  247. unsigned int CHeartBeatFSM::s2_on_event(FSMEvent* pEvt)
  248. {
  249. switch(pEvt->iEvt)
  250. {
  251. case USER_EVT_INSTRUCTION:
  252. {
  253. InstructionEvent *pIE = dynamic_cast<InstructionEvent*>(pEvt);
  254. pEvt->SetHandled();
  255. DoInstruction(pIE->ctx);
  256. }
  257. break;
  258. case USER_EVT_HANDSHAKEFINISHED:
  259. pEvt->SetHandled();
  260. break;
  261. case USER_EVT_STOP:
  262. pEvt->SetHandled();
  263. break;
  264. case USER_EVT_START:
  265. pEvt->SetHandled();
  266. break;
  267. case USER_EVT_CARD_ACTIVE:
  268. {
  269. Dbg("s2 card active.");
  270. pEvt->SetHandled();
  271. CardActiveEvent *pcae = dynamic_cast<CardActiveEvent*>(pEvt);
  272. CardActiveTask *pTask = new CardActiveTask(this);
  273. pTask->ctx = pcae->ctx;
  274. GetEntityBase()->GetFunction()->PostThreadPoolTask(pTask);
  275. }
  276. break;
  277. case USER_EVT_CARD_ACTIVE_FINISHED:
  278. pEvt->SetHandled();
  279. break;
  280. case USER_EVT_CROSS_TERM_CALL:
  281. {
  282. pEvt->SetHandled();
  283. CrossTermCallEvent* pCTCE = dynamic_cast<CrossTermCallEvent*>(pEvt);
  284. CrossTermCallTask *pTask = new CrossTermCallTask(this);
  285. pTask->ctx = pCTCE->ctx;
  286. Dbg("s2 cross call,type %x.",pCTCE->ctx->Req.type);
  287. GetEntityBase()->GetFunction()->PostThreadPoolTask(pTask);
  288. }
  289. break;
  290. case USER_EVT_CROSS_TERM_CALL_FINISHED:
  291. pEvt->SetHandled();
  292. break;
  293. case USER_EVT_ILCallToRVC:
  294. {
  295. pEvt->SetHandled();
  296. ILCallToRVCEvent* pCTCE = dynamic_cast<ILCallToRVCEvent*>(pEvt);
  297. ILCallToRVCTask *pTask = new ILCallToRVCTask(this);
  298. pTask->ctx = pCTCE->ctx;
  299. GetEntityBase()->GetFunction()->PostThreadPoolTask(pTask);
  300. }
  301. break;
  302. case USER_EVT_CallResultToIL:
  303. {
  304. pEvt->SetHandled();
  305. CallResultToILEvent* pCTCE = dynamic_cast<CallResultToILEvent*>(pEvt);
  306. CallResultToILTask *pTask = new CallResultToILTask(this);
  307. pTask->ctx = pCTCE->ctx;
  308. GetEntityBase()->GetFunction()->PostThreadPoolTask(pTask);
  309. }
  310. break;
  311. default:
  312. break;
  313. }
  314. return 0;
  315. }
  316. //Lost
  317. void CHeartBeatFSM::s3_on_entry()
  318. {
  319. GetEntityBase()->GetFunction()->SetSysVar("HeartbeatState","L");
  320. }
  321. void CHeartBeatFSM::s3_on_exit()
  322. {
  323. }
  324. unsigned int CHeartBeatFSM::s3_on_event(FSMEvent* pEvt)
  325. {
  326. return 0;
  327. }
  328. //Reject
  329. void CHeartBeatFSM::s4_on_entry()
  330. {
  331. GetEntityBase()->GetFunction()->SetSysVar("HeartbeatState","R");
  332. FSMEvent *pStopEvt = new FSMEvent(USER_EVT_STOP);
  333. PostEventFIFO(pStopEvt);
  334. }
  335. void CHeartBeatFSM::s4_on_exit()
  336. {
  337. }
  338. unsigned int CHeartBeatFSM::s4_on_event(FSMEvent* pEvt)
  339. {
  340. switch(pEvt->iEvt)
  341. {
  342. case USER_EVT_STOP:
  343. pEvt->SetHandled();
  344. break;
  345. default:
  346. break;
  347. }
  348. return 0;
  349. }
  350. //Failed
  351. void CHeartBeatFSM::s5_on_entry()
  352. {
  353. m_testResult = Error_InvalidState;
  354. }
  355. void CHeartBeatFSM::s5_on_exit()
  356. {
  357. }
  358. unsigned int CHeartBeatFSM::s5_on_event(FSMEvent* pEvt)
  359. {
  360. return 0;
  361. }
  362. int CHeartBeatFSM::Starting()
  363. {
  364. Dbg("starting.....");
  365. if (!m_pHandShakeConn)
  366. {
  367. //HeartBeatConnection* pHandShakeConn;
  368. m_pHandShakeConn = new HeartBeatConnection(m_pEntity, this);
  369. if (m_pHandShakeConn != NULL)
  370. {
  371. bool bConn = false;
  372. bConn = m_pHandShakeConn->ConnectFromCentralSetting();
  373. //if (!m_bUseBackup)
  374. //{
  375. // bConn = m_pHandShakeConn->Connect(m_servIP, m_port, 3);
  376. // m_dwServIP = inet_addr(m_servIP);
  377. // m_csServerIP = m_servIP;
  378. //}
  379. //else
  380. //{
  381. // bConn = m_pHandShakeConn->Connect(m_servIPB, m_portB, 3);
  382. // m_dwServIP = inet_addr(m_servIPB);
  383. // m_csServerIP = m_servIPB;
  384. //}
  385. if (!bConn)
  386. {
  387. m_pHandShakeConn->Close();
  388. //delete m_pHandShakeConn;//oiltest
  389. m_pHandShakeConn->DecRefCount();
  390. m_pHandShakeConn = NULL;
  391. Dbg("cannot connect to server.");
  392. //if (m_bUseBackup)
  393. LogEvent(Severity_Middle, LOG_EVT_HEARTBEAT_UN_CONNECTED, "Branch heartbeat service unconnected.");
  394. //m_bUseBackup = !m_bUseBackup;
  395. return 1;
  396. }
  397. }
  398. //else
  399. //Dbg("new heartbeatconnection failed.");
  400. }
  401. Dbg("start ok.");
  402. return 0;
  403. /*
  404. WSADATA wsaData;
  405. m_ConnSocket = INVALID_SOCKET;
  406. struct addrinfo *result = NULL,*ptr = NULL,hints;
  407. int iResult;
  408. int recvbuflen = DEFAULT_BUFLEN;
  409. // Initialize Winsock
  410. iResult = WSAStartup(MAKEWORD(2,2), &wsaData);
  411. if (iResult != 0)
  412. {
  413. Dbg("WSAStartup failed with error: %d\n", iResult);
  414. return 1;
  415. }
  416. ZeroMemory( &hints, sizeof(hints) );
  417. hints.ai_family = AF_UNSPEC;
  418. hints.ai_socktype = SOCK_STREAM;
  419. hints.ai_protocol = IPPROTO_TCP;
  420. //oiltest get from ini file
  421. Dbg("server %s,port %d",(LPCSTR)m_servIP,m_port);
  422. iResult = getaddrinfo(m_servIP, m_servPort, &hints, &result);
  423. if ( iResult != 0 )
  424. {
  425. Dbg("getaddrinfo failed with error: %d\n", iResult);
  426. WSACleanup();
  427. return 1;
  428. }
  429. for(ptr=result; ptr != NULL ;ptr=ptr->ai_next)
  430. {
  431. m_ConnSocket = socket(ptr->ai_family, ptr->ai_socktype,
  432. ptr->ai_protocol);
  433. if (m_ConnSocket == INVALID_SOCKET)
  434. {
  435. Dbg("socket failed with error: %ld\n", WSAGetLastError());
  436. WSACleanup();
  437. return 1;
  438. }
  439. iResult = connect(m_ConnSocket, ptr->ai_addr, (int)ptr->ai_addrlen);
  440. if (iResult == SOCKET_ERROR)
  441. {
  442. closesocket(m_ConnSocket);
  443. m_ConnSocket = INVALID_SOCKET;
  444. continue;
  445. }
  446. break;
  447. }
  448. Dbg("conn socket %d",m_ConnSocket);
  449. freeaddrinfo(result);
  450. if (m_ConnSocket == INVALID_SOCKET)
  451. {
  452. Dbg("Unable to connect to server!\n");
  453. WSACleanup();
  454. return 1;
  455. }
  456. */
  457. }
  458. int CHeartBeatFSM::DoHandShake()
  459. {
  460. if (m_pHandShakeConn) {
  461. Dbg("start handshake");
  462. //oiltest sp_var_client_set has no write privilege!
  463. //GetEntityBase()->GetFunction()->SetSysVar("HeartbeatState","C");
  464. while (1)
  465. {
  466. //HeartBeatConnection* pHandShakeConn;
  467. //pHandShakeConn = new HeartBeatConnection(m_pEntity, this);
  468. //if (pHandShakeConn != NULL)
  469. //{
  470. // bool bConn = false;
  471. // if (!m_bUseBackup)
  472. // bConn = pHandShakeConn->Connect(m_servIP, m_port, 3);
  473. // else
  474. // bConn = pHandShakeConn->Connect(m_servIPB, m_portB, 3);
  475. // if (!bConn)
  476. // {
  477. // pHandShakeConn->Close();
  478. // //delete m_pHandShakeConn;//oiltest
  479. // pHandShakeConn->DecRefCount();
  480. // pHandShakeConn = NULL;
  481. // Dbg("cannot connect to server(%d).", m_bUseBackup);
  482. // m_bUseBackup = !m_bUseBackup;
  483. // }
  484. //}
  485. if (!m_pHandShakeConn || !m_pHandShakeConn->IsConnectionOK())
  486. {
  487. FSMEvent *e = new FSMEvent(USER_EVT_START);
  488. PostEventFIFO(e);
  489. break;
  490. }
  491. GetEntityBase()->GetFunction()->SetSysVar("HeartbeatState", "C");
  492. m_pHandShakeConn->SendHandShake();
  493. Sleep(20000);//oiltest
  494. if (m_tmpTestFlag)
  495. {
  496. Dbg("send spshell.exe restart event.");
  497. LogEvent(Severity_Middle, Event_Req_Framework_Restart, "spshell.exe restart");
  498. }
  499. }
  500. }
  501. /*
  502. char sendbuf[DEFAULT_BUFLEN];
  503. memset(sendbuf,0,sizeof(sendbuf));
  504. TerminalInfo* pTermInfo = (TerminalInfo*)sendbuf;
  505. memcpy(pTermInfo->TerminalNo,"12345678",8);
  506. //CSimpleStringA warningLevel,runState,customerHandle,callState,localMaintain,remoteMaintain;
  507. //oiltest set default value
  508. CSimpleStringA warningLevel("w"),runState("r"),customerHandle("c"),callState("s"),
  509. localMaintain("l"),remoteMaintain("m");
  510. Dbg("get sysvar");
  511. GetEntityBase()->GetFunction()->GetSysVar("WarningLevel",warningLevel);
  512. GetEntityBase()->GetFunction()->GetSysVar("RunState",runState);
  513. GetEntityBase()->GetFunction()->GetSysVar("CustomerHandle",customerHandle);
  514. GetEntityBase()->GetFunction()->GetSysVar("CallState",callState);
  515. GetEntityBase()->GetFunction()->GetSysVar("LocalMaintain",localMaintain);
  516. GetEntityBase()->GetFunction()->GetSysVar("RemoteMaintain",remoteMaintain);
  517. //oiltest byteorder
  518. pTermInfo->ip = m_ulServIP;
  519. pTermInfo->WarningLevel = warningLevel[0];
  520. pTermInfo->RunState = runState[0];
  521. pTermInfo->CustomerHandle = customerHandle[0];
  522. pTermInfo->CallState = callState[0];
  523. pTermInfo->LocalMaintain = localMaintain[0];
  524. pTermInfo->RemoteMaintain = remoteMaintain[0];
  525. Dbg("before send socket %d",m_ConnSocket);
  526. int sendFailedTimes = 0;
  527. while(1)
  528. {
  529. //oiltest break condition...
  530. //send machine info
  531. int iResult = send(m_ConnSocket, sendbuf, (int)sizeof(sendbuf), 0 );
  532. if (iResult == SOCKET_ERROR)
  533. {
  534. Dbg("send failed with error: %d\n", WSAGetLastError());
  535. sendFailedTimes++;
  536. if (sendFailedTimes > MAX_SEND_FAILED_TIMES)
  537. {
  538. Dbg("have failed %d times,no send anymore.",sendFailedTimes);
  539. closesocket(m_ConnSocket);
  540. WSACleanup();
  541. break;
  542. }
  543. }
  544. Sleep(20000);//oiltest
  545. }
  546. */
  547. return 0;
  548. }
  549. int CHeartBeatFSM::CardActive(SpReqAnsContext<HeartBeatService_CardActive_Req, HeartBeatService_CardActive_Ans>::Pointer ctx)
  550. {
  551. LOG_FUNCTION();
  552. if (m_pHandShakeConn && m_pHandShakeConn->IsConnectionOK())
  553. {
  554. m_pHandShakeConn->SendCardActive(0,ctx->Req.slot, 0,(const char*)ctx->Req.term,(const char*)ctx->Req.account, ctx->Req.account.GetLength(), (const char*)ctx->Req.data, ctx->Req.data.GetLength(),0,0);
  555. }
  556. else
  557. {
  558. if (ctx->Req.account.GetLength() > 6)
  559. Dbg("acc:%s****%s,no connection.", (const char*)ctx->Req.account.SubString(0, 6), (const char*)ctx->Req.account.SubString(ctx->Req.account.GetLength() - 4, 4));
  560. else
  561. Dbg("acc:%s, size:%d", (const char*)ctx->Req.account,ctx->Req.account.GetLength());
  562. ctx->Answer(Error_Unexpect);
  563. }
  564. return 0;
  565. }
  566. void CHeartBeatFSM::DoInstruction(SpReqAnsContext<HeartBeatService_Instruction_Req, HeartBeatService_Instruction_Ans>::Pointer ctx)
  567. {
  568. switch(ctx->Req.type)
  569. {
  570. case INC_GLOBAL_SETTING_SYNC:
  571. break;
  572. case INC_COMM_RECONNECT:
  573. break;
  574. case INC_START_REMOTE_CONTROL:
  575. break;
  576. case INC_UPDATE_CHECK:
  577. break;
  578. case INC_RECOVER_SERVICE:
  579. break;
  580. case INC_PAUSE_SERVICE:
  581. break;
  582. case INC_AREA_SERVICE_SWITCH:
  583. break;
  584. default:
  585. break;
  586. }
  587. }
  588. ErrorCodeEnum CHeartBeatFSM::SetErrorList(int warmLevel,CSimpleStringA strList)
  589. {
  590. m_warnLevel = warmLevel;
  591. m_entErrorList = strList;
  592. Dbg("strList[%s]",(LPCTSTR)strList);
  593. return Error_Succeed;
  594. }
  595. void CHeartBeatFSM::SelfTest(EntityTestEnum eTestType,CSmartPointer<ITransactionContext> pTransactionContext)
  596. {
  597. //for simple
  598. pTransactionContext->SendAnswer(m_testResult);
  599. }
  600. void CHeartBeatFSM::LocalPreOnline(int slot, CSimpleStringA fromTermNo,CSimpleStringA termNo, CSimpleStringA account, CSimpleStringA data)
  601. {
  602. LOG_FUNCTION();
  603. CardReadAdapterService_ClientBase *pCardReadAdapterClient = NULL;
  604. ErrorCodeEnum eErr = Error_Unexpect;
  605. pCardReadAdapterClient = new CardReadAdapterService_ClientBase(GetEntityBase());
  606. if (pCardReadAdapterClient != NULL)
  607. eErr = pCardReadAdapterClient->Connect();
  608. if (pCardReadAdapterClient == NULL || eErr != Error_Succeed)
  609. {
  610. Dbg("pGuiConsoleClient is null or connect CardReadAdapter failed.%d",eErr);
  611. return;
  612. }
  613. CardReadAdapterService_PreOnline_Req req;
  614. CardReadAdapterService_PreOnline_Ans ans;
  615. req.businessData = data;
  616. char buf[16];
  617. ZeroMemory(buf, sizeof(buf));
  618. _itoa(slot, buf, 10);
  619. CSimpleStringA kaku("kaku#");
  620. req.module = 1;
  621. req.reserved2.Init(2);
  622. req.reserved2[0] = kaku + CSimpleStringA(buf);
  623. Dbg("local:%s", (const char*)req.reserved2[0]);
  624. req.reserved2[1] = account;
  625. eErr = pCardReadAdapterClient->PreOnline(req, ans, 65000);
  626. if (eErr != Error_Succeed)
  627. Dbg("local preonline failed. code:%d", eErr);
  628. CardReadAdapterService_QueryCardInfoOnStore_Req reqX;
  629. CardReadAdapterService_QueryCardInfoOnStore_Ans ansX;
  630. ErrorCodeEnum eErrX = Error_Unexpect;
  631. eErrX = pCardReadAdapterClient->QueryCardInfoOnStore(reqX, ansX,12000);
  632. if (eErrX != Error_Succeed)
  633. {
  634. Dbg("QueryCardInfoOnStore failed.%d",eErrX);
  635. ansX.findCard = ansX.cardPos = 9999;
  636. }
  637. if (m_pHandShakeConn && m_pHandShakeConn->IsConnectionOK())
  638. {
  639. m_pHandShakeConn->SendCardActive(1,slot,eErr, (const char*)termNo, (const char*)account,
  640. account.GetLength(), (const char*)ans.result, ans.result.GetLength(),ansX.findCard,ansX.cardPos);
  641. }
  642. }
  643. void CHeartBeatFSM::ReceivePreOnlineBack(unsigned long errCode,CSimpleStringA data, unsigned long findCard, unsigned long cardPos)
  644. {
  645. CardIssuerService_ClientBase *pCardIssuerClient = NULL;
  646. ErrorCodeEnum eErr = Error_Unexpect;
  647. pCardIssuerClient = new CardIssuerService_ClientBase(GetEntityBase());
  648. if (pCardIssuerClient != NULL)
  649. eErr = pCardIssuerClient->Connect();
  650. if (pCardIssuerClient == NULL || eErr != Error_Succeed)
  651. {
  652. Dbg("pGuiConsoleClient is null or connect to cardissuer failed.%d", eErr);
  653. return;
  654. }
  655. CardIssuerService_NotifyPreonline_Req req;
  656. CardIssuerService_NotifyPreonline_Ans ans;
  657. req.data = data;
  658. req.findCard = findCard;
  659. req.cardPos = cardPos;
  660. req.errCode = errCode;
  661. eErr = pCardIssuerClient->NotifyPreonline(req, ans, 10000);
  662. Dbg("NotifyPreonline ret:%d",eErr);
  663. }
  664. int CHeartBeatFSM::CrossTermCall(SpReqAnsContext<HeartBeatService_CrossTermCall_Req, HeartBeatService_CrossTermCall_Ans>::Pointer ctx)
  665. {
  666. int ret = 0;
  667. Dbg("cross term call,type:%x, entity: 0x%x",ctx->Req.type, ctx->Req.nEntityID);
  668. switch (ctx->Req.nEntityID)
  669. {
  670. case 0x206:
  671. case 0x201:
  672. case 0x218:
  673. case 0x21B:
  674. ret = ProcessCrossCallToHBService(ctx->Req.type,ctx);
  675. break;
  676. default:
  677. break;
  678. }
  679. return ret;
  680. }
  681. int CHeartBeatFSM::ProcessCrossCallToHBService(int callType, SpReqAnsContext<HeartBeatService_CrossTermCall_Req, HeartBeatService_CrossTermCall_Ans>::Pointer ctx)
  682. {
  683. LOG_FUNCTION();
  684. ctx->Answer(Error_Succeed);
  685. return SendToHeartBeatService(ctx->Req,ctx->Ans);
  686. }
  687. void CHeartBeatFSM::DoLocalProcessCrossCallTask(CrossCallReq *reqInfo, const int nBufSize)
  688. {
  689. if (GetTerminalStageState().Compare("A"))
  690. {
  691. Dbg("Terminal havn't been auth suc,forbid cross call.");
  692. return;
  693. }
  694. LocalProcessCrossCallTask *pTask = new LocalProcessCrossCallTask(this, reqInfo, nBufSize);
  695. GetEntityBase()->GetFunction()->PostThreadPoolTask(pTask);
  696. }
  697. int CHeartBeatFSM::LocalProcessCrossCall(CrossCallReq* reqInfo, const int nBufSize)
  698. {
  699. LOG_FUNCTION();
  700. if(reqInfo == NULL) {
  701. return -1;
  702. }
  703. Dbg("entity sn:%x,is RVC.IL:%d,bTwoWay:%d", reqInfo->nEntityID, m_bJBMachine, reqInfo->bTwoWay);
  704. if(m_bJBMachine) { //简版心跳逻辑,那么接收到的应该是回收包
  705. switch(reqInfo->nEntityID) //实体ID
  706. {
  707. case 0x201:
  708. {
  709. ErrorCodeEnum ec = Error_Succeed;
  710. IDCertService_ClientBase* pClient = new IDCertService_ClientBase(GetEntityBase());
  711. ec = pClient->Connect();
  712. if (ec == Error_Succeed) {
  713. IDCertService_CrossTermInvokeInfo_Info info;
  714. info.type = reqInfo->CallType;
  715. info.nEntityID = reqInfo->nEntityID;
  716. info.result = reqInfo->ErrorCode;
  717. SpBuffer spbuf2;
  718. int xSize = nBufSize - FIELD_OFFSET(CrossCallReq, StrParamX);
  719. Dbg("offset %d, %d", FIELD_OFFSET(CrossCallReq, StrParamX), xSize);
  720. bool bBuf = spbuf2.OpenRead((const char*)&(reqInfo->StrParamX[0]), xSize);
  721. if (bBuf) {
  722. Dbg("offset succ.");
  723. if (xSize > 0)
  724. info.paramX = spbuf2.ToBlob();
  725. }
  726. ec = pClient->CrossTermInvokeInfo(info);
  727. Dbg("CrossTermInvokeInfo return %d", ec);
  728. }
  729. else {
  730. Dbg("Connect to IDCertificate failed %d", ec);
  731. }
  732. }
  733. break;
  734. case 0x206://pinpad
  735. {
  736. ErrorCodeEnum ec = Error_Succeed;
  737. PinPadService_ClientBase* pClient = new PinPadService_ClientBase(GetEntityBase());
  738. ec = pClient->Connect();
  739. if (ec == Error_Succeed) {
  740. PinPadService_CrossTermInvokeInfo_Info info;
  741. info.type = reqInfo->CallType;
  742. info.nEntityID = reqInfo->nEntityID;
  743. info.result = reqInfo->ErrorCode;
  744. SpBuffer spbuf2;
  745. int xSize = nBufSize - FIELD_OFFSET(CrossCallReq, StrParamX);
  746. Dbg("offset %d, %d", FIELD_OFFSET(CrossCallReq, StrParamX), xSize);
  747. bool bBuf = spbuf2.OpenRead((const char*)&(reqInfo->StrParamX[0]), xSize);
  748. if (bBuf) {
  749. Dbg("offset succ.");
  750. if (xSize > 0)
  751. info.paramX = spbuf2.ToBlob();
  752. }
  753. ec = pClient->CrossTermInvokeInfo(info);
  754. Dbg("CrossTermInvokeInfo return %d", ec);
  755. }
  756. else {
  757. Dbg("Connect to PinPad failed %d", ec);
  758. }
  759. }
  760. break;
  761. case 0x218:
  762. {
  763. Dbg("Scanner set");
  764. ErrorCodeEnum ec = Error_Succeed;
  765. ScannerService_ClientBase* pClient = new ScannerService_ClientBase(GetEntityBase());
  766. ec = pClient->Connect();
  767. if(ec == Error_Succeed) {
  768. ScannerService_CrossTermInvokeInfo_Info info;
  769. info.type = reqInfo->CallType;
  770. info.nEntityID = reqInfo->nEntityID;
  771. info.result = reqInfo->ErrorCode;
  772. SpBuffer spbuf2;
  773. int size = nBufSize - FIELD_OFFSET(CrossCallReq, StrParamX);
  774. Dbg("offset %d, %d", FIELD_OFFSET(CrossCallReq, StrParamX) , size);
  775. bool bBuf = spbuf2.OpenRead((const char*)&(reqInfo->StrParamX[0]), size);
  776. if(bBuf) {
  777. Dbg("offset succ.");
  778. if(size > 0) {
  779. info.paramX = spbuf2.ToBlob();
  780. }
  781. }
  782. ec = pClient->CrossTermInvokeInfo(info);
  783. Dbg("CrossTermInvokeInfo return %d", ec);
  784. } else {
  785. Dbg("Connect to scanner failed %d", ec);
  786. }
  787. }
  788. break;
  789. case 0x21B:
  790. {
  791. ErrorCodeEnum ec = Error_Succeed;
  792. CardReadAdapterService_ClientBase* pClient = new CardReadAdapterService_ClientBase(GetEntityBase());
  793. ec = pClient->Connect();
  794. if (ec == Error_Succeed) {
  795. CardReadAdapterService_CrossTermInvokeInfo_Info info;
  796. info.type = reqInfo->CallType;
  797. info.nEntityID = reqInfo->nEntityID;
  798. info.result = reqInfo->ErrorCode;
  799. SpBuffer spbuf2;
  800. int xSize = nBufSize - FIELD_OFFSET(CrossCallReq, StrParamX);
  801. Dbg("offset %d, %d", FIELD_OFFSET(CrossCallReq, StrParamX), xSize);
  802. bool bBuf = spbuf2.OpenRead((const char*)&(reqInfo->StrParamX[0]), xSize);
  803. if (bBuf) {
  804. Dbg("offset succ.");
  805. if (xSize > 0)
  806. info.paramX = spbuf2.ToBlob();
  807. }
  808. ec = pClient->CrossTermInvokeInfo(info);
  809. Dbg("CrossTermInvokeInfo return %d", ec);
  810. }
  811. else {
  812. Dbg("Connect to CardReadAdapter failed %d", ec);
  813. }
  814. }
  815. break;
  816. case 0x999:
  817. {
  818. if (reqInfo->numOfBlobInParamX == 1)
  819. {
  820. NotifyIECallResult resultNote;
  821. resultNote.ans_context = reqInfo->StrParamX;
  822. Dbg("oiltest %s", (const char*)resultNote.ans_context.SubString(0, 512));
  823. resultNote.error = reqInfo->ErrorCode;
  824. Dbg("notify result to IE:error %d,len of ans_context %d", resultNote.error, reqInfo->lensOfBlobInParamX[0]);
  825. SpSendBroadcast(GetEntityBase()->GetFunction(), SP_MSG_OF(NotifyIECallResult), SP_MSG_SIG_OF(NotifyIECallResult), resultNote);
  826. }
  827. else
  828. {//oiltest 需要改成按照序号组包
  829. m_tmpMultiBlob += reqInfo->StrParamX;
  830. if (reqInfo->blobSN == reqInfo->numOfBlobInParamX-1)
  831. {
  832. NotifyIECallResult resultNote;
  833. resultNote.ans_context = m_tmpMultiBlob;
  834. if (resultNote.ans_context.GetLength() > 512)
  835. Dbg("oiltest substr %s", (const char*)resultNote.ans_context.SubString(0, 512));
  836. else
  837. Dbg("oiltest %s", (const char*)resultNote.ans_context);
  838. if (resultNote.ans_context.GetLength() > 100)
  839. Dbg("oiltest the last 100 str %s", (const char*)resultNote.ans_context.SubString(resultNote.ans_context.GetLength()-100, 100));
  840. resultNote.error = reqInfo->ErrorCode;
  841. Dbg("notify result to IE:error %d,len of ans_context %d", resultNote.error, resultNote.ans_context.GetLength());
  842. SpSendBroadcast(GetEntityBase()->GetFunction(), SP_MSG_OF(NotifyIECallResult), SP_MSG_SIG_OF(NotifyIECallResult), resultNote);
  843. m_tmpMultiBlob = "";
  844. }
  845. }
  846. }
  847. break;
  848. default:
  849. break;
  850. }
  851. } else { //常规机型,连接适配器
  852. switch(reqInfo->nEntityID) //实体ID
  853. {
  854. case 0x201:
  855. {
  856. ErrorCodeEnum ec = Error_Succeed;
  857. if (m_pIDClient == NULL)
  858. {
  859. Dbg("creat IDCertService_ClientBase client");
  860. m_pIDClient = new IDCertService_ClientBase(GetEntityBase());
  861. }
  862. if (m_pIDClient != NULL)
  863. {
  864. if (m_pIDClient->QuerySessionClosed())
  865. {
  866. m_pIDClient->SafeDelete();
  867. m_pIDClient = new IDCertService_ClientBase(GetEntityBase());
  868. Dbg("to connect to IDCertificate...");
  869. if (m_pIDClient != NULL)
  870. ec = m_pIDClient->Connect();
  871. }
  872. }
  873. if (ec == Error_Succeed) {
  874. IDCertService_CrossTermCall_Req reqX;
  875. IDCertService_CrossTermCall_Ans ansX;
  876. reqX.type = reqInfo->CallType;
  877. //这个应该不用存储
  878. reqX.fromTerminalNo = reqInfo->ToTerminalNo;
  879. reqX.toTerminalNo = reqInfo->FromTerminalNo;
  880. SpBuffer spbuf2;
  881. Dbg("offset %d", FIELD_OFFSET(CrossCallReq, StrParamX));
  882. bool bBuf = spbuf2.OpenRead((const char*)&(reqInfo->StrParamX[0]), nBufSize - FIELD_OFFSET(CrossCallReq, StrParamX) + 1);
  883. if (bBuf) {
  884. reqX.paramX = spbuf2.ToBlob();
  885. }
  886. ec = m_pIDClient->CrossTermCall(reqX, ansX, 20000);
  887. Dbg("local term call ret:%x", ec);
  888. if (reqInfo->bTwoWay)//if one way call, no need to feed back
  889. {
  890. HeartBeatService_CrossTermCall_Req reqY;
  891. HeartBeatService_CrossTermCall_Ans ansY;
  892. reqY.type = reqInfo->CallType;
  893. reqY.nEntityID = reqInfo->nEntityID;
  894. //做返回
  895. ansY.retCode = ec;
  896. reqY.fromTerminalNo = reqInfo->ToTerminalNo;
  897. reqY.toTerminalNo = reqInfo->FromTerminalNo;
  898. reqY.paramX = ansX.retParamX;
  899. //reqY. = ansX.retParamY.m_iLength;//oiltest 暂时用来传递blob长度
  900. Dbg("send pkg to client: %d,Y len:%d", ec, reqY.paramX.m_iLength);
  901. SendToHeartBeatService(reqY, ansY);
  902. }
  903. }
  904. else {
  905. Dbg("Connect to IDCertificate failed %d", ec);
  906. m_pIDClient->SafeDelete();
  907. m_pIDClient = NULL;
  908. }
  909. }
  910. break;
  911. case 0x206://pinpad
  912. {
  913. ErrorCodeEnum ec = Error_Succeed;
  914. if (m_pPinPadClient == NULL)
  915. {
  916. Dbg("creat PinPadService_ClientBase client");
  917. m_pPinPadClient = new PinPadService_ClientBase(GetEntityBase());
  918. }
  919. if (m_pPinPadClient != NULL)
  920. {
  921. if (m_pPinPadClient->QuerySessionClosed())
  922. {
  923. m_pPinPadClient->SafeDelete();
  924. m_pPinPadClient = new PinPadService_ClientBase(GetEntityBase());
  925. Dbg("to connect to PinPad...");
  926. if (m_pPinPadClient != NULL)
  927. ec = m_pPinPadClient->Connect();
  928. }
  929. }
  930. if (ec == Error_Succeed) {
  931. PinPadService_CrossTermCall_Req reqX;
  932. PinPadService_CrossTermCall_Ans ansX;
  933. reqX.type = reqInfo->CallType;
  934. //这个应该不用存储
  935. reqX.fromTerminalNo = reqInfo->ToTerminalNo;
  936. reqX.toTerminalNo = reqInfo->FromTerminalNo;
  937. SpBuffer spbuf2;
  938. Dbg("offset %d", FIELD_OFFSET(CrossCallReq, StrParamX));
  939. bool bBuf = spbuf2.OpenRead((const char*)&(reqInfo->StrParamX[0]), nBufSize - FIELD_OFFSET(CrossCallReq, StrParamX) + 1);
  940. if (bBuf) {
  941. reqX.paramX = spbuf2.ToBlob();
  942. }
  943. ec = m_pPinPadClient->CrossTermCall(reqX, ansX, 20000);
  944. Dbg("local term call ret:%x", ec);
  945. if (reqInfo->bTwoWay)//if one way call, no need to feed back
  946. {
  947. HeartBeatService_CrossTermCall_Req reqY;
  948. HeartBeatService_CrossTermCall_Ans ansY;
  949. reqY.type = reqInfo->CallType;
  950. reqY.nEntityID = reqInfo->nEntityID;
  951. //做返回
  952. ansY.retCode = ec;
  953. reqY.fromTerminalNo = reqInfo->ToTerminalNo;
  954. reqY.toTerminalNo = reqInfo->FromTerminalNo;
  955. reqY.paramX = ansX.retParamX;
  956. //reqY. = ansX.retParamY.m_iLength;//oiltest 暂时用来传递blob长度
  957. Dbg("send pkg to client: %d,Y len:%d", ec, reqY.paramX.m_iLength);
  958. SendToHeartBeatService(reqY, ansY);
  959. }
  960. }
  961. else {
  962. Dbg("Connect to PinPad failed %d", ec);
  963. }
  964. }
  965. break;
  966. case 0x218: // 高拍仪功能集
  967. {
  968. ErrorCodeEnum ec = Error_Succeed;
  969. ScannerService_ClientBase* pClient = new ScannerService_ClientBase(GetEntityBase());
  970. ec = pClient->Connect();
  971. if(ec == Error_Succeed) {
  972. ScannerService_CrossTermCall_Req reqX;
  973. ScannerService_CrossTermCall_Ans ansX;
  974. reqX.type = reqInfo->CallType;
  975. //这个应该不用存储
  976. reqX.fromTerminalNo = reqInfo->ToTerminalNo;
  977. reqX.toTerminalNo = reqInfo->FromTerminalNo;
  978. SpBuffer spbuf2;
  979. Dbg("offset %d", FIELD_OFFSET(CrossCallReq, StrParamX) );
  980. bool bBuf = spbuf2.OpenRead((const char*)&(reqInfo->StrParamX[0]), nBufSize - FIELD_OFFSET(CrossCallReq, StrParamX) + 1 );
  981. if(bBuf) {
  982. reqX.paramX = spbuf2.ToBlob();
  983. }
  984. ec = pClient->CrossTermCall(reqX, ansX, 20000);
  985. Dbg("local term call ret:%x",ec);
  986. if (reqInfo->bTwoWay)//if one way call, no need to feed back
  987. {
  988. HeartBeatService_CrossTermCall_Req reqY;
  989. HeartBeatService_CrossTermCall_Ans ansY;
  990. reqY.type = reqInfo->CallType;
  991. reqY.nEntityID = reqInfo->nEntityID;
  992. //做返回
  993. ansY.retCode = ec;
  994. reqY.fromTerminalNo = reqInfo->ToTerminalNo;
  995. reqY.toTerminalNo = reqInfo->FromTerminalNo;
  996. reqY.paramX = ansY.retParamX;
  997. Dbg("send pkg to client: %d", ec);
  998. SendToHeartBeatService(reqY, ansY);
  999. }
  1000. } else {
  1001. Dbg("Connect to scanner failed %d", ec);
  1002. }
  1003. }
  1004. break;
  1005. case 0x21B:
  1006. {
  1007. ErrorCodeEnum ec = Error_Succeed;
  1008. if (m_pCRAClient == NULL)
  1009. {
  1010. Dbg("creat CardReadAdapterService_ClientBase client");
  1011. m_pCRAClient = new CardReadAdapterService_ClientBase(GetEntityBase());
  1012. }
  1013. if (m_pCRAClient != NULL)
  1014. {
  1015. if (m_pCRAClient->QuerySessionClosed())
  1016. {
  1017. m_pCRAClient = NULL;
  1018. m_pCRAClient = new CardReadAdapterService_ClientBase(GetEntityBase());
  1019. Dbg("to connect to CardReadAdapter");
  1020. ec = m_pCRAClient->Connect();
  1021. }
  1022. }
  1023. if (ec == Error_Succeed) {
  1024. CardReadAdapterService_CrossTermCall_Req reqX;
  1025. CardReadAdapterService_CrossTermCall_Ans ansX;
  1026. reqX.type = reqInfo->CallType;
  1027. //这个应该不用存储
  1028. reqX.fromTerminalNo = reqInfo->ToTerminalNo;
  1029. reqX.toTerminalNo = reqInfo->FromTerminalNo;
  1030. SpBuffer spbuf2;
  1031. Dbg("offset %d", FIELD_OFFSET(CrossCallReq, StrParamX));
  1032. bool bBuf = spbuf2.OpenRead((const char*)&(reqInfo->StrParamX[0]), nBufSize - FIELD_OFFSET(CrossCallReq, StrParamX) + 1);
  1033. if (bBuf) {
  1034. reqX.paramX = spbuf2.ToBlob();
  1035. }
  1036. ec = m_pCRAClient->CrossTermCall(reqX, ansX, 20000);
  1037. Dbg("local term call ret:%x", ec);
  1038. if (reqInfo->bTwoWay)//if one way call, no need to feed back
  1039. {
  1040. HeartBeatService_CrossTermCall_Req reqY;
  1041. HeartBeatService_CrossTermCall_Ans ansY;
  1042. reqY.type = reqInfo->CallType;
  1043. reqY.nEntityID = reqInfo->nEntityID;
  1044. //做返回
  1045. ansY.retCode = ec;
  1046. reqY.fromTerminalNo = reqInfo->ToTerminalNo;
  1047. reqY.toTerminalNo = reqInfo->FromTerminalNo;
  1048. reqY.paramX = ansX.retParamX;
  1049. //reqY. = ansX.retParamY.m_iLength;//oiltest 暂时用来传递blob长度
  1050. Dbg("send pkg to client: %d,X len:%d", ec, reqY.paramX.m_iLength);
  1051. SendToHeartBeatService(reqY, ansY);
  1052. }
  1053. }
  1054. else {
  1055. Dbg("Connect to CardReadAdapter failed %d", ec);
  1056. }
  1057. }
  1058. break;
  1059. case 0x999:
  1060. {
  1061. m_ILDeviceNo = reqInfo->FromTerminalNo;
  1062. Dbg("save il TerminalNo:%s",(const char*)m_ILDeviceNo);
  1063. NotifyIEToCall note;
  1064. note.context = reqInfo->StrParamX;
  1065. Dbg("oiltest %s",(const char*)note.context);
  1066. Dbg("note IE to call:%d", reqInfo->lensOfBlobInParamX[0]);
  1067. SpSendBroadcast(GetEntityBase()->GetFunction(), SP_MSG_OF(NotifyIEToCall), SP_MSG_SIG_OF(NotifyIEToCall), note);
  1068. }
  1069. break;
  1070. default:
  1071. break;
  1072. }
  1073. }
  1074. //TODO: return
  1075. }
  1076. ErrorCodeEnum CHeartBeatFSM::GetPerformCounter(TermianlCounter& counter)
  1077. {
  1078. memset(&counter, 0, sizeof(TermianlCounter));//oiltmp@20210611
  1079. #ifdef RVC_OS_WIN
  1080. //oilyang@20171122 数量太多,暂时去掉
  1081. //LOG_FUNCTION();
  1082. PDH_STATUS Status;
  1083. HQUERY Query = NULL;
  1084. //HCOUNTER hcMemoryCount;
  1085. HCOUNTER hcHandleCount, hcProcessCount, hcThreadCount;
  1086. HCOUNTER hcElapsedTimeCount, hcProcessTimeCount;
  1087. DWORD CounterType;
  1088. MEMORYSTATUSEX statex;
  1089. Status = PdhOpenQuery(NULL, NULL, &Query);
  1090. if (Status != ERROR_SUCCESS)
  1091. {
  1092. Dbg("PdhOpenQuery failed with status 0x%x.", Status);
  1093. goto Cleanup;
  1094. }
  1095. Status = PdhAddCounter(Query, ProcessTimeQuery, NULL, &hcProcessTimeCount);
  1096. if (Status != ERROR_SUCCESS)
  1097. {
  1098. Dbg("PdhAddCounter for ProcessTimeQuery failed with status 0x%x.", Status);
  1099. goto Cleanup;
  1100. }
  1101. Status = PdhAddCounter(Query, HandleNumQuery, NULL, &hcHandleCount);
  1102. if (Status != ERROR_SUCCESS)
  1103. {
  1104. Dbg("PdhAddCounter for HandleNumQuery failed with status 0x%x.", Status);
  1105. goto Cleanup;
  1106. }
  1107. Status = PdhAddCounter(Query, ThreadNumQuery, NULL, &hcThreadCount);
  1108. if (Status != ERROR_SUCCESS)
  1109. {
  1110. Dbg("PdhAddCounter for ThreadNumQuery failed with status 0x%x.", Status);
  1111. goto Cleanup;
  1112. }
  1113. Status = PdhAddCounter(Query, ProcessNumQuery, NULL, &hcProcessCount);
  1114. if (Status != ERROR_SUCCESS)
  1115. {
  1116. Dbg("PdhAddCounter for ProcessNumQuery failed with status 0x%x.", Status);
  1117. goto Cleanup;
  1118. }
  1119. Status = PdhAddCounter(Query, SystemElapsedQuery, NULL, &hcElapsedTimeCount);
  1120. if (Status != ERROR_SUCCESS)
  1121. {
  1122. Dbg("PdhAddCounter for SystemElapsedQuery failed with status 0x%x.", Status);
  1123. goto Cleanup;
  1124. }
  1125. Status = PdhCollectQueryData(Query);
  1126. if (Status != ERROR_SUCCESS)
  1127. {
  1128. Dbg("PdhCollectQueryData failed with 0x%x.\n", Status);
  1129. goto Cleanup;
  1130. }
  1131. do
  1132. {
  1133. Sleep(COUNTER_INTERVAL_MS);
  1134. Status = PdhCollectQueryData(Query);
  1135. if (Status != ERROR_SUCCESS)
  1136. {
  1137. Dbg("PdhCollectQueryData failed with status 0x%x.", Status);
  1138. break;
  1139. }
  1140. memset(&statex, 0, sizeof(MEMORYSTATUSEX));
  1141. statex.dwLength = sizeof(statex);
  1142. if (GlobalMemoryStatusEx(&statex))
  1143. {
  1144. //Dbg("CPUUseRate:%u%%", statex.dwMemoryLoad);
  1145. counter.totalMem = (unsigned short)(statex.ullTotalPhys / DIV);
  1146. //Dbg("TotalPhysMemory:%I64dMB %d", statex.ullTotalPhys / DIV, counter.totalMem);
  1147. counter.freeMem = (unsigned short)(statex.ullAvailPhys / DIV);
  1148. //Dbg("AvailableMemory:%I64dMB %d", statex.ullAvailPhys / DIV, counter.freeMem);
  1149. }
  1150. PDH_FMT_COUNTERVALUE counterValue;
  1151. //Status = PdhGetFormattedCounterValue(hcMemoryCount, PDH_FMT_DOUBLE, NULL, &counterValue);
  1152. //if (Status == ERROR_SUCCESS)
  1153. //{
  1154. // Dbg("AvailableMemory:%.20gMB\n", counterValue.doubleValue);
  1155. //}
  1156. Status = PdhGetFormattedCounterValue(hcProcessTimeCount, PDH_FMT_DOUBLE, &CounterType, &counterValue);
  1157. if (Status == ERROR_SUCCESS)
  1158. {
  1159. counter.cpuLoad = (unsigned short)(counterValue.doubleValue + 0.5);
  1160. //Dbg("CPURate:%d %u", (long)counterValue.doubleValue, counter.cpuLoad);
  1161. }
  1162. Status = PdhGetFormattedCounterValue(hcHandleCount, PDH_FMT_LONG, NULL, &counterValue);
  1163. if (Status == ERROR_SUCCESS)
  1164. {
  1165. counter.handleNum = (unsigned int)(counterValue.longValue);
  1166. //Dbg("HandlesNum:%ld %u", counterValue.longValue, counter.handleNum);
  1167. }
  1168. Status = PdhGetFormattedCounterValue(hcThreadCount, PDH_FMT_LONG, NULL, &counterValue);
  1169. if (Status == ERROR_SUCCESS)
  1170. {
  1171. counter.threadNum = (unsigned short)(counterValue.longValue);
  1172. //Dbg("ThreadsNum:%ld %u", counterValue.longValue, counter.threadNum);
  1173. }
  1174. Status = PdhGetFormattedCounterValue(hcProcessCount, PDH_FMT_LONG, NULL, &counterValue);
  1175. if (Status == ERROR_SUCCESS)
  1176. {
  1177. counter.procNum = (unsigned short)(counterValue.longValue);
  1178. //Dbg("ProcessesNum:%ld %u", counterValue.longValue, counter.procNum);
  1179. }
  1180. Status = PdhGetFormattedCounterValue(hcElapsedTimeCount, PDH_FMT_LARGE, NULL, &counterValue);
  1181. if (Status == ERROR_SUCCESS)
  1182. {
  1183. ULONGLONG ulSinceSeconds = counterValue.largeValue;
  1184. ULONG days = 0, hours = 0, minutes = 0, seconds = 0;
  1185. days = ULONG(ulSinceSeconds / DAY_DIV);
  1186. ulSinceSeconds %= DAY_DIV;
  1187. hours = ULONG(ulSinceSeconds / HOURS_DIV);
  1188. ulSinceSeconds %= HOURS_DIV;
  1189. minutes = ULONG(ulSinceSeconds / MINUS_DIV);
  1190. ulSinceSeconds %= MINUS_DIV;
  1191. seconds = ULONG(ulSinceSeconds);
  1192. //Dbg("SystemElapseTime: %u:%02u:%02u:%02u", days, hours, minutes, seconds);
  1193. FILETIME ftCurTime, ftStartTime;
  1194. GetSystemTimeAsFileTime(&ftCurTime);
  1195. ULARGE_INTEGER uliCurTime;
  1196. uliCurTime.HighPart = ftCurTime.dwHighDateTime;
  1197. uliCurTime.LowPart = ftCurTime.dwLowDateTime;
  1198. uliCurTime.QuadPart -= counterValue.largeValue * 1e7;
  1199. ftStartTime.dwHighDateTime = uliCurTime.HighPart;
  1200. ftStartTime.dwLowDateTime = uliCurTime.LowPart;
  1201. SYSTEMTIME stUTC, stLocal;
  1202. FileTimeToSystemTime(&ftStartTime, &stUTC);
  1203. SystemTimeToTzSpecificLocalTime(NULL, &stUTC, &stLocal);
  1204. sprintf_s(counter.osStartTime, 22, "%d-%02d-%02d %02d:%02d:%02d",
  1205. stLocal.wYear, stLocal.wMonth, stLocal.wDay, stLocal.wHour, stLocal.wMinute, stLocal.wSecond);
  1206. //Dbg("OSStartTime: %s", counter.osStartTime);
  1207. }
  1208. }while(false);
  1209. //Status = PdhRemoveCounter(hcMemoryCount);
  1210. Status = PdhRemoveCounter(hcHandleCount);
  1211. Status = PdhRemoveCounter(hcThreadCount);
  1212. Status = PdhRemoveCounter(hcProcessCount);
  1213. Status = PdhRemoveCounter(hcElapsedTimeCount);
  1214. Cleanup:
  1215. if (Query)
  1216. {
  1217. PdhCloseQuery(Query);
  1218. }
  1219. if(Status != ERROR_SUCCESS)
  1220. {
  1221. switch(Status)
  1222. {
  1223. case PDH_CSTATUS_BAD_COUNTERNAME :
  1224. Dbg("The counter path could not be parsed or interpreted.");
  1225. break;
  1226. case PDH_CSTATUS_NO_COUNTER :
  1227. Dbg("Unable to find the specified counter on the computer or in the log file.");
  1228. break;
  1229. case PDH_CSTATUS_NO_COUNTERNAME :
  1230. Dbg("The counter path is empty.");
  1231. break;
  1232. case PDH_CSTATUS_NO_MACHINE :
  1233. Dbg("The path did not contain a computer name, and function was unable to retrieve local computer name.");
  1234. break;
  1235. case PDH_CSTATUS_NO_OBJECT :
  1236. {
  1237. Dbg("Unable to find the specified object on the computer or in the log file.");
  1238. //CSystemStaticInfo sysInfo;
  1239. //if(GetEntityBase()->GetFunction()->GetSystemStaticInfo(sysInfo) == Error_Succeed)
  1240. //{
  1241. // if(!sysInfo.strMachineType.Compare("RVC.PAD", true))
  1242. // {
  1243. // Dbg("Pad MachineType, abort lodctr operation.");
  1244. // break;
  1245. // }
  1246. //}
  1247. if(!m_nLodCtrFlag || m_nLodCtrFlag == 2)
  1248. {
  1249. LodctrTask* task = new LodctrTask(this);
  1250. GetEntityBase()->GetFunction()->PostThreadPoolTask(task);
  1251. }
  1252. }
  1253. break;
  1254. case PDH_FUNCTION_NOT_FOUND :
  1255. Dbg("Unable to determine the calculation function to use for this counter.");
  1256. break;
  1257. case PDH_INVALID_ARGUMENT :
  1258. Dbg("One or more arguments are not valid.");
  1259. break;
  1260. case PDH_INVALID_HANDLE :
  1261. Dbg("The query handle is not valid.");
  1262. break;
  1263. case PDH_MEMORY_ALLOCATION_FAILURE :
  1264. Dbg("Unable to allocate memory required to complete the function.");
  1265. break;
  1266. default :
  1267. Dbg("Cannot figure the erroCode(0x%08x)(%d) in GetPerformCounter", Status, GetLastError());
  1268. break;
  1269. }
  1270. return Error_Unexpect;
  1271. }
  1272. return Error_Succeed;
  1273. #else
  1274. return Error_Succeed;
  1275. //oiltestlinux
  1276. #endif //RVC_OS_WIN
  1277. }
  1278. int CHeartBeatFSM::SendToHeartBeatService(HeartBeatService_CrossTermCall_Req &req, HeartBeatService_CrossTermCall_Ans &ans)
  1279. {
  1280. LOG_FUNCTION();
  1281. if (m_pHandShakeConn && m_pHandShakeConn->IsConnectionOK())
  1282. {
  1283. m_pHandShakeConn->SendCrossCallToService(req,ans);
  1284. }
  1285. return 0;
  1286. }
  1287. void CHeartBeatFSM::ILCallToRVC(SpOnewayCallContext<HeartBeatService_CallFromILToRVC_Info>::Pointer ctx)
  1288. {
  1289. if (m_pHandShakeConn && m_pHandShakeConn->IsConnectionOK())
  1290. {
  1291. CSimpleStringA csTerm("");
  1292. GetEntityBase()->GetFunction()->GetSysVar("AttachedTerminal", csTerm);
  1293. m_pHandShakeConn->SendILCallToService(ctx->Info.req_context,0,true, m_localDeviceNo,csTerm);
  1294. }
  1295. }
  1296. void CHeartBeatFSM::CallResultToIL(SpOnewayCallContext<HeartBeatService_CallResultToIL_Info>::Pointer ctx)
  1297. {
  1298. if (m_pHandShakeConn && m_pHandShakeConn->IsConnectionOK())
  1299. {
  1300. m_pHandShakeConn->SendILCallToService(ctx->Info.ans_context, ctx->Info.error, false, m_localDeviceNo,m_ILDeviceNo);
  1301. }
  1302. }
  1303. void HeartBeatConnection::OnPkgAnswer(const CSmartPointer<IPackage> &pRecvPkg)
  1304. {
  1305. string serviceCode = pRecvPkg->GetServiceCode();
  1306. if (serviceCode.compare("HANDSHK") == 0 || serviceCode.compare("INSTRUC") == 0)
  1307. {
  1308. PkgRcvProcHandAndInstruc(pRecvPkg);
  1309. }
  1310. else if (serviceCode.compare("CARDACT") == 0)
  1311. {
  1312. PkgRcvProcCardActive(pRecvPkg);
  1313. }
  1314. else if (serviceCode.compare("CRSSACT") == 0)
  1315. {
  1316. PkgRcvProcCrossCall(pRecvPkg);
  1317. }
  1318. else
  1319. {
  1320. Dbg("unknown service code!");
  1321. }
  1322. };
  1323. void HeartBeatConnection::SendHandShake()
  1324. {
  1325. HandReq req = {0};
  1326. //oiltest
  1327. //strcpy(req.TerminalNo,"75500000002");
  1328. //Dbg("get sysvar");
  1329. //oiltest set default value
  1330. CSimpleStringA warningLevel("w"),runState("r"),customerHandle("c"),callState("s"),
  1331. localMaintain("l"),remoteMaintain("m"),termStage("U");
  1332. //m_pEntity->GetFunction()->GetSysVar("WarningLevel",warningLevel);
  1333. strncpy(req.TerminalNo,m_TerminalNo.GetData(),m_TerminalNo.GetLength());
  1334. m_pEntity->GetFunction()->GetSysVar("RunState",runState);
  1335. m_pEntity->GetFunction()->GetSysVar("CustomerHandle",customerHandle);
  1336. m_pEntity->GetFunction()->GetSysVar("CallState",callState);
  1337. //m_pEntity->GetFunction()->GetSysVar("LocalMaintain",localMaintain);
  1338. //m_pEntity->GetFunction()->GetSysVar("RemoteMaintain",remoteMaintain);
  1339. m_pEntity->GetFunction()->GetSysVar("TerminalStage",termStage);
  1340. //Dbg("ts[%s]",(LPCTSTR)termStage);
  1341. //oiltest byteorder
  1342. #ifdef RVC_OS_WIN
  1343. char tmp[256];
  1344. gethostname(tmp, sizeof(tmp));
  1345. hostent *ent = gethostbyname(tmp);
  1346. unsigned long ip = 0xffffffff;
  1347. if (ent) {
  1348. for (int i = 0; ent->h_addr_list[i]; ++i) {
  1349. if (ent->h_addrtype == AF_INET) {
  1350. struct in_addr *in = (struct in_addr*)ent->h_addr_list[i];
  1351. if (in->S_un.S_un_b.s_b1 != 0) {
  1352. if (in->S_un.S_un_b.s_b1 == 192)
  1353. continue;
  1354. ip = (in->S_un.S_un_b.s_b1<<24)+(in->S_un.S_un_b.s_b2<<16)
  1355. +(in->S_un.S_un_b.s_b3<<8)+in->S_un.S_un_b.s_b4;
  1356. break;
  1357. }
  1358. }
  1359. }
  1360. }
  1361. req.ip = ip;
  1362. #else
  1363. //oiltest
  1364. req.ip = 0x0;
  1365. #endif //RVC_OS_WIN
  1366. req.WarningLevel = warningLevel[0];
  1367. req.RunState = runState[0];
  1368. req.CustomerHandle = customerHandle[0];
  1369. req.CallState = callState[0];
  1370. req.LocalMaintain = localMaintain[0];
  1371. req.RemoteMaintain = remoteMaintain[0];
  1372. req.TermStage = termStage[0];
  1373. CSmartPointer<IPackage> pkt = CreateNewPackage("HANDSHK");
  1374. Dbg("sizeof(HandReq):%d",sizeof(HandReq));
  1375. Dbg("sizeof(int):%d", sizeof(int));
  1376. Dbg("sizeof(long):%d", sizeof(long));
  1377. pkt->AddStruct("FNTSTAT", false, false, (LPBYTE)&req, sizeof(HandReq));
  1378. HandErrListReq errListReq;
  1379. errListReq.warnLevel = m_pFSM->GetWarnLevel();
  1380. errListReq.reserved1 = m_pFSM->GetTradeManagerState();
  1381. ZeroMemory(errListReq.errList, 512);
  1382. strncpy(errListReq.errList,m_pFSM->GetEntityErrorList(),m_pFSM->GetEntityErrorList().GetLength());
  1383. pkt->AddStruct("ENTSTAT", false, false, (LPBYTE)&errListReq, sizeof(HandErrListReq));
  1384. // [Josephus in 9:38:25 2016/4/23]
  1385. TermianlCounter counter;
  1386. ErrorCodeEnum erroCode = m_pFSM->GetPerformCounter(counter);
  1387. if(erroCode != Error_Succeed)
  1388. {
  1389. Dbg("Get Terminal Performance Information failed !!!");
  1390. }
  1391. else
  1392. {
  1393. //oilyang@20171122 数量太多,暂时去掉
  1394. //Dbg("Get Terminal Performance Information suc");
  1395. }
  1396. //const char* szIP = m_pFSM->GetRealIP();
  1397. //memset(tmp, 0, sizeof(tmp));
  1398. //strcpy_s(tmp, 256, szIP);
  1399. //Dbg("Calling gethostbyname with %s %s", tmp, szIP);
  1400. //ent = gethostbyname(tmp);
  1401. //ip = 0xffffffff;
  1402. //if (ent == NULL)
  1403. //{
  1404. // DWORD dwError = WSAGetLastError();
  1405. // if (dwError != 0)
  1406. // {
  1407. // if (dwError == WSAHOST_NOT_FOUND)
  1408. // {
  1409. // Dbg("Host not found");
  1410. // } else if (dwError == WSANO_DATA)
  1411. // {
  1412. // Dbg("No data record found");
  1413. // } else
  1414. // {
  1415. // Dbg("Function failed with error: %ld", dwError);
  1416. // }
  1417. // }
  1418. // counter.serverIP = 0xffffffff;
  1419. //}
  1420. //else
  1421. //{
  1422. // //unsigned long ulIP = ((struct in_addr*)ent->h_addr)->S_un.S_addr;
  1423. // for (int i = 0; ent->h_addr_list[i]; ++i)
  1424. // {
  1425. // if (ent->h_addrtype == AF_INET)
  1426. // {
  1427. // struct in_addr *in = (struct in_addr*)ent->h_addr_list[i];
  1428. // if (in->S_un.S_un_b.s_b1 != 0)
  1429. // {
  1430. // if (in->S_un.S_un_b.s_b1 == 192)
  1431. // continue;
  1432. // ip = (in->S_un.S_un_b.s_b1<<24)+(in->S_un.S_un_b.s_b2<<16)
  1433. // +(in->S_un.S_un_b.s_b3<<8)+in->S_un.S_un_b.s_b4;
  1434. // // test for ip with S_addr [Josephus in 11:15:43 2016/4/22]
  1435. // unsigned long ulIP = in->S_un.S_addr;
  1436. // unsigned long ul2IP = inet_addr(tmp);
  1437. // Dbg("joseph-test2: ip=0x%x, ulIp=0x%x, ul2IP=0x%x", ip, ulIP, ul2IP);
  1438. // break;
  1439. // }
  1440. // }
  1441. // }
  1442. //}
  1443. counter.serverIP = m_pFSM->m_dwServIP;
  1444. //Dbg("dwServIP 0x%x", counter.serverIP);
  1445. #ifdef RVC_OS_WIN
  1446. const char* diskPath = m_pFSM->GetRunDiskPath();
  1447. ULARGE_INTEGER uliFreeBytesAvailable;
  1448. if(GetDiskFreeSpaceEx(diskPath, &uliFreeBytesAvailable, NULL, NULL))
  1449. {
  1450. counter.freeDisk = (unsigned int)(uliFreeBytesAvailable.QuadPart / 1024.0 / 1024.0);
  1451. //Dbg("FreeDisk:%.2fMB, %u", uliFreeBytesAvailable.QuadPart / 1024.0 / 1024.0, counter.freeDisk);
  1452. }
  1453. else
  1454. {
  1455. Dbg("GetDiskFreeSpaceEx with %s failed failed 0x%x", diskPath, GetLastError());
  1456. }
  1457. #else
  1458. //oiltestlinux
  1459. counter.freeDisk = 0;
  1460. #endif //RVC_OS_WIN
  1461. pkt->AddStruct("CNTSTAT", false, false, (LPBYTE)&counter, sizeof(TermianlCounter));
  1462. SendPackage(pkt);
  1463. //delete pkt;
  1464. }
  1465. void HeartBeatConnection::SendCardActive(const int type,const int slot,unsigned long errCode,const char *termNo, const char *account, const int accSize, const char *data, const int dataSize,int findCard,int cardPos)
  1466. {
  1467. Dbg("type:%d,errCode:%d,termNo:%s,dataSize:%d", type, errCode, termNo, dataSize);
  1468. //发起跨机调用包
  1469. if (type == 0)
  1470. {
  1471. CardActiveReq req = { 0 };
  1472. CSystemStaticInfo sysSInfo;
  1473. m_pEntity->GetFunction()->GetSystemStaticInfo(sysSInfo);
  1474. req.type = 0;
  1475. req.slot = slot;
  1476. strcpy_s(req.FromTerminalNo, sizeof(req.FromTerminalNo), m_TerminalNo.GetData());
  1477. strcpy_s(req.Account, accSize, account);
  1478. strcpy_s(req.TerminalNo, sizeof(req.TerminalNo), termNo);
  1479. strcpy_s(req.Param2, dataSize, data);
  1480. CSmartPointer<IPackage> pkt = CreateNewPackage("CARDACT");
  1481. pkt->AddStruct("INSREQX", false, false, (LPBYTE)&req, sizeof(CardActiveReq));
  1482. SendPackage(pkt);
  1483. }
  1484. //发送跨机调用返回包
  1485. else if (type == 1)
  1486. {
  1487. CardActiveReq req = { 0 };
  1488. CSystemStaticInfo sysSInfo;
  1489. m_pEntity->GetFunction()->GetSystemStaticInfo(sysSInfo);
  1490. req.type = 1;
  1491. req.ErrCode = errCode;
  1492. req.findCard = findCard;
  1493. req.cardPos = cardPos;
  1494. strcpy_s(req.FromTerminalNo, sizeof(req.FromTerminalNo), m_TerminalNo.GetData());
  1495. strcpy_s(req.Account, accSize, account);
  1496. strcpy_s(req.TerminalNo, sizeof(req.TerminalNo), termNo);
  1497. strcpy_s(req.Param2, dataSize, data);
  1498. CSmartPointer<IPackage> pkt = CreateNewPackage("CARDACT");
  1499. pkt->AddStruct("INSREQX", false, false, (LPBYTE)&req, sizeof(CardActiveReq));
  1500. SendPackage(pkt);
  1501. }
  1502. }
  1503. void HeartBeatConnection::SendCrossCallToService(HeartBeatService_CrossTermCall_Req &req, HeartBeatService_CrossTermCall_Ans &ans)
  1504. {
  1505. LOG_FUNCTION();
  1506. Dbg("from term %s to term %s for entity %x,twoway:%d", (const char*)req.fromTerminalNo, (const char*)req.toTerminalNo, req.nEntityID, req.isTwoWay);
  1507. if (req.paramX.m_iLength > 0)
  1508. {
  1509. //char *pBuf = new char[64 * 1024];
  1510. //ZeroMemory(pBuf, 64 * 1024);
  1511. //HexBuf2StrBuf((PBYTE)req.paramX.m_pData, &pBuf, req.paramX.m_iLength);
  1512. //CSimpleStringA xStr(pBuf);
  1513. //int i = 0;
  1514. //for (; i < req.paramX.m_iLength / 900; i++)
  1515. //{
  1516. // Dbg("%s", xStr.SubString(i * 900, 900));
  1517. //}
  1518. //Dbg("%s", xStr.SubString(i * 900, req.paramX.m_iLength - i * 900));
  1519. }
  1520. int count = req.paramX.m_iLength / (50 * 1000);
  1521. int size = sizeof(CrossCallReq)*(count + 1) + req.paramX.m_iLength + count;
  1522. char* pBuf = new char[size];
  1523. ZeroMemory(pBuf, size);
  1524. CrossCallReq* pReqX = (CrossCallReq*)pBuf;
  1525. for (int i = 0; i < count+1; i++)
  1526. {
  1527. pReqX[i].CallType = req.type;
  1528. pReqX[i].bTwoWay = req.isTwoWay;
  1529. pReqX[i].nEntityID = req.nEntityID;
  1530. pReqX[i].ErrorCode = ans.retCode;
  1531. pReqX[i].lensOfBlobInParamX[0] = req.paramX.m_iLength;
  1532. pReqX[i].numOfBlobInParamX = count+1;
  1533. strcpy_s(pReqX[i].FromTerminalNo, sizeof(pReqX[i].FromTerminalNo),req.fromTerminalNo);
  1534. strcpy_s(pReqX[i].ToTerminalNo, sizeof(pReqX[i].ToTerminalNo), req.toTerminalNo);
  1535. strcpy_s(pReqX[i].StrParam1, sizeof(pReqX[i].StrParam1), req.param1);
  1536. strcpy_s(pReqX[i].StrParam2, sizeof(pReqX[i].StrParam2), req.param2);
  1537. if (i == count)
  1538. memcpy_s(pReqX[i].StrParamX, (req.paramX.m_iLength-50*1000*i), (char*)req.paramX.m_pData+50*1000*i, req.paramX.m_iLength - 50 * 1000 * i);
  1539. else
  1540. memcpy_s(pReqX[i].StrParamX, 50*1000, (char*)req.paramX.m_pData + 50 * 1000 *i, 50 * 1000);
  1541. }
  1542. //memcpy_s(pReqX->StrParamX,req.paramY.GetLength(),req.paramX, req.paramX.GetLength());
  1543. Dbg("from %s to %s,struct X size:%d, len:%d,struct count:%d", pReqX->FromTerminalNo, pReqX->ToTerminalNo, size, req.paramX.m_iLength,count);
  1544. CSmartPointer<IPackage> pkt = CreateNewPackage("CRSSACT");
  1545. pkt->AddStruct("CRSSREQ", false, false, (LPBYTE)pReqX, size,count+1);
  1546. SendPackage(pkt);
  1547. delete [] pBuf;
  1548. }
  1549. void HeartBeatConnection::SendILCallToService(CSimpleStringA csContent, int err, bool bFromIL, CSimpleStringA fromDevNo, CSimpleStringA toDevNo)
  1550. {
  1551. LOG_FUNCTION();
  1552. int count = csContent.GetLength() / (50 * 1000);
  1553. Dbg("count %d,size of content %d",count,csContent.GetLength());
  1554. if (csContent.GetLength() > 32)
  1555. Dbg("the last 32 str %s", (const char*)csContent.SubString(csContent.GetLength()-32,32));
  1556. for (int i = 0; i < count + 1; i++)
  1557. {
  1558. int size;
  1559. if (i == count)
  1560. {
  1561. size = sizeof(CrossCallReq) + csContent.GetLength() - 50*1000*i + 1;
  1562. }
  1563. else
  1564. size = sizeof(CrossCallReq) + 50 * 1000 + 1;
  1565. char* pBuf = new char[size];
  1566. ZeroMemory(pBuf, size);
  1567. Dbg("sz %d", size);
  1568. CrossCallReq* pReqX = (CrossCallReq*)pBuf;
  1569. pReqX->CallType = 999;
  1570. pReqX->bTwoWay = false;
  1571. pReqX->nEntityID = 0x999;
  1572. pReqX->blobSN = i;
  1573. pReqX->lensOfBlobInParamX[0] = csContent.GetLength();//no use 实际用到的时候需要修改这里
  1574. pReqX->numOfBlobInParamX = count + 1;
  1575. if (bFromIL)
  1576. {
  1577. pReqX->ErrorCode = 0;
  1578. }
  1579. else
  1580. {
  1581. pReqX->ErrorCode = err;
  1582. }
  1583. strcpy_s(pReqX->FromTerminalNo,sizeof(pReqX->FromTerminalNo), fromDevNo);
  1584. strcpy_s(pReqX->ToTerminalNo, sizeof(pReqX->ToTerminalNo), toDevNo);
  1585. CSmartPointer<IPackage> pkt = CreateNewPackage("CRSSACT");
  1586. if (i == count)
  1587. {
  1588. memcpy_s(pReqX->StrParamX, csContent.GetLength() - 50 * 1000 * i, (const char*)csContent+50 * 1000 * i, csContent.GetLength() - 50 * 1000 * i);
  1589. Dbg("to add the %d packet from %d",i, csContent.GetLength() - 50 * 1000 * i);
  1590. Dbg("[%d],%d%d%d", strlen(pReqX->StrParamX), pReqX->StrParamX[strlen(pReqX->StrParamX) - 3], pReqX->StrParamX[strlen(pReqX->StrParamX) - 2],pReqX->StrParamX[strlen(pReqX->StrParamX)-1]);
  1591. pkt->AddStruct("CRSSREQ", false, false, (LPBYTE)pReqX, sizeof(CrossCallReq) + csContent.GetLength() - 50 * 1000 * i);
  1592. Dbg("p len:%d", sizeof(CrossCallReq) + csContent.GetLength() - 50 * 1000 * i);
  1593. SendPackage(pkt);
  1594. Dbg("the last of %d",i);
  1595. }
  1596. else
  1597. {
  1598. memcpy_s(pReqX->StrParamX, 50 * 1000, (const char*)csContent + 50 * 1000 * i, 50 * 1000);
  1599. pkt->AddStruct("CRSSREQ", false, false, (LPBYTE)pReqX, sizeof(CrossCallReq)+50*1000);
  1600. Dbg("p len %d:%d,last 3:%d,%d,%d",i, sizeof(CrossCallReq) + 50 * 1000, pReqX->StrParamX[strlen(pReqX->StrParamX) - 3], pReqX->StrParamX[strlen(pReqX->StrParamX) - 2], pReqX->StrParamX[strlen(pReqX->StrParamX) - 1]);
  1601. SendPackage(pkt);
  1602. Dbg("the %d packet",i);
  1603. }
  1604. delete[] pBuf;
  1605. }
  1606. }
  1607. void HeartBeatConnection::PkgRcvProcHandAndInstruc(const CSmartPointer<IPackage> &pRecvPkg)
  1608. {
  1609. int nLen = pRecvPkg->GetStructLen("FNTHAND");
  1610. if (nLen > 0) {
  1611. Dbg("nLen %d", nLen);
  1612. BYTE *pBuf = new BYTE[nLen+1];
  1613. memset(pBuf, 0, nLen+1);
  1614. int nArrayNum = 0;
  1615. if (pRecvPkg->GetStructData("FNTHAND", pBuf, &nLen, &nArrayNum)) {
  1616. Dbg("%s,%d,%d", pBuf, nLen, nArrayNum);
  1617. HandAns* pAns = (HandAns*)pBuf;
  1618. Dbg("hand recv %d events", nArrayNum);
  1619. for (int i = 0; i < nArrayNum; ++i)
  1620. {
  1621. bool bKnownEvent = true;
  1622. DWORD userEvtCode = 0;
  1623. unsigned long ulTmp = (pAns + i)->EventCode;
  1624. Dbg("event %d,param1 %s", ulTmp, (pAns + i)->param1);
  1625. switch (ulTmp)
  1626. {
  1627. case INC_GLOBAL_SETTING_SYNC:
  1628. userEvtCode = LOG_EVT_INC_GLOBAL_SETTING_SYNC;
  1629. break;
  1630. case INC_COMM_RECONNECT:
  1631. userEvtCode = LOG_EVT_INC_COMM_RECONNECT;
  1632. break;
  1633. case INC_START_REMOTE_CONTROL:
  1634. userEvtCode = LOG_EVT_INC_START_REMOTE_CONTROL;
  1635. break;
  1636. case INC_UPDATE_CHECK:
  1637. userEvtCode = LOG_EVT_INC_UPDATE_CHECK;
  1638. break;
  1639. case INC_RECOVER_SERVICE:
  1640. userEvtCode = LOG_EVT_INC_RECOVER_SERVICE;
  1641. break;
  1642. case INC_PAUSE_SERVICE:
  1643. userEvtCode = LOG_EVT_INC_PAUSE_SERVICE;
  1644. break;
  1645. case INC_AREA_SERVICE_SWITCH:
  1646. userEvtCode = LOG_EVT_INC_AREA_SERVICE_SWITCH;
  1647. break;
  1648. case INC_VERSION_ROLLBACK:
  1649. userEvtCode = LOG_EVT_INC_VERSION_ROLLBACK;
  1650. break;
  1651. case INC_BRIDGE:
  1652. userEvtCode = LOG_EVT_INC_BRIDGE;
  1653. break;
  1654. case INC_VEDIO_CONNECTING:
  1655. userEvtCode = LOG_EVT_INC_VEDIO_CONNECTING;
  1656. break;
  1657. case INC_TRADE_MANAGER_NORMAL:
  1658. userEvtCode = LOG_EVT_INC_TRADE_MANAGER_NORMAL;
  1659. break;
  1660. case INC_TRADE_MANAGER_ON:
  1661. userEvtCode = LOG_EVT_INC_TRADE_MANAGER_ON;
  1662. break;
  1663. case INC_TRADE_MANAGER_OFF:
  1664. userEvtCode = LOG_EVT_INC_TRADE_MANAGER_OFF;
  1665. break;
  1666. case INC_DEVICE_LOCK_ON:
  1667. userEvtCode = LOG_EVT_INC_DEVICE_LOCK_ON;
  1668. break;
  1669. case INC_DEVICE_UNLOCK:
  1670. userEvtCode = LOG_EVT_INC_DEVICE_UNLOCK;
  1671. break;
  1672. case INC_DEVICE_KICK_OFF:
  1673. userEvtCode = LOG_EVT_INC_DEVICE_KICK_OFF;
  1674. break;
  1675. default:
  1676. bKnownEvent = false;
  1677. Dbg("unknown ins %d", ulTmp);
  1678. break;
  1679. }
  1680. if (bKnownEvent)
  1681. {
  1682. LogEvent(Severity_Middle, userEvtCode, (pAns + i)->param1);
  1683. }
  1684. }
  1685. }
  1686. else {
  1687. Dbg("invalid handshakeans packet!");
  1688. //OnDisconnect();
  1689. }
  1690. delete pBuf;
  1691. }
  1692. }
  1693. void HeartBeatConnection::PkgRcvProcCardActive(const CSmartPointer<IPackage> &pRecvPkg)
  1694. {
  1695. LOG_FUNCTION();
  1696. int nLen = pRecvPkg->GetStructLen("INSREQX");
  1697. if (nLen > 0) {
  1698. Dbg("nLen %d", nLen);
  1699. BYTE *pBuf = new BYTE[nLen+1];
  1700. memset(pBuf, 0, nLen+1);
  1701. int nArrayNum = 0;
  1702. if (pRecvPkg->GetStructData("INSREQX", pBuf, &nLen, &nArrayNum)) {
  1703. Dbg("%s,%d,%d", pBuf, nLen, nArrayNum);
  1704. CardActiveReq* pAns = (CardActiveReq*)pBuf;
  1705. //Dbg("hand recv %d events", nArrayNum);
  1706. //for (int i = 0; i < nArrayNum; ++i)
  1707. if (nArrayNum > 0)
  1708. {
  1709. Dbg("type %d,from term:%s,term %s,acc(len):%d,param1(len) %d", pAns->type, pAns->FromTerminalNo, pAns->TerminalNo
  1710. , strlen(pAns->Account), strlen(pAns->Param2));
  1711. //Dbg("type %d,from term:%s,term %s,acc:%s,param1 %s", pAns->type, pAns->FromTerminalNo,pAns->TerminalNo, pAns->Account, pAns->Param2);
  1712. Dbg("findCard %d,cardPos %d", pAns->findCard, pAns->cardPos);
  1713. if (pAns->type == 0)
  1714. m_pFSM->LocalPreOnline(pAns->slot, pAns->TerminalNo, pAns->FromTerminalNo, pAns->Account, pAns->Param2);
  1715. else if (pAns->type == 1)
  1716. m_pFSM->ReceivePreOnlineBack(pAns->ErrCode, pAns->Param2, pAns->findCard, pAns->cardPos);
  1717. }
  1718. }
  1719. else {
  1720. Dbg("invalid insreqx packet!");
  1721. }
  1722. delete pBuf;
  1723. }
  1724. }
  1725. void HeartBeatConnection::PkgRcvProcCrossCall(const CSmartPointer<IPackage> &pRecvPkg)
  1726. {
  1727. LOG_FUNCTION();
  1728. int nLen = pRecvPkg->GetStructLen("CRSSREQ");
  1729. Dbg("nLen: %d", nLen);
  1730. if (nLen > 0) {
  1731. BYTE *pBuf = new BYTE[nLen+1];
  1732. ZeroMemory(pBuf,nLen+1);
  1733. int nArrayNum = 0;
  1734. if (pRecvPkg->GetStructData("CRSSREQ", pBuf, &nLen, &nArrayNum)) {
  1735. Dbg("%d,array num:%d,last 3:%d,%d,%d", nLen, nArrayNum,pBuf[nLen-3], pBuf[nLen - 2], pBuf[nLen - 1]);
  1736. CrossCallReq* pAnsArray = (CrossCallReq*)pBuf;
  1737. Dbg("%x", ((CrossCallReq*)pBuf)->nEntityID);
  1738. Dbg("num %x", ((CrossCallReq*)pBuf)->numOfBlobInParamX);
  1739. int tmpXLen = 0;
  1740. for (int i = 0; i < nArrayNum; ++i)
  1741. {
  1742. tmpXLen += strlen(pAnsArray[i].StrParamX);
  1743. }
  1744. tmpXLen += (sizeof(CrossCallReq)*nArrayNum);
  1745. Dbg("tmpXLen:%d", tmpXLen);
  1746. BYTE *pAnsBuf = new BYTE[tmpXLen + 1];
  1747. ZeroMemory(pAnsBuf, tmpXLen + 1);
  1748. memcpy_s(pAnsBuf, tmpXLen+1, pBuf, tmpXLen);
  1749. CrossCallReq* pAns = (CrossCallReq*)pAnsBuf;
  1750. pAns->Appendix1 = pAnsArray->Appendix1;
  1751. pAns->Appendix2 = pAnsArray->Appendix2;
  1752. pAns->bTwoWay = pAnsArray->bTwoWay;
  1753. pAns->CallType = pAnsArray->CallType;
  1754. pAns->ErrorCode = pAnsArray->ErrorCode;
  1755. pAns->nEntityID = pAnsArray->nEntityID;
  1756. pAns->numOfBlobInParamX = pAnsArray->numOfBlobInParamX;
  1757. for (int i = 0; i < sizeof(pAns->lensOfBlobInParamX); i++)
  1758. pAns->lensOfBlobInParamX[i] = pAnsArray->lensOfBlobInParamX[i];
  1759. strcpy_s(pAns->FromTerminalNo, sizeof(pAns->FromTerminalNo), pAnsArray->FromTerminalNo);
  1760. strcpy_s(pAns->StrParam1, sizeof(pAns->StrParam1), pAnsArray->StrParam1);
  1761. strcpy_s(pAns->StrParam2, sizeof(pAns->StrParam2), pAnsArray->StrParam2);
  1762. strcpy_s(pAns->ToTerminalNo, sizeof(pAns->ToTerminalNo), pAnsArray->ToTerminalNo);
  1763. Dbg("%x",pAns->nEntityID);
  1764. for (int i = 0, start = 0; i < nArrayNum; ++i)
  1765. {
  1766. strcpy_s(pAns->StrParamX + start, tmpXLen - start, pAnsArray[i].StrParamX);
  1767. start += strlen(pAnsArray[i].StrParamX);
  1768. }
  1769. Dbg("type:%x,from %s,to %s", pAns->CallType, pAns->FromTerminalNo, pAns->ToTerminalNo);
  1770. Dbg("nEntityID: %x", pAns->nEntityID);
  1771. Dbg("appendix1: %d", pAns->Appendix1);
  1772. Dbg("bTwoWay:[%d]", pAns->bTwoWay);
  1773. Dbg("blobSN:[%d]", pAns->blobSN);
  1774. Dbg("param2:[%s]", pAns->StrParam2);
  1775. Dbg("param3:[%d]", pAns->Appendix2);//oiltest
  1776. Dbg("ErrorCode:[%x]", pAns->ErrorCode);//oiltest
  1777. //Dbg("paramX:[%s]", pAns->StrParamX);
  1778. //if (pAns->Appendix2 > 0)
  1779. //{
  1780. // char *pBuf = new char[64 * 1024];
  1781. // ZeroMemory(pBuf, 64 * 1024);
  1782. // HexBuf2StrBuf((PBYTE)pAns->StrParamX, &pBuf, pAns->Appendix2);
  1783. // CSimpleStringA xStr(pBuf);
  1784. // int i = 0;
  1785. // for (; i < pAns->Appendix2 / 900; i++)
  1786. // {
  1787. // Dbg("%s", xStr.SubString(i * 900, 900));
  1788. // }
  1789. // Dbg("%s", xStr.SubString(i * 900, pAns->Appendix2 - i * 900));
  1790. //}
  1791. m_pFSM->DoLocalProcessCrossCallTask(pAns, nLen);
  1792. }
  1793. else {
  1794. Dbg("invalid CRSSREQ packet!");
  1795. }
  1796. delete pBuf;
  1797. }
  1798. }