PinPadFSM.cpp 48 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408
  1. #include "stdafx.h"
  2. #include "PinPadFSM.h"
  3. #include "PinPad_msg_g.h"
  4. #include "GetDevInfoHelper.h"
  5. #include "EventCode.h"
  6. #include "ModuleMix.h"
  7. #include <map>
  8. #include "RVCComm.h"
  9. #include "sm4.h"
  10. #include "publicFunExport.h"
  11. #if defined(RVC_OS_LINUX)
  12. #include <thread>
  13. #include <chrono>
  14. #include <winpr/sysinfo.h>
  15. #endif
  16. using namespace std;
  17. const int PINPAD_INIT_TRIES = 3;
  18. const int PINPAD_ANY_INPUT_TIMEOUT = 100;
  19. const int MAX_PINPAD_INPUT_TIMEOUT = 60000;
  20. const int MAX_INPUT_TIMER_TIMEOUT = 600000;
  21. void CPinPadFSM::ToLogWarnInfoAboutTermCustom()
  22. {
  23. LOG_FUNCTION();
  24. std::map<std::string, std::string> termInfo;
  25. char* strFileHash = new char[128];
  26. memset(strFileHash, 0, 128);
  27. termInfo["keyType"] = _itoa(m_encryptkey, strFileHash,10);
  28. if (strFileHash != nullptr) {
  29. delete[] strFileHash;
  30. strFileHash = nullptr;
  31. }
  32. if (m_bSMLoaded)
  33. termInfo["SMKeyLoad"] = "true";
  34. else
  35. termInfo["SMKeyLoad"] = "false";
  36. ToLogWarnInfoAboutTermExtend(termInfo);
  37. }
  38. ErrorCodeEnum CPinPadFSM::OnInit()
  39. {
  40. LOG_FUNCTION();
  41. CSystemStaticInfo sysInfo;
  42. m_csMachineType = m_csSite = m_terminalNo = "";
  43. GetEntityBase()->GetFunction()->GetSystemStaticInfo(sysInfo);
  44. m_csMachineType = sysInfo.strMachineType;
  45. m_csSite = sysInfo.strSite;
  46. m_terminalNo = sysInfo.strTerminalID;
  47. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("machineType:%s,site:%s,terminalNo:%s",
  48. (const char*)m_csMachineType, (const char*)m_csSite, (const char*)m_terminalNo);
  49. _beginthreadex(NULL,0,DoWork,(void*)this,0,NULL);
  50. return Error_Succeed;
  51. }
  52. ErrorCodeEnum CPinPadFSM::OnExit()
  53. {
  54. LOG_FUNCTION();
  55. m_bEntityExit = true;
  56. m_hInputConVar.Broadcast();
  57. ErrorCodeEnum eErr = Error_Succeed;
  58. if (m_hDevHelper != nullptr)
  59. {
  60. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  61. eErr = m_hDevHelper->StopInput();
  62. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  63. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::StopInput").setCostTime(m_ullEndTime - m_ullBeginTime)("%s", SpStrError(eErr));
  64. m_hDevHelper.TearDown();
  65. }
  66. return eErr;
  67. }
  68. void CPinPadFSM::s0_on_entry()
  69. {
  70. LOG_FUNCTION();
  71. FSMEvent *e = new FSMEvent(USER_EVT_INIT);
  72. PostEventFIFO(e);
  73. m_ullConnectCost = SP::Module::Comm::RVCGetTickCount();
  74. }
  75. void CPinPadFSM::s0_on_exit()
  76. {
  77. }
  78. unsigned int CPinPadFSM::s0_on_event(FSMEvent* evt)
  79. {
  80. LOG_FUNCTION();
  81. if (evt->iEvt == USER_EVT_INIT) {
  82. m_hInputConVar.Broadcast();
  83. evt->SetHandled();
  84. return 0;
  85. }else if (evt->iEvt == USER_EVT_QUIT) {
  86. evt->SetHandled();
  87. return 0;
  88. }
  89. return 0;
  90. }
  91. void CPinPadFSM::s1_on_entry()
  92. {
  93. LOG_FUNCTION();
  94. }
  95. void CPinPadFSM::s1_on_exit()
  96. {
  97. }
  98. unsigned int CPinPadFSM::s1_on_event(FSMEvent* evt)
  99. {
  100. LOG_FUNCTION();
  101. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("s1 event %d",evt->iEvt);
  102. int ret = 0;
  103. if (evt->iEvt == USER_EVT_INITFINISHED) {
  104. evt->SetHandled();
  105. int err = evt->param1;
  106. if (err == 0)
  107. ret = 0;
  108. else
  109. ret = 1;
  110. //SetEvent(m_hInitEvt);
  111. return ret;
  112. }else if (evt->iEvt == USER_EVT_QUIT) {
  113. evt->SetHandled();
  114. return 0;
  115. }
  116. return 0;
  117. }
  118. //Idle
  119. void CPinPadFSM::s2_on_entry()
  120. {
  121. LOG_FUNCTION();
  122. m_eDevState = DEVICE_STATUS_NORMAL;
  123. GetEntityBase()->GetFunction()->SetUserDefineState(USER_PINPAD_IDLE);
  124. m_testResult = Error_Succeed;
  125. }
  126. void CPinPadFSM::s2_on_exit()
  127. {
  128. }
  129. unsigned int CPinPadFSM::s2_on_event(FSMEvent* pEvt)
  130. {
  131. if (pEvt->iEvt != 1)
  132. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("s2 %d,%d",pEvt->iEvt,pEvt->param1);
  133. switch(pEvt->iEvt)
  134. {
  135. case USER_EVT_GETINPUT_SM:
  136. {
  137. m_hInputConVar.Broadcast();
  138. pEvt->SetHandled();
  139. return 0;
  140. }
  141. case USER_EVT_LOADKEY_SM:
  142. {
  143. pEvt->SetHandled();
  144. m_bLoadKey = true;
  145. LoadKeySMTask* task = new LoadKeySMTask(this);
  146. LoadKeySMEvent* lke = dynamic_cast<LoadKeySMEvent*>(pEvt);
  147. task->ctx = lke->ctx;
  148. GetEntityBase()->GetFunction()->PostThreadPoolTask(task);
  149. return 2;
  150. }
  151. case USER_EVT_ENCRYPT_SM:
  152. {
  153. pEvt->SetHandled();
  154. m_bEncrypt = true;
  155. EncryptSMTask* task = new EncryptSMTask(this);
  156. EncryptSMEvent* ee = dynamic_cast<EncryptSMEvent*>(pEvt);
  157. task->ctx = ee->ctx;
  158. GetEntityBase()->GetFunction()->PostThreadPoolTask(task);
  159. return 2;
  160. }
  161. case USER_EVT_GET_CHECKCODE:
  162. {
  163. pEvt->SetHandled();
  164. GetCheckCodeTask* task = new GetCheckCodeTask(this);
  165. GetCheckCodeEvent* gcce = dynamic_cast<GetCheckCodeEvent*>(pEvt);
  166. task->ctx = gcce->ctx;
  167. GetEntityBase()->GetFunction()->PostThreadPoolTask(task);
  168. return 0;
  169. }
  170. case USER_EVT_QUIT:
  171. pEvt->SetHandled();
  172. break;
  173. default:
  174. break;
  175. }
  176. return 1;
  177. }
  178. //Input
  179. void CPinPadFSM::s3_on_entry()
  180. {
  181. LOG_FUNCTION();
  182. GetEntityBase()->GetFunction()->SetUserDefineState(USER_PINPAD_PININPUT);
  183. }
  184. void CPinPadFSM::s3_on_exit()
  185. {
  186. LOG_FUNCTION();
  187. }
  188. unsigned int CPinPadFSM::s3_on_event(FSMEvent* evt)
  189. {
  190. LOG_FUNCTION();
  191. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("s3 event %d",evt->iEvt);
  192. switch(evt->iEvt)
  193. {
  194. case USER_EVT_GETINPUT_SM_FINISHED:
  195. evt->SetHandled();
  196. break;
  197. case USER_EVT_INPUTCANCEL:
  198. evt->SetHandled();
  199. m_bFrontCancel = true;
  200. break;
  201. case USER_EVT_INPUTWAITINGMORE:
  202. evt->SetHandled();
  203. m_bWaitingMore = true;
  204. break;
  205. case USER_EVT_EXIT:
  206. SetExitFlag();
  207. break;
  208. case USER_EVT_QUIT:
  209. evt->SetHandled();
  210. break;
  211. default:
  212. break;
  213. }
  214. return 0;
  215. }
  216. //AccessAuth
  217. void CPinPadFSM::s4_on_entry()
  218. {
  219. LOG_FUNCTION();
  220. GetEntityBase()->GetFunction()->SetUserDefineState(USER_PINPAD_PARAM_ENCRYPTE);
  221. }
  222. void CPinPadFSM::s4_on_exit()
  223. {
  224. LOG_FUNCTION();
  225. }
  226. unsigned int CPinPadFSM::s4_on_event(FSMEvent* pEvt)
  227. {
  228. switch(pEvt->iEvt)
  229. {
  230. case USER_EVT_LOADKEY_SM_FINISHED:
  231. pEvt->SetHandled();
  232. break;
  233. case USER_EVT_ENCRYPT_SM_FINISHED:
  234. pEvt->SetHandled();
  235. break;
  236. case USER_EVT_GET_CHECKCODE:
  237. {
  238. pEvt->SetHandled();
  239. GetCheckCodeTask* task = new GetCheckCodeTask(this);
  240. GetCheckCodeEvent* gcce = dynamic_cast<GetCheckCodeEvent*>(pEvt);
  241. task->ctx = gcce->ctx;
  242. GetEntityBase()->GetFunction()->PostThreadPoolTask(task);
  243. return 0;
  244. }
  245. default:
  246. break;
  247. }
  248. return 0;
  249. }
  250. void CPinPadFSM::s5_on_entry()
  251. {
  252. LOG_FUNCTION();
  253. if (m_bOpened)
  254. m_eDevState = DEVICE_STATUS_FAULT;
  255. GetEntityBase()->GetFunction()->SetUserDefineState(USER_PINPAD_FAILED);
  256. m_testResult = Error_InvalidState;
  257. }
  258. void CPinPadFSM::s5_on_exit()
  259. {
  260. LOG_FUNCTION();
  261. }
  262. unsigned int CPinPadFSM::s5_on_event(FSMEvent* pEvt)
  263. {
  264. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("s5 evt %d",pEvt->iEvt);
  265. switch (pEvt->iEvt)
  266. {
  267. default:
  268. break;
  269. }
  270. return 0;
  271. }
  272. void CPinPadFSM::s6_on_entry()
  273. {
  274. LOG_FUNCTION();
  275. m_eDevState = DEVICE_STATUS_NOT_READY;
  276. GetEntityBase()->GetFunction()->SetUserDefineState(USER_PINPAD_FAILED);
  277. }
  278. void CPinPadFSM::s6_on_exit()
  279. {
  280. }
  281. unsigned int CPinPadFSM::s6_on_event(FSMEvent* pEvt)
  282. {
  283. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("s6 evt %d", pEvt->iEvt);
  284. switch (pEvt->iEvt)
  285. {
  286. default:
  287. break;
  288. }
  289. return 0;
  290. }
  291. int CPinPadFSM::Initial()
  292. {
  293. LOG_FUNCTION();
  294. #if defined(RVC_OS_WIN)
  295. DWORD dwCurrThId = GetCurrentThreadId();
  296. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Initial thread id:%d", dwCurrThId);
  297. #endif
  298. ErrorCodeEnum eErrDev;
  299. auto pEntity = GET_DEV_ENTITY_BASE_POINTER();
  300. GetEntityBase()->GetFunction()->GetSystemStaticInfo(m_sysStaticInfo);
  301. m_deviceNo = m_sysStaticInfo.strTerminalID;
  302. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("m_deviceNo:%s", m_deviceNo.GetData());
  303. m_devCheckData = "0000000000000000";
  304. CSimpleStringA csDepPath(""), csBackslash(SPLIT_SLASH_STR);
  305. m_devSN = "";
  306. eErrDev = pEntity->LoadVendorLibName();
  307. if (eErrDev != Error_Succeed)
  308. {
  309. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("SpGetDevAdaptorPath(%d) failed.", eErrDev);
  310. LogWarn(Severity_Middle, eErrDev, PinPad_UserErrorCode_Get_DevAdapter_Path_Failed, "Initial:SpGetDevAdaptorPath");
  311. return Error_DevLoadFileFailed;
  312. }
  313. FulfillAdapterInfoFrom(pEntity->vendorLibInfo);
  314. HARDWARE_ENTITY_SET_VENDOR_NAME(m_entCode, m_adapterInfo.strVendor);
  315. pEntity->InitializeVendorLogSwitch();
  316. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("to load vendor dll.");
  317. eErrDev = m_hDevHelper.LoadUp(m_adapterInfo.adapterFilePath);
  318. if (!IS_SUCCEED(eErrDev))
  319. {
  320. LogWarn(Severity_Middle, Error_NotInit, PinPad_UserErrorCode_Load_Dll_File_Failed, "密码键盘加载厂商适配器失败!请检查root.ini配置是否正确。");
  321. return Error_DevLoadFileFailed;
  322. }
  323. else {
  324. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("load vendor dll suc.");
  325. }
  326. int initTries = 0;
  327. ErrorCodeEnum eErr = Error_Unexpect;
  328. do
  329. {
  330. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("port:%d,baudRate:%d", m_adapterInfo.GetPortInt(), m_adapterInfo.GetBaudrateInt());
  331. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  332. eErr = m_hDevHelper->DevOpen(m_adapterInfo.GetPortInt(), m_adapterInfo.GetBaudrateInt());
  333. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  334. if (eErr == Error_Succeed)
  335. {
  336. ToLogRootINIInfo();
  337. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::DevOpen").setCostTime(m_ullEndTime - m_ullBeginTime)();
  338. initTries = 0;
  339. ErrorCodeEnum errCode3, errCode4;
  340. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  341. //errCode1 = m_hDevHelper->SetParam(EPP_PT_SET_ENCRYPT_METHOD,EPP_ALGO_METHOD_3DES);
  342. //errCode2 = m_hDevHelper->SetParam(EPP_PT_SET_MAC_ALGORITH,EPP_MAC_ALGO_ASNIX99);
  343. errCode3 = m_hDevHelper->SetParam(EPP_PT_SET_PIN_ALGORITH, EPP_PIN_ALGO_SM4);
  344. errCode4 = m_hDevHelper->SetParam(EPP_PT_SET_ECB_CBC_MODE, EPP_ALGO_MODE_3DEC_CBC);
  345. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  346. if (errCode3 != Error_Succeed || errCode4 != Error_Succeed)
  347. {
  348. if (errCode3 != Error_Succeed)
  349. {
  350. SetErrPackage("Initial::SetParm(3)", m_devSN, errCode3, MEC_DEVAPI_EPP_SetParam);
  351. AlarmDEC();
  352. }
  353. if (errCode4 != Error_Succeed)
  354. {
  355. SetErrPackage("Initial::SetParm(4)", m_devSN, errCode4, MEC_DEVAPI_EPP_SetParam);
  356. AlarmDEC();
  357. }
  358. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM).setAPI("DevAdapter::SetParam").setResultCode("RTA260B")
  359. .setCostTime(m_ullEndTime - m_ullBeginTime)("errCode3:%s, errCode4:%s", SpStrError(errCode3), SpStrError(errCode4));
  360. return 1;
  361. }
  362. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::SetParam").setCostTime(m_ullEndTime - m_ullBeginTime)();
  363. break;
  364. }
  365. else
  366. {
  367. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_SYSTEM).setAPI("DevAdapter::DevOpen").setResultCode("RTA2602").setCostTime(m_ullEndTime - m_ullBeginTime)("%s", SpStrError(eErr));
  368. initTries++;
  369. SetErrPackage("Initial::DevOpen", m_devSN, eErr, MEC_DEVAPI_EPP_DevOpen);
  370. AlarmDEC();
  371. Sleep(1200);
  372. continue;
  373. }
  374. } while (initTries < PINPAD_INIT_TRIES);
  375. if (initTries != 0)
  376. {
  377. LogEvent(Severity_Middle, LOG_EVT_PINPAD_OPEN_FAIL, "Open pinpad failed.");
  378. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_SYSTEM)("Open pinpad failed.");
  379. return 1;
  380. }
  381. m_bOpened = true;
  382. //oiltmp comment the following 20160406
  383. //update with the version 1.7.1
  384. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  385. m_encryptkey = m_hDevHelper->GetEncryptFunc();
  386. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  387. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::GetEncryptFunc").setCostTime(m_ullEndTime - m_ullBeginTime)("Error_Succeed");
  388. CSmartPointer<IConfigInfo> spConfig;
  389. eErrDev = GetEntityBase()->GetFunction()->OpenConfig(Config_Run, spConfig);
  390. if (eErrDev != Error_Succeed)
  391. {
  392. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("read run cfg failed(sm).");
  393. m_bSMLoaded = false;
  394. LogWarn(Severity_Middle, eErrDev, PinPad_UserErrorCode_Open_RunCfgFile_Failed, "Initial:OpenConfig");
  395. }
  396. else
  397. {
  398. int tmpLoad = 0;
  399. eErrDev = spConfig->ReadConfigValueInt("Load", "SM", tmpLoad);
  400. if (eErrDev == Error_Succeed)
  401. m_bSMLoaded = tmpLoad;
  402. //oilyang@20201026 from kmc micro service
  403. spConfig->ReadConfigValue("Load", "SN_SM", m_keySNSM);
  404. spConfig->ReadConfigValue("Load", "ckckck", m_lastCheckCode);
  405. }
  406. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("encrypt key :%d,load key :%d", m_encryptkey, m_bSMLoaded);
  407. DevCategoryInfo devInfo;
  408. ZeroMemory(devInfo.szModel, MAX_DEV_MODEL_LEN);
  409. ZeroMemory(devInfo.szType, MAX_DEV_TYPE_LEN);
  410. ZeroMemory(devInfo.szVendor, MAX_DEV_VENDOR_LEN);
  411. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  412. eErrDev = m_hDevHelper->GetDevCategory(devInfo);
  413. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  414. if (eErrDev == Error_Succeed)
  415. {
  416. m_szModel = devInfo.szModel;
  417. m_szType = devInfo.szType;
  418. m_szVendor = devInfo.szVendor;
  419. m_adapterInfo.FulfillCategoryInfo(devInfo);
  420. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::GetDevCategory").setCostTime(m_ullEndTime - m_ullBeginTime)
  421. ("model,%d,%s;type,%d,%s;vendor,%d,%s", strlen(devInfo.szModel), m_szModel.GetData(), strlen(devInfo.szType), m_szType.GetData(), strlen(devInfo.szVendor), m_szVendor.GetData());
  422. }
  423. else
  424. {
  425. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM).setAPI("DevAdapter::GetDevCategory").setResultCode("RTA2606").setCostTime(m_ullEndTime - m_ullBeginTime)("%s", SpStrError(eErrDev));
  426. SetErrPackage("Initial::GetDevCategory", m_devSN, eErrDev, MEC_DEVAPI_EPP_GetDevCategory);
  427. AlarmDEC();
  428. }
  429. CSimpleStringA xTmpStr = CSimpleStringA::Format("(hw support):%d,load key :%d,SMSN:%s", m_encryptkey, m_bSMLoaded, m_keySNSM.GetData());
  430. LogWarn(Severity_Low, Error_Unexpect, PinPad_UserErrorCode_DevConnect_CostTime, CSimpleStringA::Format("%d", (SP::Module::Comm::RVCGetTickCount() - m_ullConnectCost) / 1000));
  431. LogWarn(Severity_Low, Error_Unexpect, PinPad_UserErrorCode_PinPad_InfoAboutKey_Onboot, xTmpStr.GetData());
  432. LogEvent(Severity_Middle, LOG_EVT_PINPAD_OPEN_SUC, "Open pinpad suc.");
  433. return 0;
  434. }
  435. unsigned int __stdcall DoWork(void *pData)
  436. {
  437. while(1)
  438. {
  439. CPinPadFSM *pFsm = (CPinPadFSM*)pData;
  440. pFsm->m_hInputConVar.Wait();
  441. if (pFsm->GetEntityExit())
  442. break;
  443. FSMEvent *evt;
  444. int ret;
  445. if (!pFsm->GetDevInitFlag())
  446. {
  447. ret = pFsm->Initial();
  448. evt = new FSMEvent(USER_EVT_INITFINISHED);
  449. }
  450. else
  451. {
  452. SpReqAnsContext<PinPadService_GetInputSM_Req, PinPadService_GetInputSM_Ans>::Pointer ctxSM;
  453. bool bRet = pFsm->GetCtx(ctxSM);
  454. if (!bRet)
  455. {
  456. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("get ctx failed.doing nothing");
  457. continue;
  458. }
  459. ret = pFsm->GetInput(ctxSM);
  460. evt = new FSMEvent(USER_EVT_GETINPUT_SM_FINISHED);
  461. }
  462. if (ret == 0)
  463. evt->param1 = 0;
  464. else
  465. evt->param1 = 1;
  466. pFsm->PostEventFIFO(evt);
  467. }
  468. #if defined(RVC_OS_WIN)
  469. _endthreadex(0);
  470. #else
  471. pthread_exit(0);
  472. #endif //RVC_OS_WIN
  473. return 0;
  474. }
  475. void CPinPadFSM::push_char(char *buf, int *len, int c)
  476. {
  477. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("len:%d",*len);
  478. buf[*len] = c;
  479. *len = *len + 1;
  480. buf[*len] = 0;
  481. InputContent evt;
  482. evt.data = buf;
  483. SpSendBroadcast(GetEntityBase()->GetFunction(), SP_MSG_OF(InputContent), SP_MSG_SIG_OF(InputContent), evt);
  484. }
  485. void CPinPadFSM::PushInputChar(char *buf,int c)
  486. {
  487. buf[0] = c;
  488. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("anyinput[%d][%s]",c,buf);
  489. InputContent evt;
  490. evt.data = buf;
  491. SpSendBroadcast(GetEntityBase()->GetFunction(), SP_MSG_OF(InputContent), SP_MSG_SIG_OF(InputContent), evt);
  492. }
  493. void CPinPadFSM::pop_char(char *buf, int *len, bool bClear)
  494. {
  495. if (*len > 0) {
  496. if (bClear){
  497. memset(buf,0,*len);
  498. *len = 0;
  499. }else {
  500. *len -= 1;
  501. buf[*len] = 0;
  502. }
  503. InputContent evt;
  504. evt.data = buf;
  505. SpSendBroadcast(GetEntityBase()->GetFunction(), SP_MSG_OF(InputContent), SP_MSG_SIG_OF(InputContent), evt);
  506. }
  507. }
  508. void CPinPadFSM::clear_char(char *buf, int *len)
  509. {
  510. if (*len > 0) {
  511. *len = 0;
  512. buf[*len] = 0;
  513. InputContent evt;
  514. evt.data = buf;
  515. SpSendBroadcast(GetEntityBase()->GetFunction(), SP_MSG_OF(InputContent), SP_MSG_SIG_OF(InputContent), evt);
  516. }
  517. }
  518. bool CPinPadFSM::Get12Account(char *szAcc)
  519. {
  520. memset(m_szAccount,0,sizeof(m_szAccount));
  521. const int accLen = strlen(szAcc);
  522. if (accLen == 0) {
  523. return false;
  524. }
  525. if (accLen > 12)
  526. memcpy(m_szAccount + 4, szAcc + (accLen - 12 -1), 12);
  527. else if (accLen == 12)
  528. {
  529. if (strncmp(szAcc, "0755", 4) == 0)
  530. memcpy(m_szAccount + 4, szAcc, 12);
  531. else
  532. {
  533. m_szAccount[4] = '5';
  534. memcpy(m_szAccount + 5, szAcc + 1, 11);
  535. }
  536. }
  537. else if (accLen == 9)
  538. {
  539. memcpy(m_szAccount + 4, szAcc, 3);
  540. memcpy(m_szAccount + 7, szAcc, 9);
  541. }
  542. else
  543. memcpy(m_szAccount + 4, szAcc, accLen);
  544. return true;
  545. }
  546. ErrorCodeEnum CPinPadFSM::GetEncryptText(SpReqAnsContext<PinPadService_GetInputSM_Req, PinPadService_GetInputSM_Ans>::Pointer ctxSM)
  547. {
  548. LOG_FUNCTION();
  549. ErrorCodeEnum errCode;
  550. CSmartPointer<IEntityFunction> spEntityFunction = GetEntityBase()->GetFunction();
  551. int len, timeout;
  552. bool confirm, bSMFlag = false;
  553. len = ctxSM->Req.length;
  554. timeout = ctxSM->Req.timeout;
  555. confirm = ctxSM->Req.confirm;
  556. if (ctxSM->Req.smflag == 1 || ctxSM->Req.smflag == 11)
  557. {
  558. bSMFlag = true;
  559. }
  560. if (!bSMFlag)
  561. {
  562. LogWarn(Severity_Low, Error_Unexpect, PinPad_UserErrorCode_PinPad_Not_SM, "Encryption is not SM");
  563. ctxSM->Answer(Error_Unexpect, PinPad_UserErrorCode_UnknownSMFlag);
  564. return Error_Unexpect;
  565. }
  566. AccountInfo accInfo;
  567. memset(accInfo.account, 0, MAX_ACCOUNT_LEN);
  568. CSimpleStringA errMsg(true);
  569. if (Get12Account(const_cast<char*>(ctxSM->Req.account.GetData())))
  570. memcpy(accInfo.account, m_szAccount + 4, 12);
  571. else
  572. {
  573. errMsg = CSimpleStringA::Format("Get12Account err(%s).", (const char*)ctxSM->Req.account);
  574. if (m_iInWhatPage == PageType_Other)
  575. {
  576. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setResultCode("RTA2607")(errMsg.GetData());
  577. LogError(Severity_High, Error_Unexpect, PinPad_UserErrorCode_PinPad_GetEncryptText_Get12Account_Error, errMsg.GetData());
  578. }
  579. else
  580. LogWarn(Severity_High, Error_Unexpect, PinPad_UserErrorCode_PinPad_GetEncryptText_Get12Account_Error, errMsg.GetData());
  581. ctxSM->Answer(Error_DevCommFailed, PinPad_UserErrorCode_PinPad_GetEncryptText_Get12Account_Error);
  582. return Error_DevCommFailed;
  583. }
  584. //memcpy(accInfo.account,"588571006555",12);
  585. accInfo.dwAccLen = 12;
  586. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("acc(%s)", accInfo.account);
  587. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  588. errCode = m_hDevHelper->SetAccNo(accInfo);
  589. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  590. if (errCode != Error_Succeed)
  591. {
  592. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("[sm]set accout(%s)(%s) failed(%d).", (const char*)ctxSM->Req.account, accInfo.account, errCode);
  593. SetErrPackage("GetEncryptText::SetAccNo", m_devSN, errCode, MEC_DEVAPI_EPP_SetAccNo);
  594. if (IsInBusiness())
  595. {
  596. ctxSM->Answer(Error_DevCommFailed, AlarmDEC(true));
  597. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::SetAccNo")
  598. .setCostTime(m_ullEndTime - m_ullBeginTime).setResultCode("RTA2608")("设置账号失败:%s", SpStrError(errCode));
  599. }
  600. else
  601. {
  602. ctxSM->Answer(Error_DevCommFailed, AlarmDEC());
  603. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::SetAccNo")
  604. .setCostTime(m_ullEndTime - m_ullBeginTime).setResultCode("RTA2608")("设置账号失败:%s", SpStrError(errCode));
  605. }
  606. return Error_DevCommFailed;
  607. }
  608. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::SetAccNo").setCostTime(m_ullEndTime - m_ullBeginTime)();
  609. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  610. errCode = m_hDevHelper->ActiveWorkingKey(1, 0);
  611. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  612. if (errCode != Error_Succeed)
  613. {
  614. SetErrPackage("GetEncryptText::ActiveWorkingKey", m_devSN, errCode, MEC_DEVAPI_EPP_ActiveWorkingKey);
  615. if (IsInBusiness())
  616. {
  617. ctxSM->Answer(Error_DevCommFailed, AlarmDEC(true));
  618. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::ActiveWorkingKey")
  619. .setResultCode("RTA260C").setCostTime(m_ullEndTime - m_ullBeginTime)("计算密文时激活工作密钥失败");
  620. }
  621. else
  622. {
  623. ctxSM->Answer(Error_DevCommFailed, AlarmDEC());
  624. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::ActiveWorkingKey")
  625. .setResultCode("RTA260C").setCostTime(m_ullEndTime - m_ullBeginTime)("计算密文时激活工作密钥失败");
  626. }
  627. return Error_DevCommFailed;
  628. }
  629. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setAPI("DevAdapter::ActiveWorkingKey").setCostTime(m_ullEndTime - m_ullBeginTime)();
  630. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  631. errCode = m_hDevHelper->SetParam(EPP_PT_SET_PIN_ALGORITH, EPP_PIN_ALGO_SM4);
  632. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  633. if (errCode != Error_Succeed)
  634. {
  635. SetErrPackage("GetEncryptText::SetParam", m_devSN, errCode, MEC_DEVAPI_EPP_SetParam);
  636. if (IsInBusiness())
  637. {
  638. ctxSM->Answer(Error_DevCommFailed, AlarmDEC(true));
  639. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::SetParam")
  640. .setResultCode("RTA260B")("计算密文时设置参数失败:%s", SpStrError(errCode));
  641. }
  642. else
  643. {
  644. ctxSM->Answer(Error_DevCommFailed, AlarmDEC());
  645. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::SetParam")
  646. .setResultCode("RTA260B")("计算密文时设置参数失败:%s", SpStrError(errCode));
  647. }
  648. return Error_DevCommFailed;
  649. }
  650. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::SetParam").setCostTime(m_ullEndTime - m_ullBeginTime)();
  651. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  652. errCode = m_hDevHelper->StartPinInput(len);
  653. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  654. if (errCode != Error_Succeed)
  655. {
  656. SetErrPackage("GetEncryptText::StartPinInput", m_devSN, errCode, MEC_DEVAPI_EPP_StartPinInput);
  657. if (IsInBusiness())
  658. {
  659. ctxSM->Answer(Error_DevCommFailed, AlarmDEC(true));
  660. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::StartPinInput")
  661. .setResultCode("RTA2609").setCostTime(m_ullEndTime - m_ullBeginTime)("%s", SpStrError(errCode));
  662. }
  663. else
  664. {
  665. ctxSM->Answer(Error_DevCommFailed, AlarmDEC());
  666. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::StartPinInput")
  667. .setResultCode("RTA2609").setCostTime(m_ullEndTime - m_ullBeginTime)("%s", SpStrError(errCode));
  668. }
  669. return Error_DevCommFailed;
  670. }
  671. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::StartPinInput").setCostTime(m_ullEndTime - m_ullBeginTime)();
  672. char* buf = new char[len + 1];
  673. memset(buf, 0, len + 1);
  674. int readed = 0;
  675. DWORD elapsed = 0;
  676. DWORD dwStart = GetTickCount();
  677. DWORD dwEnd = GetTickCount();
  678. bool bCancelInput = false;
  679. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("req(pin)len:[%d],timeout:[%d],confirm:[%d],bExit(%d)", len, timeout, confirm, m_bExit);
  680. while (elapsed < MAX_PINPAD_INPUT_TIMEOUT) {
  681. if (m_bExit)
  682. break;
  683. if (!confirm && readed >= len)
  684. break;
  685. if (m_bWaitingMore)
  686. {
  687. dwStart = GetTickCount();
  688. elapsed = 0;
  689. m_bWaitingMore = false;
  690. continue;
  691. }
  692. if (m_bFrontCancel)
  693. {
  694. bCancelInput = true;
  695. goto Err;
  696. }
  697. BYTE btCh;
  698. Sleep(100);
  699. errCode = m_hDevHelper->KeyRead(btCh);//循环调用,无需计算耗时
  700. if (errCode == Error_Succeed) {
  701. LogEvent(Severity_Middle, LOG_EVT_PINPAD_OP, "PinPad op.", ctxSM->link);
  702. if (btCh == 0x0d) {
  703. if (confirm)
  704. {
  705. ctxSM->Ans.enter = true;
  706. if (buf != NULL)
  707. delete[]buf;
  708. ctxSM->Answer(Error_Succeed);
  709. return Error_Succeed;
  710. }
  711. else
  712. {
  713. dwEnd = GetTickCount();
  714. elapsed = dwEnd - dwStart;
  715. continue;
  716. }
  717. }
  718. else if (btCh == 0x08) { // back
  719. if (confirm)
  720. {
  721. dwEnd = GetTickCount();
  722. elapsed = dwEnd - dwStart;
  723. continue;
  724. }
  725. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER)("clear input");
  726. pop_char(buf, &readed,true);
  727. } else if (btCh == 0x1b) { // quit
  728. if (confirm)
  729. {
  730. ctxSM->Ans.enter = true;
  731. if (buf != NULL)
  732. delete[]buf;
  733. ctxSM->Answer(Error_Succeed);
  734. return Error_Succeed;
  735. }
  736. else
  737. {
  738. bCancelInput = true;
  739. goto Err;
  740. }
  741. }
  742. else if (btCh == 0x3f) {
  743. if (confirm)
  744. {
  745. dwEnd = GetTickCount();
  746. elapsed = dwEnd - dwStart;
  747. continue;
  748. }
  749. push_char(buf, &readed, '*');
  750. }else{
  751. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER)("else[%d]",btCh);
  752. }
  753. }
  754. else {
  755. }
  756. dwEnd = GetTickCount();
  757. elapsed = dwEnd - dwStart;
  758. }
  759. buf[readed] = 0;
  760. Err:
  761. if (m_bExit)
  762. {
  763. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("exit");
  764. ctxSM->Answer(Error_Unexpect, PinPad_UserErrorCode_Unexpected_Exit);
  765. return Error_Unexpect;
  766. }
  767. m_bExit = false;
  768. if (buf != NULL)
  769. delete[]buf;
  770. if (bCancelInput)
  771. {
  772. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode("QLR040220602")("input cancel(pin)");
  773. ctxSM->Answer(Error_Cancel);
  774. return Error_Cancel;
  775. }
  776. if (readed < len) {
  777. if (elapsed >= MAX_PINPAD_INPUT_TIMEOUT) {
  778. ctxSM->Answer(Error_TimeOut);
  779. return Error_TimeOut;
  780. }
  781. }
  782. PinBlock pinBlk;
  783. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("to getpinblk");
  784. Sleep(500);//nantian
  785. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  786. errCode = m_hDevHelper->GetPinBlock(pinBlk);
  787. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  788. LogWarn(Severity_Low, Error_Succeed, PinPad_UserErrorCode_PinPad_GetPinBlock_Call
  789. , CSimpleStringA::Format("{\"cost\":%d}", m_ullEndTime - m_ullBeginTime));
  790. if (errCode == Error_Succeed)
  791. {
  792. char* tmpPinData = new char[MAX_PIN_BLOCK_SIZE];
  793. if (tmpPinData == NULL)
  794. return Error_Resource;
  795. memset(tmpPinData, 0, MAX_PIN_BLOCK_SIZE);
  796. memcpy(tmpPinData, pinBlk.data, pinBlk.dwSize);
  797. ctxSM->Ans.data = tmpPinData;
  798. //Dbg("pinblk(%s)",tmpPinData);
  799. if (tmpPinData != NULL)
  800. {
  801. delete[]tmpPinData;
  802. tmpPinData = NULL;
  803. }
  804. EnDecryptInfo srcInfo, dstInfo;
  805. memset(srcInfo.data, 0, MAX_EN_DECRYPT_DATA_SIZE);
  806. memcpy(srcInfo.data, m_devCheckData, m_devCheckData.GetLength());
  807. srcInfo.dwSize = m_devCheckData.GetLength();
  808. memset(dstInfo.data, 0, MAX_EN_DECRYPT_DATA_SIZE);
  809. //set param
  810. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  811. errCode = m_hDevHelper->SetParam(EPP_PT_SET_ENCRYPT_METHOD, EPP_ALGO_METHOD_SM4);
  812. if (errCode == Error_Succeed)
  813. errCode = m_hDevHelper->SetParam(EPP_PT_SET_ECB_CBC_MODE, EPP_ALGO_MODE_CBC);
  814. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  815. if (errCode != Error_Succeed)
  816. {
  817. SetErrPackage("GetEncryptText::SetParam", m_devSN, errCode, MEC_DEVAPI_EPP_SetParam);
  818. if (IsInBusiness())
  819. {
  820. ctxSM->Answer(Error_Param, AlarmDEC(true));
  821. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::SetParam")
  822. .setResultCode("RTA260B").setCostTime(m_ullEndTime - m_ullBeginTime)("计算密文时设置参数失败:%s", SpStrError(errCode));
  823. }
  824. else
  825. {
  826. ctxSM->Answer(Error_Param, AlarmDEC());
  827. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::SetParam")
  828. .setResultCode("RTA260B").setCostTime(m_ullEndTime - m_ullBeginTime)("计算密文时设置参数失败:%s", SpStrError(errCode));
  829. }
  830. return Error_Param;
  831. }
  832. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::SetParam").setCostTime(m_ullEndTime - m_ullBeginTime)();
  833. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  834. errCode = m_hDevHelper->EncryptData(srcInfo, dstInfo);
  835. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  836. if (errCode != Error_Succeed)
  837. {
  838. SetErrPackage("GetEncryptText::EncryptData", m_devSN, errCode, MEC_DEVAPI_EPP_EncryptData);
  839. if (IsInBusiness())
  840. {
  841. ctxSM->Answer(Error_DevCommFailed, AlarmDEC(true));
  842. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::EncryptData")
  843. .setResultCode("RTA260D").setCostTime(m_ullEndTime - m_ullBeginTime)("计算密文时数据加密失败", SpStrError(errCode));
  844. }
  845. else
  846. {
  847. ctxSM->Answer(Error_DevCommFailed, AlarmDEC());
  848. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::EncryptData")
  849. .setResultCode("RTA260D").setCostTime(m_ullEndTime - m_ullBeginTime)("计算密文时数据加密失败", SpStrError(errCode));
  850. }
  851. return Error_DevCommFailed;
  852. }
  853. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::EncryptData").setCostTime(m_ullEndTime - m_ullBeginTime)();
  854. char* tmpCheckCode = new char[MAX_PIN_BLOCK_SIZE];
  855. if (tmpCheckCode == NULL)
  856. return Error_Resource;
  857. memset(tmpCheckCode, 0, MAX_PIN_BLOCK_SIZE);
  858. //HexBuf2StrBuf(dstInfo.data,&tmpCheckCode,dstInfo.dwSize);
  859. memcpy(tmpCheckCode, dstInfo.data, dstInfo.dwSize);
  860. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ckckck[%s], m_keySNSM:%s", tmpCheckCode, m_keySNSM.GetData());
  861. if (strnicmp(tmpCheckCode, "9F1F7BFF6F5511384D9430531E538FD3",
  862. strlen("9F1F7BFF6F5511384D9430531E538FD3")) == 0)
  863. {
  864. SetErrPackage("GetEncryptText::EncryptData(SM)", m_devSN, Error_Unexpect, PinPad_UserErrorCode_KEY_LOST_SM);
  865. AlarmDEC();
  866. }
  867. ctxSM->Ans.checkcode = tmpCheckCode;
  868. ctxSM->Ans.deviceno = m_deviceNo;
  869. ctxSM->Ans.keyseq = m_keySNSM;
  870. CSimpleStringA tmpLastCkCode = m_lastCheckCode;
  871. if (m_lastCheckCode.IsNullOrEmpty() || strnicmp(tmpCheckCode, m_lastCheckCode, m_lastCheckCode.GetLength()) != 0)
  872. {
  873. ErrorCodeEnum eErr;
  874. CSmartPointer<IConfigInfo> spConfigRun;
  875. eErr = GetEntityBase()->GetFunction()->OpenConfig(Config_Run, spConfigRun);
  876. if (eErr == Error_Succeed)
  877. {
  878. spConfigRun->WriteConfigValue("Load", "ckckck", tmpCheckCode);
  879. m_lastCheckCode = tmpCheckCode;
  880. }
  881. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("write ckckck:%s", tmpCheckCode);
  882. }
  883. if (!tmpLastCkCode.IsNullOrEmpty() && strnicmp(tmpCheckCode, tmpLastCkCode, tmpLastCkCode.GetLength()) != 0)
  884. {
  885. CSimpleStringA xCkChangeMsg = CSimpleStringA::Format("last ck:%s,current ck:%s,m_keySNSM:%s", tmpLastCkCode.GetData()
  886. , tmpCheckCode, m_keySNSM.GetData());
  887. LogWarn(Severity_Low, Error_Unexpect, PinPad_UserErrorCode_PinPad_CheckCode_Changed, xCkChangeMsg.GetData());
  888. }
  889. }
  890. else
  891. {
  892. SetErrPackage("GetEncryptText::GetPinBlock", m_devSN, errCode, MEC_DEVAPI_EPP_GetPinBlock);
  893. if (IsInBusiness())
  894. {
  895. ctxSM->Answer(Error_DevCommFailed, AlarmDEC(true));
  896. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::GetPinBlock")
  897. .setResultCode("RTA260A").setCostTime(m_ullEndTime - m_ullBeginTime)("计算密文失败:%s", SpStrError(errCode));
  898. }
  899. else
  900. {
  901. ctxSM->Answer(Error_DevCommFailed, AlarmDEC());
  902. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM).setAPI("DevAdapter::GetPinBlock")
  903. .setResultCode("RTA260A").setCostTime(m_ullEndTime - m_ullBeginTime)("计算密文失败:%s", SpStrError(errCode));
  904. }
  905. return Error_DevCommFailed;
  906. }
  907. DbgWithLink(LOG_LEVEL_INFO, ctxSM->link.checkEmpty() ? LOG_TYPE_SYSTEM : LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetInputSM)
  908. .setAPI("DevAdapter::GetPinBlock").setCostTime(m_ullEndTime - m_ullBeginTime)("获取密文成功");
  909. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  910. ErrorCodeEnum errClosePinPad = m_hDevHelper->StopInput();
  911. if (errClosePinPad != Error_Succeed)
  912. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("close pinpad(%d).", errClosePinPad);
  913. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  914. Sleep(100);
  915. ctxSM->Answer(Error_Succeed);
  916. return Error_Succeed;
  917. }
  918. int CPinPadFSM::GetInput(SpReqAnsContext<PinPadService_GetInputSM_Req, PinPadService_GetInputSM_Ans>::Pointer ctxSM)
  919. {
  920. DWORD dwCurrThId = GetCurrentThreadId();
  921. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("GetInput thread id:%d",dwCurrThId);
  922. m_bWaitingMore = false;
  923. m_bFrontCancel = false;
  924. m_bExit = false;
  925. LogEvent(Severity_Middle, LOG_EVT_PINPAD_GREEN_ON, "PinPad light on.");
  926. if (!m_hDevHelper)
  927. {
  928. SetErrPackage("GetInput(SM)", m_devSN, Error_Unexpect, PinPad_UserErrorCode_PinPad_Instance_Is_Null);
  929. m_inputSMCtx->Answer(Error_Unexpect, AlarmDEC());
  930. LogEvent(Severity_Middle, LOG_EVT_PINPAD_GREEN_OFF, "PinPad light off.");
  931. m_bPinInput = false;
  932. return 1;
  933. }
  934. if (!m_inputSMCtx->Req.encrypt)
  935. {
  936. SetErrPackage("GetInput(SM)", m_devSN, Error_Unexpect, PinPad_UserErrorCode_NoPlainInput);
  937. m_inputSMCtx->Answer(Error_Unexpect, AlarmDEC());
  938. return 1;
  939. }
  940. ErrorCodeEnum err;
  941. err = GetEncryptText(m_inputSMCtx);
  942. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)
  943. ("req acc.len:%d,confirm:%d,len:%d. ans:ck.len:%d", m_inputSMCtx->Req.account.GetLength(), m_inputSMCtx->Req.confirm
  944. , m_inputSMCtx->Req.length, m_inputSMCtx->Ans.checkcode.IsNullOrEmpty() ? 0 : m_inputSMCtx->Ans.checkcode.GetLength());
  945. DbgToBeidou(m_inputSMCtx->link, "GetInput")();
  946. m_bPinInput = false;
  947. LogEvent(Severity_Middle, LOG_EVT_PINPAD_GREEN_OFF, "PinPad light off.");
  948. return 0;
  949. }
  950. int CPinPadFSM::LoadKeySM(SpReqAnsContext<PinPadService_LoadKeysSM_Req, PinPadService_LoadKeysSM_Ans>::Pointer ctx)
  951. {
  952. ErrorCodeEnum eErr;
  953. CSmartPointer<IEntityFunction> spEntityFunction = GetEntityBase()->GetFunction();
  954. CSmartPointer<IConfigInfo> spConfig;
  955. eErr = spEntityFunction->OpenConfig(Config_Run, spConfig);
  956. if (eErr != Error_Succeed)
  957. {
  958. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER)("LoadKeySM::OpenConfig failed,eErr:%d", eErr);
  959. spConfig = NULL;
  960. ctx->Answer(eErr, PinPad_UserErrorCode_Open_RunCfgFile_Failed);
  961. return 0;
  962. }
  963. if (!(ctx->Req.smflag == 1 || ctx->Req.smflag == 11))
  964. {
  965. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER)("密钥标识不支持,ctx->Req.smflag:%d", ctx->Req.smflag);
  966. ctx->Answer(Error_Unexpect, PinPad_UserErrorCode_UnknownSMFlag);
  967. return 0;
  968. }
  969. //initialization need load master key
  970. if (ctx->Req.initializeflag)
  971. {
  972. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER)("mkey len:%d,ctx->Req.smflag:%d", strlen(ctx->Req.masterkey), ctx->Req.smflag);
  973. if (ctx->Req.smflag == 11)
  974. {
  975. #if defined(RVC_OS_WIN)
  976. MasterKeyParamEx mkParamEx;
  977. mkParamEx.dwSN = 1;
  978. mkParamEx.smFlag = ctx->Req.smflag;
  979. memset(mkParamEx.key, 0, MAX_EN_DECRYPT_DATA_SIZE);
  980. memcpy(mkParamEx.key, ctx->Req.masterkey, strlen(ctx->Req.masterkey));
  981. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  982. eErr = m_hDevHelper->LoadMasterKeyEx(mkParamEx);
  983. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  984. if (eErr != Error_Succeed)
  985. {
  986. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_LoadKeysSM).setAPI("DevAdapter::LoadMasterKeyEx")
  987. .setCostTime(m_ullEndTime - m_ullBeginTime).setResultCode("RTA2604")("加载主密钥失败,eErr:%s", SpStrError(eErr));
  988. ctx->Ans.result = 0;
  989. SetErrPackage("LoadKeySM::LoadMasterKeyEx", m_devSN, eErr, MEC_DEVAPI_EPP_LoadMasterKey);
  990. ctx->Answer(Error_Unexpect, AlarmDEC());
  991. m_bLoadKey = false;
  992. return 0;
  993. }
  994. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::LoadMasterKeyEx").setCostTime(m_ullEndTime - m_ullBeginTime)();
  995. #endif
  996. }
  997. else
  998. {
  999. MasterKeyParam mkParam;
  1000. mkParam.dwSN = 1;
  1001. mkParam.smFlag = ctx->Req.smflag;
  1002. memset(mkParam.key, 0, MAX_MASTER_KEY_SIZE);
  1003. memcpy(mkParam.key, ctx->Req.masterkey, strlen(ctx->Req.masterkey));
  1004. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1005. eErr = m_hDevHelper->LoadMasterKey(mkParam);
  1006. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1007. if (eErr != Error_Succeed)
  1008. {
  1009. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("PinPadService_LogCode_LoadKeysSM").setAPI("DevAdapter::LoadMasterKey")
  1010. .setResultCode("RTA2604").setCostTime(m_ullEndTime - m_ullBeginTime)("加载主密钥失败,eErr:%s", SpStrError(eErr));
  1011. ctx->Ans.result = 0;
  1012. SetErrPackage("LoadKeySM::LoadMasterKey", m_devSN, eErr, MEC_DEVAPI_EPP_LoadMasterKey);
  1013. ctx->Answer(Error_Unexpect, AlarmDEC());
  1014. m_bLoadKey = false;
  1015. return 0;
  1016. }
  1017. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::LoadMasterKey").setCostTime(m_ullEndTime - m_ullBeginTime)();
  1018. }
  1019. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_LoadKeysSM)("Load master key suc.");
  1020. //after load Master key,clear the load key status
  1021. spConfig->WriteConfigValueInt("Load", "SM", 0);
  1022. }
  1023. WorkKeyParam wkParam1, wkParam2;
  1024. memset(wkParam1.key, 0, MAX_WORKING_KEY_SIZE);
  1025. memset(wkParam2.key, 0, MAX_WORKING_KEY_SIZE);
  1026. wkParam1.dwMasterSN = wkParam2.dwMasterSN = 1;
  1027. wkParam1.dwWorkingSN = 0;
  1028. wkParam2.dwWorkingSN = 1;
  1029. wkParam1.smFlag = ctx->Req.smflag;
  1030. wkParam2.smFlag = ctx->Req.smflag;
  1031. memcpy(wkParam1.key, ctx->Req.workingkey1, strlen(ctx->Req.workingkey1));
  1032. memcpy(wkParam2.key, ctx->Req.workingkey2, strlen(ctx->Req.workingkey2));
  1033. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1034. eErr = m_hDevHelper->LoadWorkingKey(wkParam1);
  1035. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1036. if (eErr != Error_Succeed)
  1037. {
  1038. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_LoadKeysSM).setAPI("DevAdapter::LoadWorkingKey")
  1039. .setResultCode("RTA2605").setCostTime(m_ullEndTime - m_ullBeginTime)("加载工作密钥1(TPK)失败,eErr:%s", SpStrError(eErr));
  1040. ctx->Ans.result = 1;
  1041. SetErrPackage("LoadKeySM::LoadMasterKey 1", m_devSN, eErr, MEC_DEVAPI_EPP_LoadWorkingKey);
  1042. ctx->Answer(Error_Unexpect, AlarmDEC());
  1043. m_bLoadKey = false;
  1044. return 0;
  1045. }
  1046. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::LoadWorkingKey").setCostTime(m_ullEndTime - m_ullBeginTime)("Load working key1 suc.");
  1047. //oilyang@20220308 to calc checkcode if called Initializer
  1048. if (ctx->Req.initializeflag)
  1049. {
  1050. PBYTE pCtMasterKey = new BYTE[48];
  1051. PBYTE pCtPinKey = new BYTE[48];
  1052. BYTE pinKey[16] = { 0 };
  1053. int pinKeyLen = 16;
  1054. int ctMLen = SP::Module::Util::StrBuf2HexBuf(ctx->Req.masterkey.GetData(), &pCtMasterKey);
  1055. int ctPinLen = SP::Module::Util::StrBuf2HexBuf(ctx->Req.workingkey1.GetData(), &pCtPinKey);
  1056. //sm4 decrypt
  1057. sm4_context sm4Contxt;
  1058. sm4_setkey_dec(&sm4Contxt, pCtMasterKey);
  1059. sm4_crypt_ecb(&sm4Contxt, SM4_DECRYPT, ctPinLen, pCtPinKey, (BYTE*)pinKey);
  1060. BYTE ck[16] = { 0 };
  1061. BYTE ckCode[128] = { 0 };
  1062. sm4_setkey_enc(&sm4Contxt, pinKey);
  1063. sm4_crypt_ecb(&sm4Contxt, SM4_ENCRYPT, 8, ck, (BYTE*)ckCode);
  1064. char* strCkCode = new char[256];
  1065. memset(strCkCode, 0, 256);
  1066. SP::Module::Util::HexBuf2StrBuf((PBYTE)ckCode, &strCkCode, 16);
  1067. LogWarn(Severity_Low, Error_Unexpect, PinPad_UserErrorCode_PinPad_CkCode_While_Load_SM, strCkCode);
  1068. BYTE ckMaster[16] = { 0 };
  1069. BYTE ckCodeMaster[128] = { 0 };
  1070. sm4_setkey_enc(&sm4Contxt, pCtMasterKey);
  1071. sm4_crypt_ecb(&sm4Contxt, SM4_ENCRYPT, 8, ckMaster, (BYTE*)ckCodeMaster);
  1072. char* strCkCodeMaster = new char[256];
  1073. memset(strCkCodeMaster, 0, 256);
  1074. SP::Module::Util::HexBuf2StrBuf((PBYTE)ckCodeMaster, &strCkCodeMaster, 16);
  1075. GetEntityBase()->GetFunction()->SetSysVar("ckCode", strCkCodeMaster, true);
  1076. delete[] pCtMasterKey;
  1077. delete[] pCtPinKey;
  1078. delete[] strCkCode;
  1079. delete[] strCkCodeMaster;
  1080. }
  1081. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1082. eErr = m_hDevHelper->LoadWorkingKey(wkParam2);
  1083. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1084. if (eErr != Error_Succeed)
  1085. {
  1086. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_LoadKeysSM).setAPI("DevAdapter::LoadWorkingKey")
  1087. .setCostTime(m_ullEndTime - m_ullBeginTime).setResultCode("RTA2605")("加载工作密钥2(EDK)失败,eErr:%s", SpStrError(eErr));
  1088. ctx->Ans.result = 2;
  1089. SetErrPackage("LoadKeySM::LoadMasterKey 2", m_devSN, eErr, MEC_DEVAPI_EPP_LoadWorkingKey);
  1090. ctx->Answer(Error_Unexpect, AlarmDEC());
  1091. m_bLoadKey = false;
  1092. return 0;
  1093. }
  1094. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::LoadWorkingKey").setCostTime(m_ullEndTime - m_ullBeginTime)("Load working key2 suc.");
  1095. if (spConfig != NULL)
  1096. {
  1097. eErr = spConfig->WriteConfigValueInt("Load", "SM", 1);
  1098. if (eErr != Error_Succeed)
  1099. {
  1100. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_SYSTEM).setResultCode("RTA2613")("写密钥加载标识失败:%s", SpStrError(eErr));
  1101. LogWarn(Severity_Middle, Error_Unexpect, PinPad_UserErrorCode_Write_RunCfgFile_Failed, CSimpleStringA::Format("写密钥加载标识失败:%s", SpStrError(eErr)));
  1102. }
  1103. if (!ctx->Req.reserved3.IsNullOrEmpty())
  1104. {
  1105. if ((eErr = spConfig->WriteConfigValue("Load", "SN_SM", ctx->Req.reserved3)) != Error_Succeed)
  1106. {
  1107. DbgWithLink(LOG_LEVEL_ERROR, LOG_TYPE_SYSTEM).setResultCode("RTA2613")("写密钥序号失败:%s", SpStrError(eErr));
  1108. LogWarn(Severity_Middle, Error_Unexpect, PinPad_UserErrorCode_Write_RunCfgFile_Failed, CSimpleStringA::Format("写密钥序号失败:%s", SpStrError(eErr)));
  1109. }
  1110. m_keySNSM = ctx->Req.reserved3;
  1111. LogWarn(Severity_Low, Error_Unexpect, PinPad_UserErrorCode_PinPad_LoadKey_SMSN, m_keySNSM.GetData());
  1112. }
  1113. else
  1114. {
  1115. spConfig->WriteConfigValue("Load", "SN_SM", "");
  1116. m_keySNSM = "";
  1117. LogWarn(Severity_Low, Error_Unexpect, PinPad_UserErrorCode_PinPad_LoadKey_Clear_SMSN, "clear sm key sn");
  1118. }
  1119. }
  1120. m_bLoadKey = false;
  1121. m_bSMLoaded = true;
  1122. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_LoadKeysSM)("加载密钥成功");
  1123. ctx->Answer(Error_Succeed);
  1124. return 0;
  1125. }
  1126. int CPinPadFSM::EncryptSM(SpReqAnsContext<PinPadService_EncryptDataSM_Req, PinPadService_EncryptDataSM_Ans>::Pointer ctx)
  1127. {
  1128. if (!(ctx->Req.smflag == 1 || ctx->Req.smflag == 11))
  1129. {
  1130. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER)("密钥标识不支持,ctx->Req.smflag:%d", ctx->Req.smflag);
  1131. ctx->Answer(Error_Unexpect, PinPad_UserErrorCode_UnknownSMFlag);
  1132. return 0;
  1133. }
  1134. //set param
  1135. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1136. if (m_hDevHelper->SetParam(EPP_PT_SET_ENCRYPT_METHOD, EPP_ALGO_METHOD_SM4) != Error_Succeed
  1137. || m_hDevHelper->SetParam(EPP_PT_SET_ECB_CBC_MODE, EPP_ALGO_MODE_CBC) != Error_Succeed)
  1138. {
  1139. SetErrPackage("EncryptSM::SetParam", m_devSN, Error_Unexpect, MEC_DEVAPI_EPP_SetParam);
  1140. ctx->Answer(Error_Unexpect, AlarmDEC(IsInBusiness()));
  1141. m_bEncrypt = false;
  1142. return 0;
  1143. }
  1144. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1145. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1146. ErrorCodeEnum eErr = m_hDevHelper->ActiveWorkingKey(1, 1);
  1147. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1148. DbgToBeidou(ctx->link, "ActiveWorkingKey")();
  1149. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_EncryptDataSM).setCostTime(m_ullEndTime - m_ullBeginTime)("%s", SpStrError(eErr));
  1150. if (eErr != Error_Succeed)
  1151. {
  1152. SetErrPackage("EncryptSM::ActiveWorkingKey", m_devSN, eErr, MEC_DEVAPI_EPP_ActiveWorkingKey);
  1153. ctx->Answer(Error_Unexpect, AlarmDEC(IsInBusiness()));
  1154. m_bEncrypt = false;
  1155. return 0;
  1156. }
  1157. EnDecryptInfo srcData, dstData;
  1158. ZeroMemory(srcData.data, MAX_EN_DECRYPT_DATA_SIZE);
  1159. ZeroMemory(dstData.data, MAX_EN_DECRYPT_DATA_SIZE);
  1160. srcData.dwSize = strlen(ctx->Req.data);
  1161. memcpy(srcData.data, ctx->Req.data, srcData.dwSize);
  1162. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1163. eErr = m_hDevHelper->EncryptData(srcData, dstData);
  1164. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1165. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setAPI("DevAdapter::EncryptData").setCostTime(m_ullEndTime - m_ullBeginTime)("%s", SpStrError(eErr));
  1166. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_EncryptDataSM)("srcData.dwSize:%d,dstData.dwSize", srcData.dwSize, dstData.dwSize);
  1167. DbgToBeidou(ctx->link, "EncryptData")();
  1168. if (eErr != Error_Succeed)
  1169. {
  1170. SetErrPackage("EncryptSM::EncryptData", m_devSN, eErr, MEC_DEVAPI_EPP_EncryptData);
  1171. ctx->Answer(Error_Unexpect, AlarmDEC(IsInBusiness()));
  1172. m_bEncrypt = false;
  1173. return 0;
  1174. }
  1175. ctx->Ans.ciphertext = (char*)dstData.data;
  1176. m_bEncrypt = false;
  1177. ctx->Answer(Error_Succeed);
  1178. return 0;
  1179. }
  1180. ErrorCodeEnum CPinPadFSM::GetCheckCode(SpReqAnsContext<PinPadService_GetCheckCode_Req, PinPadService_GetCheckCode_Ans>::Pointer ctx)
  1181. {
  1182. ErrorCodeEnum eErr = Error_Unexpect;
  1183. bool bGetOK = true;
  1184. ctx->Ans.checkcode.Init(ctx->Req.mSN.GetCount());
  1185. ctx->Ans.index.Init(ctx->Req.mSN.GetCount());
  1186. for (int i = 0; i < ctx->Req.mSN.GetCount(); i++)
  1187. {
  1188. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("mSN:%d,wSN:%d,origData[%s]", ctx->Req.mSN[i], ctx->Req.wSN[i], m_devCheckData.GetData());
  1189. //set param
  1190. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1191. if (ctx->Req.mSN[i] == 1)
  1192. eErr = m_hDevHelper->SetParam(EPP_PT_SET_ENCRYPT_METHOD, EPP_ALGO_METHOD_SM4);
  1193. else
  1194. {
  1195. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetCheckCode).setResultCode("RTA260B")("mSN:%d", ctx->Req.mSN[i]);
  1196. ctx->Ans.checkcode[i] = "";
  1197. ctx->Ans.index[i] = "";
  1198. continue;
  1199. }
  1200. if (eErr == Error_Succeed)
  1201. eErr = m_hDevHelper->SetParam(EPP_PT_SET_ECB_CBC_MODE, EPP_ALGO_MODE_CBC);
  1202. else
  1203. {
  1204. SetErrPackage("GetCheckCode::SetParam", m_devSN, eErr, MEC_DEVAPI_EPP_SetParam);
  1205. AlarmDEC();
  1206. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode(PinPadService_LogCode_GetCheckCode).setAPI("DevAdapter::SetParam")
  1207. .setResultCode("RTA260B")("计算校验码时设置参数失败");
  1208. return Error_DevCommFailed;
  1209. }
  1210. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1211. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1212. eErr = m_hDevHelper->ActiveWorkingKey(ctx->Req.mSN[i], ctx->Req.wSN[i]);
  1213. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1214. if (eErr != Error_Succeed)
  1215. {
  1216. SetErrPackage("GetCheckCode::ActiveWorkingKey", m_devSN, eErr, MEC_DEVAPI_EPP_ActiveWorkingKey);
  1217. AlarmDEC();
  1218. ctx->Ans.checkcode[i] = "";
  1219. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM).setLogCode(PinPadService_LogCode_GetCheckCode).setResultCode("RTA260C")("计算校验码时激活工作密钥失败");
  1220. return Error_DevCommFailed;
  1221. }
  1222. else
  1223. {
  1224. EnDecryptInfo srcInfo, dstInfo;
  1225. memset(srcInfo.data, 0, MAX_EN_DECRYPT_DATA_SIZE);
  1226. memcpy(srcInfo.data, m_devCheckData, m_devCheckData.GetLength());
  1227. srcInfo.dwSize = m_devCheckData.GetLength();
  1228. memset(dstInfo.data, 0, MAX_EN_DECRYPT_DATA_SIZE);
  1229. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1230. eErr = m_hDevHelper->EncryptData(srcInfo, dstInfo);
  1231. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1232. if (eErr != Error_Succeed)
  1233. {
  1234. SetErrPackage("GetCheckCode::EncryptData", m_devSN, eErr, MEC_DEVAPI_EPP_EncryptData);
  1235. AlarmDEC();
  1236. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM).setLogCode(PinPadService_LogCode_GetCheckCode).setResultCode("RTA260D")("计算校验码时数据加密失败");
  1237. return Error_DevCommFailed;
  1238. }
  1239. ctx->Ans.checkcode[i] = (const char*)dstInfo.data;
  1240. if (ctx->Req.wSN[i] == 0)
  1241. ctx->Ans.index[i] = m_keySNSM;
  1242. }
  1243. DbgWithLink(LOG_LEVEL_INFO, ctx->link.checkEmpty() ? LOG_TYPE_SYSTEM : LOG_TYPE_USER).setLogCode("QLR040220610")("计算校验码成功");
  1244. }
  1245. ctx->Answer(Error_Succeed);
  1246. return Error_Succeed;
  1247. }
  1248. bool CPinPadFSM::GetDevInfo(DevCategoryInfo &devInfo)
  1249. {
  1250. if (!m_bOpened)
  1251. {
  1252. devInfo.eState = m_eDevState;
  1253. return false;
  1254. }
  1255. DevCategoryInfo info;
  1256. ZeroMemory(info.szModel, MAX_DEV_MODEL_LEN);
  1257. ZeroMemory(info.szType, MAX_DEV_TYPE_LEN);
  1258. ZeroMemory(info.szVendor, MAX_DEV_VENDOR_LEN);
  1259. m_ullBeginTime = SP::Module::Comm::RVCGetTickCount();
  1260. ErrorCodeEnum eErrDev = m_hDevHelper->GetDevCategory(info);
  1261. m_ullEndTime = SP::Module::Comm::RVCGetTickCount();
  1262. if (eErrDev == Error_Succeed)
  1263. {
  1264. m_szModel = info.szModel;
  1265. m_szType = info.szType;
  1266. m_szVendor = info.szVendor;
  1267. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM).setAPI("DevAdapter::GetDevCategory").setCostTime(m_ullEndTime - m_ullBeginTime)
  1268. ("model,%d,%s;type,%d,%s;vendor,%d,%s", strlen(devInfo.szModel), m_szModel.GetData(), strlen(devInfo.szType), m_szType.GetData(), strlen(devInfo.szVendor), m_szVendor.GetData());
  1269. }
  1270. else
  1271. {
  1272. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM).setAPI("DevAdapter::GetDevCategory").setResultCode("RTA2606").setCostTime(m_ullEndTime - m_ullBeginTime)("%s", SpStrError(eErrDev));
  1273. SetErrPackage("GetDevInfo::GetDevCategory", m_devSN, eErrDev, MEC_DEVAPI_EPP_GetDevCategory);
  1274. AlarmDEC();
  1275. m_szModel = "";
  1276. m_szType = "";
  1277. m_szVendor = "";
  1278. m_eDevState = DEVICE_STATUS_NOT_READY;
  1279. }
  1280. ZeroMemory(devInfo.szModel,MAX_DEV_MODEL_LEN);//CM=V2.0#PM=V1.0#MID=75500001#PID=12345678#FWID=V1234567#Vendor=nantian
  1281. ZeroMemory(devInfo.szType,MAX_DEV_TYPE_LEN);
  1282. ZeroMemory(devInfo.szVendor,MAX_DEV_VENDOR_LEN);
  1283. CSimpleStringA tmpModel("");
  1284. if (m_szModel.GetLength() > 1)
  1285. {
  1286. CSimpleStringA tmpAddStr("");
  1287. tmpAddStr = tmpAddStr + "Vendor=" + m_szVendor;
  1288. if (m_szModel[m_szModel.GetLength() - 1] == '#')
  1289. tmpModel = m_szModel + tmpAddStr;
  1290. else
  1291. tmpModel = m_szModel + "#" + tmpAddStr;
  1292. strncpy(devInfo.szModel, (const char*)tmpModel, tmpModel.GetLength());
  1293. }
  1294. if (m_szType.GetLength() > 1)
  1295. strncpy(devInfo.szType, (const char*)m_szType, m_szType.GetLength());
  1296. if (m_szVendor.GetLength() > 1)
  1297. strncpy(devInfo.szVendor, (const char*)m_szVendor, m_szVendor.GetLength());
  1298. devInfo.eState = m_eDevState;
  1299. return true;
  1300. }
  1301. void CPinPadFSM::SetInWhatPage(int iPageType)
  1302. {
  1303. m_iInWhatPage = iPageType;
  1304. return;//oilyang@20200319 去掉任意情况下可输入
  1305. }
  1306. void CPinPadFSM::SelfTest(EntityTestEnum eTestType,CSmartPointer<ITransactionContext> pTransactionContext)
  1307. {
  1308. if (m_eDevState == DEVICE_STATUS_NORMAL)
  1309. pTransactionContext->SendAnswer(Error_Succeed);
  1310. else if (m_eDevState == DEVICE_STATUS_NOT_READY)
  1311. pTransactionContext->SendAnswer(Error_NotInit);
  1312. else
  1313. pTransactionContext->SendAnswer(Error_InvalidState);
  1314. }
  1315. int CPinPadFSM::ProcFWBReConn()
  1316. {
  1317. if (m_hDevHelper != nullptr)
  1318. {
  1319. if (GetDevInitFlag())
  1320. {
  1321. m_bOpened = false;
  1322. m_hDevHelper->StopInput();
  1323. }
  1324. m_hDevHelper.TearDown();
  1325. }
  1326. return 0;
  1327. }