IDCertFSM.h 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435
  1. #ifndef IDCERTFSM_H
  2. #define IDCERTFSM_H
  3. #pragma once
  4. #include "SpFSM.h"
  5. #ifdef RVC_OS_LINUX
  6. #include "SpTest.h"
  7. #else //windows
  8. #include "json/json.h"
  9. #include <xstring>
  10. #include "IHttpFunc.h"
  11. #endif
  12. #include <unordered_map>
  13. #include "DevFSMCommBase.hpp"
  14. #ifdef RVC_OS_WIN
  15. #define REFLECTION(var) #var
  16. typedef struct ImgCheckReq : CHTTPReq {
  17. string terminalNo;
  18. string name;
  19. string idNo;
  20. string nationality;
  21. string idType;
  22. string imageBase64;
  23. string fspId;
  24. int topN;
  25. int returnImgBase64;
  26. string ToJson() {
  27. Json::Value value;
  28. value[REFLECTION(terminalNo)] = terminalNo;
  29. value[REFLECTION(name)] = name;
  30. value[REFLECTION(idNo)] = idNo;
  31. value[REFLECTION(nationality)] = nationality;
  32. value[REFLECTION(idType)] = idType;
  33. value[REFLECTION(imageBase64)] = imageBase64;
  34. value[REFLECTION(fspId)] = fspId;
  35. value[REFLECTION(topN)] = topN;
  36. value[REFLECTION(returnImgBase64)] = returnImgBase64;
  37. Json::FastWriter writer;
  38. string strData = writer.write(value);
  39. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("ImgCheckReq")
  40. ("req=%s at ImgCheckReq", strData.c_str());
  41. return strData;
  42. }
  43. } ImgCheckReq;
  44. typedef struct ImgCheckRet : CHTTPRet {
  45. bool m_success;
  46. bool Parse(string strData) {
  47. Dbg("ImgCheckRet = %s", strData.c_str());
  48. Json::Value root;
  49. Json::Reader reader;
  50. reader.parse(strData, root, false);
  51. if (root["success"].isBool()) {
  52. m_success = root["success"].asBool();
  53. }
  54. else
  55. {
  56. m_success = false;
  57. }
  58. return true;
  59. }
  60. } ImgCheckRet;
  61. #endif
  62. enum EvtType
  63. {
  64. USER_EVT_TEST = EVT_USER + 1,
  65. USER_EVT_QUIT,
  66. USER_EVT_CANCEL_READ,
  67. USER_EVT_EXIT,
  68. USER_EVT_GET_DEVINFO,
  69. USER_EVT_ERROR,
  70. USER_EVT_EJECT,
  71. USER_EVT_WAIT_FETCH_IDCARD_FINISHED,
  72. USER_EVT_READ_AND_SCAN,
  73. USER_EVT_READ_AND_SCAN_FINISHED,
  74. USER_EVT_INIT_FINISHED,
  75. USER_EVT_TODO_INIT,
  76. USER_EVT_TODO_INIT_FINISHED,
  77. USER_EVT_READ_AND_SCAN_UTF8, //ex1
  78. USER_EVT_READ_AND_SCAN_UTF8_FINISHED,
  79. };
  80. enum BmpType
  81. {
  82. Bmp_ZP = 1,
  83. Bmp_SCAN = 2,
  84. };
  85. #include "IDCerClass.h"
  86. #include "IDCertificate_def_g.h"
  87. #pragma region forsonar
  88. typedef IDCertificate::IDCertService_CancelRead_Info IDCert_CancelRead_Info;
  89. typedef IDCertificate::IDCertService_ReadWaitMore_Info IDCert_ReadWaitMore_Info;
  90. typedef IDCertificate::IDCertService_Exit_Info IDCert_Exit_Info;
  91. typedef IDCertificate::IDCertService_Eject_Req IDCert_Eject_Req;
  92. typedef IDCertificate::IDCertService_Eject_Ans IDCert_Eject_Ans;
  93. typedef IDCertificate::IDCertService_ReadAndScan_Req IDCert_ReadAndScan_Req;
  94. typedef IDCertificate::IDCertService_ReadAndScan_Ans IDCert_ReadAndScan_Ans;
  95. typedef IDCertificate::IDCertService_ReadAndScanUTF8_Req IDCert_ReadAndScanUTF8_Req; //ex2
  96. typedef IDCertificate::IDCertService_ReadAndScanUTF8_Ans IDCert_ReadAndScanUTF8_Ans;
  97. typedef IDCertificate::IDCertService_GetDevInfo_Req IDCert_GetDevInfo_Req;
  98. typedef IDCertificate::IDCertService_GetDevInfo_Ans IDCert_GetDevInfo_Ans;
  99. #pragma endregion forsonar
  100. #include <map>
  101. using namespace std;
  102. typedef ErrorCodeEnum ( *lpCreateDevCom)(DeviceBaseClass *&baseObj);
  103. typedef ErrorCodeEnum ( *lpReleaseDevCom)(DeviceBaseClass *&pBaseObj);
  104. struct CtxInfo
  105. {
  106. int dataSize;
  107. LPVOID pCtx;
  108. };
  109. class CancelReadEvent : public FSMEvent
  110. {
  111. public:
  112. CancelReadEvent() : FSMEvent(USER_EVT_CANCEL_READ){}
  113. virtual ~CancelReadEvent(){}
  114. virtual void OnUnhandled()
  115. {
  116. LOG_TRACE("idcer cancel read not handled");
  117. }
  118. };
  119. class GetDevInfoEvent : public FSMEvent
  120. {
  121. public:
  122. GetDevInfoEvent() : FSMEvent(USER_EVT_GET_DEVINFO){}
  123. virtual ~GetDevInfoEvent(){}
  124. SpReqAnsContext<IDCert_GetDevInfo_Req, IDCert_GetDevInfo_Ans>::Pointer ctx;
  125. virtual void OnUnhandled()
  126. {
  127. if (ctx != NULL)
  128. ctx->Answer(Error_InvalidState);
  129. }
  130. };
  131. class EjectEvent : public FSMEvent
  132. {
  133. public:
  134. EjectEvent() : FSMEvent(USER_EVT_EJECT){}
  135. virtual ~EjectEvent(){}
  136. SpReqAnsContext<IDCert_Eject_Req, IDCert_Eject_Ans>::Pointer ctx;
  137. virtual void OnUnhandled()
  138. {
  139. if (ctx != NULL)
  140. ctx->Answer(Error_InvalidState);
  141. }
  142. };
  143. class ReadAndScanEvent : public FSMEvent
  144. {
  145. public:
  146. ReadAndScanEvent() : FSMEvent(USER_EVT_READ_AND_SCAN) {}
  147. virtual ~ReadAndScanEvent() {}
  148. SpReqAnsContext<IDCert_ReadAndScan_Req, IDCert_ReadAndScan_Ans>::Pointer ctx;
  149. virtual void OnUnhandled()
  150. {
  151. if (ctx != NULL)
  152. ctx->Answer(Error_InvalidState);
  153. }
  154. };
  155. class ReadAndScanUTF8Event : public FSMEvent //ex3
  156. {
  157. public:
  158. ReadAndScanUTF8Event() : FSMEvent(USER_EVT_READ_AND_SCAN_UTF8) {}
  159. virtual ~ReadAndScanUTF8Event() {}
  160. SpReqAnsContext<IDCert_ReadAndScanUTF8_Req, IDCert_ReadAndScanUTF8_Ans>::Pointer ctx;
  161. virtual void OnUnhandled()
  162. {
  163. if (ctx != NULL)
  164. ctx->Answer(Error_InvalidState);
  165. }
  166. };
  167. class CIDCertFSM : public CCommDevFSM<CIDCertFSM, IDCerClass>
  168. {
  169. public:
  170. enum {s0,s1,s2,s3,s4,s5};
  171. BEGIN_FSM_STATE(CIDCertFSM)
  172. FSM_STATE_ENTRY(s0,"Normal",s0_on_entry,s0_on_exit,s0_on_event)
  173. FSM_STATE_ENTRY(s1,"Reading",s1_on_entry,s1_on_exit,s1_on_event)
  174. FSM_STATE_ENTRY(s2,"Fail",s2_on_entry,s2_on_exit,s2_on_event)
  175. FSM_STATE_ENTRY(s3, "Eject", s3_on_entry, s3_on_exit, s3_on_event)
  176. FSM_STATE_ENTRY(s4, "WaitingFetch", s4_on_entry, s4_on_exit, s4_on_event)
  177. FSM_STATE_ENTRY(s5, "Init", s5_on_entry, s5_on_exit, s5_on_event)
  178. END_FSM_STATE()
  179. BEGIN_FSM_RULE(CIDCertFSM, s5)
  180. FSM_RULE_ENTRY(s0, s2, USER_EVT_ERROR, 0)
  181. FSM_RULE_ENTRY(s0, FSM_STATE_EXIT, USER_EVT_QUIT, 0)
  182. FSM_RULE_ENTRY(s0, s1, USER_EVT_READ_AND_SCAN, 0)
  183. FSM_RULE_ENTRY(s0, s1, USER_EVT_READ_AND_SCAN_UTF8, 0) //ex4
  184. FSM_RULE_ENTRY(s0, s5, USER_EVT_TODO_INIT_FINISHED, 0)
  185. FSM_RULE_ENTRY(s1, s0, USER_EVT_READ_AND_SCAN_FINISHED, 0)
  186. FSM_RULE_ENTRY(s1, s2, USER_EVT_READ_AND_SCAN_FINISHED, 1)
  187. FSM_RULE_ENTRY(s1, s0, USER_EVT_READ_AND_SCAN_FINISHED, 2)
  188. FSM_RULE_ENTRY(s1, s0, USER_EVT_READ_AND_SCAN_FINISHED, 3)
  189. FSM_RULE_ENTRY(s1, s4, USER_EVT_READ_AND_SCAN_FINISHED, 4)
  190. FSM_RULE_ENTRY(s1, s5, USER_EVT_READ_AND_SCAN_FINISHED, 5)
  191. FSM_RULE_ENTRY(s1, s0, USER_EVT_READ_AND_SCAN_UTF8_FINISHED, 0)
  192. FSM_RULE_ENTRY(s1, s2, USER_EVT_READ_AND_SCAN_UTF8_FINISHED, 1)
  193. FSM_RULE_ENTRY(s1, s0, USER_EVT_READ_AND_SCAN_UTF8_FINISHED, 2)
  194. FSM_RULE_ENTRY(s1, s0, USER_EVT_READ_AND_SCAN_UTF8_FINISHED, 3)
  195. FSM_RULE_ENTRY(s1, s4, USER_EVT_READ_AND_SCAN_UTF8_FINISHED, 4)
  196. FSM_RULE_ENTRY(s1, s5, USER_EVT_READ_AND_SCAN_UTF8_FINISHED, 5)
  197. FSM_RULE_ENTRY(s1, FSM_STATE_EXIT, USER_EVT_QUIT, 0)
  198. FSM_RULE_ENTRY(s1, s0, USER_EVT_CANCEL_READ, 2)
  199. FSM_RULE_ENTRY(s1, s0, USER_EVT_EXIT, 3)
  200. FSM_RULE_ENTRY(s2, s5, USER_EVT_TODO_INIT_FINISHED, 0)
  201. FSM_RULE_ENTRY(s4, s0, USER_EVT_WAIT_FETCH_IDCARD_FINISHED, 0)
  202. FSM_RULE_ENTRY(s5, s0, USER_EVT_INIT_FINISHED, 0)
  203. FSM_RULE_ENTRY(s5, s2, USER_EVT_INIT_FINISHED, 2)
  204. END_FSM_RULE()
  205. #ifdef RVC_OS_LINUX
  206. CIDCertFSM() :m_devInit(false), m_bCancelRead(false), m_bReading(false), m_bWaitReadMore(false),
  207. m_bExit(false), m_testResult(Error_Succeed), m_csMachineType(""), m_csSite(""), m_terminalNo(""), m_devSN("")
  208. , m_devVendor(""), m_devVer(""), m_devBatch(""), m_bRVCIL(false){
  209. HARDWARE_ENTITY_RESET_ENTITYID(m_entCode, 0x201);
  210. m_FirstStart = TRUE;
  211. ZeroMemory(&m_adapterInfo, sizeof(m_adapterInfo));
  212. };
  213. #else
  214. CIDCertFSM():m_bCancelRead(false),m_bReading(false),m_bWaitReadMore(false),
  215. m_bExit(false),m_testResult(Error_Succeed), m_csMachineType(""), m_csSite(""), m_terminalNo("")
  216. ,m_devVendor(""), m_devVer(""), m_devBatch(""), invalidBreak(false), m_logBefore(false), transImgMsg("")
  217. {
  218. HARDWARE_ENTITY_RESET_ENTITYID(m_entCode, 0x201);
  219. };
  220. #endif // RVC_OS_LINUX
  221. virtual ~CIDCertFSM() {};
  222. virtual ErrorCodeEnum OnInit();
  223. virtual ErrorCodeEnum OnExit();
  224. virtual void s0_on_entry();
  225. virtual void s0_on_exit();
  226. virtual unsigned int s0_on_event(FSMEvent* e);
  227. virtual void s1_on_entry();
  228. virtual void s1_on_exit();
  229. virtual unsigned int s1_on_event(FSMEvent* e);
  230. virtual void s2_on_entry();
  231. virtual void s2_on_exit();
  232. virtual unsigned int s2_on_event(FSMEvent* e);
  233. virtual void s3_on_entry();
  234. virtual void s3_on_exit();
  235. virtual unsigned int s3_on_event(FSMEvent* e);
  236. virtual void s4_on_entry();
  237. virtual void s4_on_exit();
  238. virtual unsigned int s4_on_event(FSMEvent* e);
  239. virtual void s5_on_entry();
  240. virtual void s5_on_exit();
  241. virtual unsigned int s5_on_event(FSMEvent* e);
  242. int ReadAndScan(SpReqAnsContext<IDCert_ReadAndScan_Req, IDCert_ReadAndScan_Ans>::Pointer ctx);
  243. int ReadAndScanUTF8(SpReqAnsContext<IDCert_ReadAndScanUTF8_Req, IDCert_ReadAndScanUTF8_Ans>::Pointer ctx);
  244. int WaitFetchIDCard();
  245. void SetReadMore(){m_bWaitReadMore = true;}
  246. void SetExitFlag(){m_bExit = true;}
  247. bool GetReadFlag(){return m_bReading;}
  248. ErrorCodeEnum GetDevCatInfo(DevCategoryInfo &devInfo, CSimpleStringA& devType);
  249. void GetDevState(DevStateEnum &devState){ devState = m_devState; }
  250. void DoExit(CSmartPointer<ITransactionContext> pTransactionContext)
  251. {
  252. pTransactionContext->SendAnswer(Error_Succeed);
  253. }
  254. #ifdef RVC_OS_WIN
  255. bool GetDevInitFlag() { return m_bOpened; }
  256. void ResetDevInitFlag() { m_bOpened = false; }
  257. #else
  258. bool GetDevInitFlag() { return m_devInit; }
  259. #endif
  260. template <class TReq,class TAns>
  261. void SaveCtx(int methodID, CSmartPointer<SpReqAnsContext<TReq, TAns> > ctx)
  262. {
  263. m_mapCtx[methodID].pCtx = static_cast<void*>(ctx.GetRawPointer());
  264. }
  265. void SaveCtxAA(int methodID, SpReqAnsContext<IDCert_ReadAndScan_Req, IDCert_ReadAndScan_Ans>::Pointer ctx)
  266. {
  267. m_readAndScanCtx = ctx;
  268. }
  269. void SaveCtxAAEx(int methodID, SpReqAnsContext<IDCert_ReadAndScanUTF8_Req, IDCert_ReadAndScanUTF8_Ans>::Pointer ctx)//UTF8
  270. {
  271. m_readAndScanUTF8Ctx = ctx;
  272. }
  273. LPVOID GetCtx(int methodID)
  274. {
  275. if (m_mapCtx.find(methodID) != m_mapCtx.end())
  276. return m_mapCtx[methodID].pCtx;
  277. else
  278. return NULL;
  279. }
  280. int Initial();
  281. void SelfTest(EntityTestEnum eTestType,CSmartPointer<ITransactionContext> pTransactionContext);
  282. int ProcFWBReConn();
  283. bool IsRVCPAD() { return !m_csMachineType.Compare("RVC.PAD", true); }
  284. static void HttpsLogCallBack(const char* logtxt);
  285. private:
  286. ErrorCodeEnum GetVendorDllPath(CSimpleStringA &strPath);
  287. ErrorCodeEnum GetPngBlob(CBlob &data,bool bClear=false);
  288. ErrorCodeEnum GetPngBlobEx(CBlob &data, CSimpleStringA fileNamePrefix,bool bClear=false);
  289. //type:1,delete img about zp; type:2,delete img about scan ID;type:3,delete both zp and scan ID
  290. void DeleteZP(int type);
  291. ErrorCodeEnum CheckDate(const char* date);
  292. ErrorCodeEnum CheckDate(const char* startDate, const char* endDate);
  293. void LogDate(IDCerInfo idInfo);
  294. void LogDateEx(IDCerInfoEx idInfo);
  295. //Delete bmp file in dep directory, you should just convey fileName only without paths -Joseph
  296. ErrorCodeEnum DeleteFileIfExisted(LPCTSTR fileName);
  297. #ifdef RVC_OS_LINUX
  298. bool GetAttachedTerminal(CSimpleStringA& csTerm);
  299. #else
  300. void ToLogWarnInfoAboutTermCustom();
  301. #endif // RVC_OS_LINUX
  302. BOOL UCS2_to_UTF8(UINT16* ucs2_code, UINT8* utf8_code);
  303. BOOL GetSexUTF8String(UINT16* in, UINT8* out);
  304. BOOL GetNationalUTF8String(UINT16* in, UINT8* out);
  305. BOOL GetDateStandardFormatUTF8(UINT16* in, UINT8* out);
  306. BOOL RemoveUCS2Blank(UINT16* ucs2_code);
  307. void CheckHanZi(UINT16* ucs2_code);
  308. private:
  309. #ifdef RVC_OS_LINUX
  310. bool m_devInit, m_bRVCIL;
  311. #endif
  312. bool m_bCancelRead, m_bReading, m_bWaitReadMore, m_bExit;
  313. ErrorCodeEnum m_testResult;
  314. DevCategoryInfo m_devCatInfo;
  315. DevStateEnum m_devState;
  316. CSimpleStringA m_csMachineType, m_csSite, m_terminalNo;
  317. CSimpleStringA m_devVendor, m_devVer, m_devBatch, m_devSN/*fwb SN*/;
  318. CSimpleStringA transImgMsg;
  319. map<int, CtxInfo> m_mapCtx;
  320. SpReqAnsContext<IDCert_ReadAndScan_Req, IDCert_ReadAndScan_Ans>::Pointer m_readAndScanCtx;
  321. SpReqAnsContext<IDCert_ReadAndScanUTF8_Req, IDCert_ReadAndScanUTF8_Ans>::Pointer m_readAndScanUTF8Ctx; //ex7
  322. #ifdef RVC_OS_WIN
  323. unordered_map<int, wstring> nationalCode;
  324. #else
  325. unordered_map<int, string> nationalCode;
  326. #endif
  327. BOOL supportUCS2; //Ö§³ÖÉúƧ×Ö
  328. BOOL igestionVer; //ÎüÈëʽÉ豸
  329. CSimpleStringA m_csAlarmMsg;
  330. bool invalidBreak;
  331. bool m_logBefore;
  332. ULLINT m_ullBeginTime, m_ullEndTime;
  333. };
  334. struct ReadAndScanTask : public ITaskSp
  335. {
  336. CIDCertFSM* fsm;
  337. SpReqAnsContext<IDCert_ReadAndScan_Req, IDCert_ReadAndScan_Ans>::Pointer ctx;
  338. ReadAndScanTask(CIDCertFSM* f) : fsm(f) {}
  339. void Process()
  340. {
  341. FSMEvent *e = new FSMEvent(USER_EVT_READ_AND_SCAN_FINISHED);
  342. e->param1 = -1;
  343. e->param1 = fsm->ReadAndScan(ctx);
  344. fsm->PostEventFIFO(e);
  345. }
  346. };
  347. struct ReadAndScanUTF8Task : public ITaskSp //ex8
  348. {
  349. CIDCertFSM* fsm;
  350. SpReqAnsContext<IDCert_ReadAndScanUTF8_Req, IDCert_ReadAndScanUTF8_Ans>::Pointer ctx;
  351. ReadAndScanUTF8Task(CIDCertFSM* f) : fsm(f) {}
  352. void Process()
  353. {
  354. FSMEvent* e = new FSMEvent(USER_EVT_READ_AND_SCAN_UTF8_FINISHED);
  355. e->param1 = -1;
  356. e->param1 = fsm->ReadAndScanUTF8(ctx);
  357. fsm->PostEventFIFO(e);
  358. }
  359. };
  360. struct WaitFetchIDCardTask : public ITaskSp
  361. {
  362. CIDCertFSM* fsm;
  363. WaitFetchIDCardTask(CIDCertFSM* f) : fsm(f) {}
  364. void Process()
  365. {
  366. FSMEvent *e = new FSMEvent(USER_EVT_WAIT_FETCH_IDCARD_FINISHED);
  367. e->param1 = fsm->WaitFetchIDCard();
  368. fsm->PostEventFIFO(e);
  369. }
  370. };
  371. struct InitTask : public ITaskSp
  372. {
  373. CIDCertFSM* fsm;
  374. InitTask(CIDCertFSM* f) : fsm(f) {}
  375. void Process()
  376. {
  377. FSMEvent* e = new FSMEvent(USER_EVT_INIT_FINISHED);
  378. e->param1 = fsm->Initial();
  379. fsm->PostEventFIFO(e);
  380. }
  381. };
  382. struct ProcFWBReConnTask : public ITaskSp
  383. {
  384. CIDCertFSM* fsm;
  385. ProcFWBReConnTask(CIDCertFSM* f) : fsm(f) {}
  386. void Process()
  387. {
  388. FSMEvent* e = new FSMEvent(USER_EVT_TODO_INIT_FINISHED);
  389. e->param1 = fsm->ProcFWBReConn();
  390. fsm->PostEventFIFO(e);
  391. }
  392. };
  393. #endif //IDCERTFSM_H