mainfrm.cpp 100 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562
  1. #include "stdafx2.h"
  2. #include "mainfrm.h"
  3. #include "guitask.h"
  4. #include "fileutil.h"
  5. #include "array.h"
  6. #include "iniutil.h"
  7. #include "EventCode.h"
  8. #include "import_libSysInit.h"
  9. #include "AccessAuthorization_client_g.h"
  10. using namespace AccessAuthorization;
  11. #include "UpgradeManager_client_g.h"
  12. using namespace UpgradeManager;
  13. #include "CardIssuer_client_g.h"
  14. using namespace CardIssuer;
  15. #include "MaterialMgrCnn.h"
  16. #include "mod_GuiConsole.h"
  17. LRESULT CAboutDlg::OnClose(UINT uMsg, WPARAM wParam, LPARAM lParam)
  18. {
  19. EndDialog(0);
  20. return 0;
  21. }
  22. void CAboutDlg::OnOK(UINT uNotifyCode, int nID, CWindow wndCtl)
  23. {
  24. char szY2KTime[64] = {};
  25. GetDlgItem(IDC_EDIT1).GetWindowTextA(szY2KTime, sizeof(szY2KTime));
  26. int nLen = strlen(szY2KTime);
  27. if (nLen == 0)
  28. return;
  29. DWORD nY2KTime(0);
  30. int nRet= sscanf_s(szY2KTime, "%X", &nY2KTime);
  31. if (nRet == 0)
  32. {
  33. MessageBox("invalid y2k time");
  34. return;
  35. }
  36. CSmallDateTime dtSysTime(nY2KTime);
  37. GetDlgItem(IDC_EDIT2).SetWindowTextA(dtSysTime.ToTimeString());
  38. }
  39. #include "MaintainWatcher_client_g.h"
  40. using namespace MaintainWatcher;
  41. void CAboutDlg::OnOK2(UINT uNotifyCode, int nID, CWindow wndCtl)
  42. {
  43. GetDlgItem(IDC_EDIT3).SetWindowTextA("");
  44. CDateTimePickerCtrl dt1;
  45. dt1.Attach(GetDlgItem(IDC_DATETIMEPICKER1));
  46. SYSTEMTIME st1 = {};
  47. dt1.GetSystemTime(&st1);
  48. CDateTimePickerCtrl dt2;
  49. dt2.Attach(GetDlgItem(IDC_DATETIMEPICKER2));
  50. SYSTEMTIME st2 = {};
  51. dt2.GetSystemTime(&st2);
  52. st1.wHour = st2.wHour;
  53. st1.wMinute = st2.wMinute;
  54. st1.wSecond = st2.wSecond;
  55. st1.wMilliseconds = st2.wMilliseconds;
  56. auto pEntity = m_pGUITask->GetEntity();
  57. CSmallDateTime dtQueryTime;
  58. dtQueryTime.FromSystemTime(st1);
  59. CBootInfo info = {};
  60. pEntity->GetFunction()->GetRebootInfo(dtQueryTime, info);
  61. CSimpleStringA str = CSimpleStringA::Format("start: %s, reboot: %s, ver: %s, reason: %d, reason count: %d, way: %d, way count: %d",
  62. (const char*)info.tmStart.ToTimeString(), (const char*)info.tmReboot.ToTimeString(), (const char*)info.InstallVersion.ToString(),
  63. info.eTriggerReason, info.wSameReasonTime, info.eWay, info.wSameWayTime);
  64. GetDlgItem(IDC_EDIT3).SetWindowTextA(str);
  65. //auto pEntity = m_pGUITask->GetEntity();
  66. MaintainCertificate_ClientBase *pClient = new MaintainCertificate_ClientBase(pEntity);
  67. auto rc = pClient->Connect();
  68. if (rc != Error_Succeed)
  69. {
  70. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("connect to MaintainWatcher entity fail: %d", rc);
  71. }
  72. else
  73. {
  74. MaintainCertificate_GetUserInfo_Req req = {};
  75. MaintainCertificate_GetUserInfo_Ans ans = {};
  76. rc = pClient->GetUserInfo(req, ans, 10000);
  77. if (rc != Error_Succeed)
  78. {
  79. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get userinfo fail from MaintainWatcher: %d", rc);
  80. pClient->SafeDelete();
  81. }
  82. else
  83. {
  84. // UserID=SP00000004;UserName=RVC0001;AuthorierID=SP00000001;AuthorizeTime=2014/8/13 18:46:29;RecommenderSAP=80274390;RecommenderOfficeID=274390;
  85. CSimpleStringA &str = ans.UserInfo;
  86. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get maintainer info: %s", (const char*)str);
  87. CSimpleStringA m_strUserID, m_strUserName, m_strAuthorizer, m_strAuthTime;
  88. auto arr = str.Split(';');
  89. for (int i = 0; i < arr.GetCount(); i++)
  90. {
  91. auto arr2 = arr[i].Split('=');
  92. if (arr2.GetCount() != 2)
  93. continue;
  94. if (arr2[0] == "UserID")
  95. m_strUserID = arr2[1];
  96. else if (arr2[0] == "UserName")
  97. m_strUserName = arr2[1];
  98. else if (arr2[0] == "AuthorierID")
  99. m_strAuthorizer = arr2[1];
  100. else if (arr2[0] == "AuthorizeTime")
  101. m_strAuthTime = arr2[1];
  102. }
  103. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("UserID=%s;UserName=%s;Authorizer=%s;AuthTime=%s",
  104. (const char*)m_strUserID,
  105. (const char*)m_strUserName,
  106. (const char*)m_strAuthorizer,
  107. (const char*)m_strAuthTime);
  108. pClient->GetFunction()->CloseSession();
  109. }
  110. pClient = NULL;
  111. }
  112. }
  113. void CAboutDlg::OnOK3(UINT uNotifyCode, int nID, CWindow wndCtl)
  114. {
  115. char szFile[256] = {};
  116. GetDlgItem(IDC_EDIT4).GetWindowTextA(szFile, sizeof(szFile));
  117. if (strlen(szFile) == 0)
  118. {
  119. MessageBoxA("请输入要验证签名的文件路径!");
  120. return;
  121. }
  122. auto pEntity = m_pGUITask->GetEntity();
  123. CSimpleStringA strErrMsg;
  124. auto rc = pEntity->GetFunction()->VerifySignature(szFile, strErrMsg);
  125. if (rc == Error_Succeed)
  126. MessageBoxA("签名验证通过!");
  127. else
  128. MessageBoxA(CSimpleStringA::Format("签名验证不通过:%s", (const char*)strErrMsg));
  129. }
  130. void CAboutDlg::OnOK4(UINT uNotifyCode, int nID, CWindow wndCtl)
  131. {
  132. auto pEntity = m_pGUITask->GetEntity();
  133. CSystemStaticInfo info;
  134. auto rc = pEntity->GetFunction()->GetSystemStaticInfo(info);
  135. if (rc != Error_Succeed)
  136. {
  137. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("GetSystemStaticInfo fail: %d", rc);
  138. return;
  139. }
  140. CSimpleStringA str = CSimpleStringA::Format("terminalno: %s, type: %s, site: %s, version: %s",
  141. (const char*)info.strTerminalID, (const char*)info.strMachineType,
  142. (const char*)info.strSite, (const char*)info.InstallVersion.ToString());
  143. GetDlgItem(IDC_EDIT3).SetWindowTextA(str);
  144. }
  145. LRESULT CAboutDlg::OnInitDialog(UINT uMsg, WPARAM wParam, LPARAM lParam)
  146. {
  147. CenterWindow();
  148. return 0;
  149. }
  150. LRESULT CLoginDlg::OnInitDialog(UINT uMsg, WPARAM wParam, LPARAM lParam)
  151. {
  152. CenterWindow();
  153. GetDlgItem(IDC_EditUser).SetFocus();
  154. return 0;
  155. }
  156. void CLoginDlg::OnOK(UINT uNotifyCode, int nID, CWindow wndCtl)
  157. {
  158. char szUserID[32] = {};
  159. GetDlgItem(IDC_EditUser).GetWindowTextA(szUserID, sizeof(szUserID));
  160. char szPassword[32] = {};
  161. GetDlgItem(IDC_EditPassword).GetWindowTextA(szPassword, sizeof(szPassword));
  162. EndDialog(nID);
  163. m_strUserID = szUserID;
  164. if (m_strUserID.Compare("admin") != 0)
  165. {
  166. if (m_strUserID.GetLength() == 8) // SAP用户
  167. m_strUserID = "SP" + m_strUserID;
  168. else
  169. m_strUserID = "SZ" + m_strUserID;
  170. }
  171. m_strPassword = szPassword;
  172. }
  173. void CLoginDlg::OnCancel(UINT uNotifyCode, int nID, CWindow wndCtl)
  174. {
  175. EndDialog(nID);
  176. m_strUserID = "";
  177. m_strPassword = "";
  178. }
  179. LRESULT CSysInfoView::OnInitDialog(UINT uMsg, WPARAM wParam, LPARAM lParam)
  180. {
  181. m_listView1 = GetDlgItem(IDC_VIEWLIST1);
  182. m_listView1.AddColumn("Item1", 0);
  183. m_listView1.AddColumn("Item2", 1);
  184. RECT rc = {};
  185. m_listView1.GetClientRect(&rc);
  186. m_listView1.SetColumnWidth(0, (rc.right-rc.left)*1/2);
  187. m_listView1.SetColumnWidth(1, LVSCW_AUTOSIZE_USEHEADER);
  188. return 0;
  189. }
  190. void CSysInfoView::OutputMsg(const char *pMsg)
  191. {
  192. ::PostMessage(GetTopLevelParent().m_hWnd, WM_SHOW_MSG, 0, (LPARAM) strdup(pMsg));
  193. }
  194. DWORD64 CSysInfoView::GetFolderSize(LPCTSTR szPath, DWORD *dwFiles, DWORD *dwFolders)
  195. {
  196. TCHAR szFileFilter[512];
  197. TCHAR szFilePath[512];
  198. HANDLE hFind = NULL;
  199. WIN32_FIND_DATA fileinfo;
  200. DWORD64 dwSize = 0;
  201. strcpy(szFilePath,szPath);
  202. strcat(szFilePath,"\\");
  203. strcpy(szFileFilter,szFilePath);
  204. strcat(szFileFilter,"*.*");
  205. hFind = FindFirstFile(szFileFilter,&fileinfo);
  206. if (hFind == INVALID_HANDLE_VALUE)
  207. return 0;
  208. do
  209. {
  210. if(fileinfo.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)
  211. {
  212. if (!strcmp(fileinfo.cFileName,".") || !strcmp(fileinfo.cFileName,".."))
  213. {
  214. //Do nothing for "." and ".." folders
  215. }
  216. else
  217. {
  218. TCHAR sztmp[512];
  219. strcpy(sztmp,szFilePath);
  220. strcat(sztmp,fileinfo.cFileName);
  221. dwSize = dwSize + GetFolderSize(sztmp, dwFiles, dwFolders);
  222. if(dwFolders != NULL)
  223. {
  224. ++(*dwFolders);
  225. }
  226. }
  227. }
  228. else if(dwFiles != NULL)
  229. {
  230. ++(*dwFiles);
  231. }
  232. dwSize += fileinfo.nFileSizeLow;
  233. }
  234. while(FindNextFile(hFind,&fileinfo));
  235. FindClose(hFind);
  236. return dwSize;
  237. }
  238. // 查看操作系统信息
  239. void CSysInfoView::OnViewOSInfo(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  240. {
  241. // 查询操作系统信息
  242. CSimpleStringA strResult = "操作系统信息:\r\n";
  243. // OS版本
  244. OSVERSIONINFO osvi;
  245. ZeroMemory(&osvi, sizeof(OSVERSIONINFO));
  246. osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
  247. GetVersionEx(&osvi);
  248. strResult = strResult + CSimpleStringA::Format(" 操作系统版本: %d.%d.%d\r\n", osvi.dwMajorVersion, osvi.dwMinorVersion, osvi.dwBuildNumber);
  249. // OS盘符
  250. _ULARGE_INTEGER lpFreeBytesAvailableToCaller = {}, lpTotalNumberOfBytes = {}, lpTotalNumberOfFreeBytes = {};
  251. char szRoot[4];
  252. DWORD dwAllDrives = GetLogicalDrives();
  253. if (dwAllDrives == 0)
  254. {
  255. LOG_TRACE("GetLogicalDrives() return 0");
  256. return ;
  257. }
  258. for(int i=0; i<26 && dwAllDrives > 0; i++)
  259. {
  260. bool bHasDrive = dwAllDrives & 0x1;
  261. dwAllDrives = dwAllDrives >> 1;
  262. if (!bHasDrive)
  263. continue;
  264. sprintf((char*)szRoot,"%c:\\", i+'A');
  265. if(GetDriveType(szRoot) == DRIVE_FIXED)
  266. {
  267. GetDiskFreeSpaceEx(szRoot, &lpFreeBytesAvailableToCaller, &lpTotalNumberOfBytes, &lpTotalNumberOfFreeBytes);
  268. strResult += CSimpleStringA::Format(" %s 总容量:%8d MB,可用容量:%8d MB\r\n", (const char*)szRoot,
  269. (DWORD)(lpTotalNumberOfBytes.QuadPart / (1024 *1024)), (DWORD)(lpTotalNumberOfFreeBytes.QuadPart / (1024 *1024)));
  270. }
  271. }
  272. // 查询相关目录占用空间
  273. auto pEntity = m_pGUITask->GetEntity();
  274. CSimpleStringA strRootPath;
  275. pEntity->GetFunction()->GetPath("Root", strRootPath);
  276. DWORD nFileCount(0), nFolderCount(0);
  277. auto nTotalSize = GetFolderSize(strRootPath, &nFileCount, &nFolderCount);
  278. if (nTotalSize >0)
  279. {
  280. strResult += CSimpleStringA::Format(" 框架安装目录:{%s}, 共有 %d个文件,%d个子目录,占用磁盘空间:%.1f MB\r\n\r\n",
  281. (const char*)strRootPath, nFileCount, nFolderCount, (nTotalSize/(1024*1024.0)));
  282. }
  283. // 输出
  284. OutputMsg(strResult);
  285. }
  286. // 查看框架信息
  287. void CSysInfoView::OnViewFWInfo(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  288. {
  289. CSimpleStringA strResult = "终端基本信息:\r\n";
  290. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  291. CSystemStaticInfo staticInfo;
  292. auto rc = pFunc->GetSystemStaticInfo(staticInfo);
  293. if (rc == Error_Succeed)
  294. {
  295. CSimpleStringA strLightPacks ="";
  296. for(int i=0; i<staticInfo.LightPackInfos.GetCount(); i++)
  297. {
  298. if (i >0)
  299. strLightPacks += "、";
  300. strLightPacks += staticInfo.LightPackInfos[i].strPackName;
  301. }
  302. strResult += CSimpleStringA::Format(
  303. " 终端号码:{%s}\r\n"
  304. " 设备型号:{%s}\r\n"
  305. " 硬件版本:{%s}\r\n"
  306. " 登记地址:{%s}\r\n"
  307. " 定位信息:{%f, %f}\r\n"
  308. " 软件版本:{%s}\r\n"
  309. " 安装包名:{%s}\r\n"
  310. " 安装时间:{%s}\r\n"
  311. " 切换时间:{%s}\r\n"
  312. " 上次启动:{%s}\r\n"
  313. " 前一版本:{%s}\r\n"
  314. " 后一版本:{%s}\r\n"
  315. " 轻量安装:{%s}\r\n"
  316. " 运行次数:{%d}\r\n"
  317. " 当天次数:{%d}\r\n",
  318. (const char*)staticInfo.strTerminalID,
  319. (const char*)staticInfo.strMachineType,
  320. (const char*)staticInfo.MachineVersion.ToString(),
  321. (const char*)staticInfo.strEnrolAddr,
  322. staticInfo.EnrolGPS.GetLatitude(), staticInfo.EnrolGPS.GetLongitude(),
  323. (const char*)staticInfo.InstallVersion.ToString(),
  324. (const char*)staticInfo.InstallPack,
  325. (const char*)staticInfo.tmCreateDate.ToTimeString(),
  326. (const char*)staticInfo.tmSwithOverDate.ToTimeString(),
  327. (const char*)staticInfo.tmCurrentTime.ToTimeString(),
  328. (const char*)staticInfo.PreviousInstallVersion.ToString(),
  329. (const char*)staticInfo.LatterInstallVersion.ToString(),
  330. (const char*)strLightPacks,
  331. staticInfo.nTotalRunCount,
  332. staticInfo.nTodayRunCount);
  333. }
  334. CSystemRunInfo runInfo;
  335. rc = pFunc->GetSystemRunInfo(runInfo);
  336. if (rc == Error_Succeed)
  337. {
  338. CSimpleStringA strEntityList = "";
  339. for(int i=0; i<runInfo.strRunningEntityNames.GetCount(); i++)
  340. {
  341. if (i>0)
  342. strEntityList += "、";
  343. strEntityList += runInfo.strRunningEntityNames[i];
  344. }
  345. strResult += CSimpleStringA::Format(
  346. " 调试级别:{%d}\r\n"
  347. " 运行实体:{%s}\r\n",
  348. (int)runInfo.eDebugLevel,
  349. (const char*)strEntityList);
  350. }
  351. // 输出
  352. OutputMsg(strResult);
  353. }
  354. void CSysInfoView::ResetListAndButtons(const char *pszOpName, char *pszColName1, char *pszColName2,
  355. char *pszBtnName1, char *pszBtnName2, char *pszBtnName3, char *pszBtnName4)
  356. {
  357. m_strOpName = pszOpName;
  358. m_listView1.EnableWindow((pszColName1 != NULL || pszColName2 != NULL) ? TRUE : FALSE);
  359. m_listView1.DeleteAllItems();
  360. m_listView1.DeleteColumn(1);
  361. m_listView1.DeleteColumn(0);
  362. int nColCount = 0;
  363. if (pszColName1 != NULL)
  364. m_listView1.AddColumn(pszColName1, nColCount++);
  365. if (pszColName2 != NULL)
  366. m_listView1.AddColumn(pszColName2, nColCount++);
  367. if (nColCount >0)
  368. {
  369. RECT rc = {};
  370. m_listView1.GetClientRect(&rc);
  371. m_listView1.SetColumnWidth(0, (rc.right-rc.left-20)*1/nColCount);
  372. m_listView1.SetColumnWidth(1, (rc.right-rc.left-20)*1/nColCount);
  373. }
  374. CWindow button = GetDlgItem(IDC_VARBUTTON1);
  375. if (pszBtnName1 == NULL)
  376. {
  377. button.EnableWindow(FALSE);
  378. button.SetWindowTextA("动作1");
  379. }
  380. else
  381. {
  382. button.EnableWindow(TRUE);
  383. button.SetWindowTextA(pszBtnName1);
  384. }
  385. button = GetDlgItem(IDC_VARBUTTON2);
  386. if (pszBtnName2 == NULL)
  387. {
  388. button.EnableWindow(FALSE);
  389. button.SetWindowTextA("动作2");
  390. }
  391. else
  392. {
  393. button.EnableWindow(TRUE);
  394. button.SetWindowTextA(pszBtnName2);
  395. }
  396. button = GetDlgItem(IDC_VARBUTTON3);
  397. if (pszBtnName3 == NULL)
  398. {
  399. button.EnableWindow(FALSE);
  400. button.SetWindowTextA("动作3");
  401. }
  402. else
  403. {
  404. button.EnableWindow(TRUE);
  405. button.SetWindowTextA(pszBtnName3);
  406. }
  407. button = GetDlgItem(IDC_VARBUTTON4);
  408. if (pszBtnName4 == NULL)
  409. {
  410. button.EnableWindow(FALSE);
  411. button.SetWindowTextA("动作4");
  412. }
  413. else
  414. {
  415. button.EnableWindow(TRUE);
  416. button.SetWindowTextA(pszBtnName4);
  417. }
  418. }
  419. // 查看本地日志
  420. void CSysInfoView::OnViewSysLog(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  421. {
  422. ResetListAndButtons("ViewLog", "日志文件", "文件路径", "日志列表", "查看日志", NULL, NULL);
  423. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  424. CSimpleStringA strSysLogPath;
  425. pFunc->GetPath("SysLog", strSysLogPath);
  426. int nItemCount = 0;
  427. m_listView1.InsertItem( nItemCount, "SysLog\\");
  428. m_listView1.SetItemText(nItemCount, 1, strSysLogPath);
  429. nItemCount++;
  430. CSimpleStringA strDbgPath;
  431. pFunc->GetPath("Dbg", strDbgPath);
  432. auto pDbgDirList = fileutil_get_sub_dirs2_a(strDbgPath, 50);
  433. for (int i = 0; i < pDbgDirList->nelts; ++i)
  434. {
  435. char *pszDirName = ARRAY_IDX(pDbgDirList, i, char*);
  436. char *p = strrchr(pszDirName, '\\');
  437. if (p == NULL)
  438. p = pszDirName;
  439. else
  440. p++;
  441. char szName[128];
  442. sprintf(szName, "%s\\", p);
  443. m_listView1.InsertItem( nItemCount, szName);
  444. m_listView1.SetItemText(nItemCount, 1, pszDirName);
  445. nItemCount++;
  446. }
  447. toolkit_array_free2(pDbgDirList);
  448. }
  449. // 日志查看处理
  450. void CSysInfoView::OnViewLogSubCmd(int nID)
  451. {
  452. int nSelectedIndex = m_listView1.GetSelectedIndex();
  453. if (nSelectedIndex <0 || nSelectedIndex >= m_listView1.GetItemCount())
  454. return;
  455. if (nID == IDC_VARBUTTON1)
  456. {
  457. char szName[128] = {};
  458. m_listView1.GetItemText(nSelectedIndex, 0, szName, sizeof(szName));
  459. if (strncmp(szName, " |--", 5) == 0)
  460. {
  461. // 文件层
  462. OutputMsg("当前项非文件目录!\r\n");
  463. return;
  464. }
  465. //MessageBox(CSimpleStringA::Format("日志列表:%s", szName));
  466. // 判断文件夹文件是否已经显示
  467. char szNextName[128] = {};
  468. if (nSelectedIndex < m_listView1.GetItemCount()-1
  469. && m_listView1.GetItemText(nSelectedIndex+1, 0, szNextName, sizeof(szNextName)) >0
  470. && strncmp(szNextName, " |--", 5) == 0)
  471. {
  472. OutputMsg("目录文件已加载!\r\n");
  473. return;
  474. }
  475. char szFullPath[128] = {};
  476. m_listView1.GetItemText(nSelectedIndex, 1, szFullPath, sizeof(szFullPath));
  477. int nInsertIndex = nSelectedIndex + 1;
  478. auto pLogList = fileutil_get_sub_files2_a(szFullPath, 50);
  479. for (int i = 0; i < pLogList->nelts; ++i)
  480. {
  481. char *pszLogPath = ARRAY_IDX(pLogList, i, char*);
  482. char *p = strrchr(pszLogPath, '\\');
  483. if (p == NULL)
  484. p = pszLogPath;
  485. else
  486. p++;
  487. char szLogName[128];
  488. sprintf(szLogName, " |--%s", p);
  489. m_listView1.InsertItem( nInsertIndex, szLogName);
  490. m_listView1.SetItemText(nInsertIndex, 1, pszLogPath);
  491. nInsertIndex++;
  492. }
  493. toolkit_array_free2(pLogList);
  494. OutputMsg(CSimpleStringA::Format("目录[%s]共有%d个日志文件\r\n", szName, nInsertIndex - nSelectedIndex -1));
  495. }
  496. else
  497. {
  498. char szName[128] = {};
  499. m_listView1.GetItemText(nSelectedIndex, 0, szName, sizeof(szName));
  500. if (strncmp(szName, " |--", 5) != 0)
  501. {
  502. OutputMsg("当前非文件项!\r\n");
  503. return;
  504. }
  505. char szLogPath[128] = {};
  506. m_listView1.GetItemText(nSelectedIndex, 1, szLogPath, sizeof(szLogPath));
  507. OutputMsg(CSimpleStringA::Format("查看日志: %s\r\n", szLogPath));
  508. //system(CSimpleStringA::Format("notepad %s", szLogPath));
  509. ShellExecute(NULL,"open","NOTEPAD.EXE",szLogPath,NULL,SW_SHOWNORMAL);
  510. }
  511. }
  512. // 查看实体配置
  513. void CSysInfoView::OnViewEntityConfig(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  514. {
  515. ResetListAndButtons("ViewConfig", "实体名称", "配置类型", "查看配置", NULL, NULL, NULL);
  516. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  517. CAutoArray<CSimpleStringA> strEntityNames;
  518. CAutoArray<WORD> wEntityIDs;
  519. pFunc->GetAllRegistedEntity(strEntityNames, wEntityIDs);
  520. m_listView1.InsertItem(0, "Root");
  521. m_listView1.SetItemText(0, 1, "硬件配置");
  522. m_listView1.InsertItem(1, "Shell");
  523. m_listView1.SetItemText(1, 1, "软件配置");
  524. for(int i=0; i<strEntityNames.GetCount(); i++)
  525. {
  526. CSimpleStringA strEntityName = strEntityNames[i];
  527. for(int j=0; j<m_listView1.GetItemCount(); j++)
  528. {
  529. char szText[128] = {};
  530. m_listView1.GetItemText(j, 0, szText, sizeof(szText));
  531. if (stricmp(szText, strEntityName) >0)
  532. {
  533. m_listView1.InsertItem(j, strEntityName);
  534. m_listView1.SetItemText(j, 1, strEntityName=="CenterSetting"? "集中配置":"实体配置");
  535. break;
  536. }
  537. }
  538. }
  539. }
  540. // 实体配置查看处理
  541. void CSysInfoView::OnViewConfigSubCmd(int nID)
  542. {
  543. int nSelectedIndex = m_listView1.GetSelectedIndex();
  544. if (nSelectedIndex <0 || nSelectedIndex >= m_listView1.GetItemCount())
  545. return;
  546. char szEntityName[64];
  547. m_listView1.GetItemText(nSelectedIndex, 0, szEntityName, sizeof(szEntityName));
  548. CSimpleStringA strCfgPath;
  549. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  550. if (strcmp(szEntityName, "Root") == 0)
  551. {
  552. pFunc->GetPath("HardwareCfg", strCfgPath);
  553. }
  554. else
  555. {
  556. pFunc->GetPath("Cfg", strCfgPath);
  557. }
  558. strCfgPath += CSimpleStringA::Format("\\%s.ini", szEntityName);
  559. if (!ExistsFileA(strCfgPath))
  560. {
  561. OutputMsg(CSimpleStringA::Format("没有找到配置文件%s.ini\r\n", szEntityName));
  562. return;
  563. }
  564. OutputMsg(CSimpleStringA::Format("查看配置%s.ini\r\n", szEntityName));
  565. ShellExecute(NULL,"open","NOTEPAD.EXE",strCfgPath,NULL,SW_SHOWNORMAL);
  566. }
  567. // 查看升级日志
  568. void CSysInfoView::OnViewUpgradeConfig(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  569. {
  570. ResetListAndButtons("ViewUpgradeLog", "升级日志", "日志路径", "查看日志", NULL, NULL, NULL);
  571. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  572. CSimpleStringA strPath;
  573. pFunc->GetPath("RunInfo", strPath);
  574. strPath += "\\InstallLog";
  575. int nInsertIndex = 0;
  576. auto pLogList = fileutil_get_sub_files2_a(strPath, 50);
  577. for (int i = 0; i < pLogList->nelts; ++i)
  578. {
  579. char *pszLogPath = ARRAY_IDX(pLogList, i, char*);
  580. char *p = strrchr(pszLogPath, '\\');
  581. if (p == NULL)
  582. p = pszLogPath;
  583. else
  584. p++;
  585. m_listView1.InsertItem( nInsertIndex, p);
  586. m_listView1.SetItemText(nInsertIndex, 1, pszLogPath);
  587. nInsertIndex++;
  588. }
  589. toolkit_array_free2(pLogList);
  590. OutputMsg(CSimpleStringA::Format("共有%d个升级文件\r\n", nInsertIndex));
  591. }
  592. // 查看升级日志处理
  593. void CSysInfoView::OnViewUpgradeLogSubCmd(int nID)
  594. {
  595. int nSelectedIndex = m_listView1.GetSelectedIndex();
  596. if (nSelectedIndex <0 || nSelectedIndex >= m_listView1.GetItemCount())
  597. return;
  598. char szLogName[64];
  599. m_listView1.GetItemText(nSelectedIndex, 0, szLogName, sizeof(szLogName));
  600. char szLogPath[128];
  601. m_listView1.GetItemText(nSelectedIndex, 1, szLogPath, sizeof(szLogPath));
  602. OutputMsg(CSimpleStringA::Format("查看日志文件%s\r\n", szLogName));
  603. ShellExecute(NULL,"open","NOTEPAD.EXE",szLogPath,NULL,SW_SHOWNORMAL);
  604. }
  605. // 查看安装目录
  606. void CSysInfoView::OnViewInstallDir(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  607. {
  608. ResetListAndButtons("ViewInstallDir", "目录/文件", "文件属性", "返回上层", "查看目录", NULL, NULL);
  609. GetDlgItem(IDC_VARBUTTON1).EnableWindow(FALSE);
  610. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  611. CSimpleStringA strPath;
  612. pFunc->GetPath("RootVer", strPath);
  613. m_strCurViewDir = strPath;
  614. OnViewInstallDirSubCmd(IDC_VARBUTTON2);
  615. }
  616. // 查看升级日志处理
  617. void CSysInfoView::OnViewInstallDirSubCmd(int nID)
  618. {
  619. if (nID == IDC_VARBUTTON1)
  620. {
  621. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  622. CSimpleStringA strPath;
  623. pFunc->GetPath("RootVer", strPath);
  624. if (strPath == m_strCurViewDir)
  625. {
  626. OutputMsg("当前目录为根目录\r\n");
  627. return;
  628. }
  629. // 返回上层
  630. char szTmp[256] = {};
  631. strcpy(szTmp, m_strCurViewDir);
  632. char *p = strrchr(szTmp, '\\');
  633. if (p == NULL)
  634. return;
  635. *p = 0;
  636. m_strCurViewDir = szTmp;
  637. if (strPath == m_strCurViewDir)
  638. GetDlgItem(IDC_VARBUTTON1).EnableWindow(FALSE);
  639. }
  640. else if (nID = IDC_VARBUTTON2)
  641. {
  642. // 查看目录
  643. int nSelectedIndex = m_listView1.GetSelectedIndex();
  644. if (nSelectedIndex <0 && m_listView1.GetItemCount() >0)
  645. return;
  646. if (nSelectedIndex>=0)
  647. {
  648. char szDirName[64];
  649. m_listView1.GetItemText(nSelectedIndex, 0, szDirName, sizeof(szDirName));
  650. if (strncmp(szDirName, "[D]", 3) != 0)
  651. {
  652. OutputMsg(CSimpleStringA::Format("当前项不是目录: %sr\n", szDirName));
  653. return;
  654. }
  655. char *p = szDirName + 3;
  656. m_strCurViewDir += CSimpleStringA::Format("\\%s", p);
  657. GetDlgItem(IDC_VARBUTTON1).EnableWindow(TRUE);
  658. }
  659. }
  660. else
  661. {
  662. return;
  663. }
  664. // 显示当前目录项
  665. m_listView1.DeleteAllItems();
  666. int nIndex = 0;
  667. WIN32_FIND_DATAA fd = {};
  668. CSimpleStringA strFindDir = m_strCurViewDir + "\\*";
  669. HANDLE hFind = FindFirstFileA(strFindDir, &fd);
  670. if (hFind != INVALID_HANDLE_VALUE)
  671. {
  672. do
  673. {
  674. if (strcmp(fd.cFileName, ".") == 0 || strcmp(fd.cFileName, "..") == 0)
  675. continue;
  676. if (fd.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)
  677. {
  678. // 目录
  679. int j =0;
  680. for(; j<nIndex; j++)
  681. {
  682. char szTmp[64];
  683. m_listView1.GetItemText(j, 0, szTmp, sizeof(szTmp));
  684. if(strncmp(szTmp, "[D]", 3) != 0)
  685. break;
  686. }
  687. m_listView1.InsertItem(j, CSimpleStringA::Format("[D]%s", fd.cFileName));
  688. nIndex++;
  689. }
  690. else
  691. {
  692. // 文件
  693. m_listView1.InsertItem(nIndex, fd.cFileName);
  694. SYSTEMTIME st = {};
  695. FILETIME ft = {};
  696. FileTimeToLocalFileTime(&fd.ftLastWriteTime, &ft);
  697. FileTimeToSystemTime(&ft, &st);
  698. DWORD dwSize = fd.nFileSizeLow;
  699. CSimpleStringA strTemp = CSimpleStringA::Format("%.4d-%.2d-%.2d %.2d:%.2d:%.2d修改, %d字节",
  700. st.wYear, st.wMonth, st.wDay, st.wHour, st.wMinute, st.wSecond, dwSize);
  701. m_listView1.SetItemText(nIndex, 1, strTemp);
  702. nIndex++;
  703. }
  704. }
  705. while (FindNextFileA(hFind, &fd));
  706. FindClose(hFind);
  707. }
  708. else
  709. {
  710. OutputMsg("当前目录为空r\n");
  711. }
  712. }
  713. // 监控变量
  714. void CSysInfoView::OnViewSysVar(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  715. {
  716. ResetListAndButtons("ViewSysVar", "变量名称", "当前值", "手动刷新", "监控变量", "取消监控", NULL);
  717. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  718. CSimpleStringA strPath;
  719. pFunc->GetPath("Cfg", strPath);
  720. strPath += "\\shell.ini";
  721. auto arr = inifile_read_section_key_all(strPath, "SysEvent");
  722. for (int i = 0; i < arr->nelts; ++i)
  723. {
  724. char *pszVarName = ARRAY_IDX(arr, i, char*);
  725. m_listView1.InsertItem(i, pszVarName);
  726. CSimpleStringA strSysVar;
  727. pFunc->GetSysVar(pszVarName, strSysVar);
  728. m_listView1.SetItemText(i, 1, strSysVar);
  729. }
  730. toolkit_array_free2(arr);
  731. OutputMsg(CSimpleStringA::Format("共%d个系统变量\r\n", m_listView1.GetItemCount()));
  732. }
  733. void CSysInfoView::OnSysVarEvent(const char *pszKey, const char *pszValue,const char *pszOldValue,const char *pszEntityName)
  734. {
  735. for(int i=0; i<m_listView1.GetItemCount(); i++)
  736. {
  737. char szVarName[64];
  738. m_listView1.GetItemText(i, 0, szVarName, sizeof(szVarName));
  739. if (strcmp(pszKey, szVarName) ==0)
  740. {
  741. m_listView1.SetItemText(i, 1, pszValue);
  742. break;
  743. }
  744. }
  745. OutputMsg(CSimpleStringA::Format("[OnSysVarEvent] var: {%s}, old value: {%s}, new value: {%s}\r\n", pszKey, pszOldValue, pszValue));
  746. }
  747. // 查看变量处理
  748. void CSysInfoView::OnViewSysVarSubCmd(int nID)
  749. {
  750. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  751. if (nID == IDC_VARBUTTON1) // 手工刷新
  752. {
  753. for(int i=0; i<m_listView1.GetItemCount(); i++)
  754. {
  755. char szVarName[64] = {};
  756. m_listView1.GetItemText(i, 0, szVarName, sizeof(szVarName));
  757. CSimpleStringA strSysVar;
  758. pFunc->GetSysVar(szVarName, strSysVar);
  759. m_listView1.SetItemText(i, 1, strSysVar);
  760. }
  761. }
  762. else if(nID == IDC_VARBUTTON2) // 订阅当前变量
  763. {
  764. int nSelectedIndex = m_listView1.GetSelectedIndex();
  765. if (nSelectedIndex <0 || nSelectedIndex >= m_listView1.GetItemCount())
  766. return;
  767. char szVarName[64];
  768. m_listView1.GetItemText(nSelectedIndex, 0, szVarName, sizeof(szVarName));
  769. auto rc = pFunc->RegistSysVarEvent(szVarName, this);
  770. if (rc == Error_Succeed)
  771. {
  772. OutputMsg(CSimpleStringA::Format("监控系统变量(%s)成功\r\n", szVarName));
  773. }
  774. else
  775. {
  776. OutputMsg(CSimpleStringA::Format("监控系统变量(%s)失败: 0x%X\r\n", szVarName, rc));
  777. }
  778. }
  779. else if(nID == IDC_VARBUTTON3) // 取消订阅
  780. {
  781. int nSelectedIndex = m_listView1.GetSelectedIndex();
  782. if (nSelectedIndex <0 || nSelectedIndex >= m_listView1.GetItemCount())
  783. return;
  784. char szVarName[64];
  785. m_listView1.GetItemText(nSelectedIndex, 0, szVarName, sizeof(szVarName));
  786. auto rc = pFunc->UnregistSysVarEvent(szVarName);
  787. if (rc == Error_Succeed)
  788. {
  789. OutputMsg(CSimpleStringA::Format("取消监控系统变量(%s)成功\r\n", szVarName));
  790. }
  791. else
  792. {
  793. OutputMsg(CSimpleStringA::Format("取消监控系统变量(%s)失败: 0x%X\r\n", szVarName, rc));
  794. }
  795. }
  796. }
  797. // 监控实体日志
  798. void CSysInfoView::OnMonitorSysLog(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  799. {
  800. ResetListAndButtons("MonitorLog", "实体名称", "是否监控", "开始监控输出", "停止监控输出", "开始监控实体", "停止监控实体");
  801. if(m_pGUITask->HasSubscibeLog())
  802. {
  803. GetDlgItem(IDC_VARBUTTON1).EnableWindow(FALSE);
  804. GetDlgItem(IDC_VARBUTTON2).EnableWindow(TRUE);
  805. }
  806. else
  807. {
  808. GetDlgItem(IDC_VARBUTTON1).EnableWindow(TRUE);
  809. GetDlgItem(IDC_VARBUTTON2).EnableWindow(FALSE);
  810. }
  811. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  812. CAutoArray<CSimpleStringA> strEntityNames;
  813. CAutoArray<WORD> wEntityIDs;
  814. auto rc = pFunc->GetAllRegistedEntity(strEntityNames, wEntityIDs);
  815. int i=0;
  816. for(; i<strEntityNames.GetCount(); i++)
  817. {
  818. int j=0;
  819. for(; j<i; j++)
  820. {
  821. char szName[64] = {};
  822. m_listView1.GetItemText(j, 0, szName, sizeof(szName));
  823. if (stricmp(strEntityNames[i], szName) <0)
  824. break;
  825. }
  826. m_listView1.InsertItem(j, strEntityNames[i]);
  827. CEntityRunInfo info = {};
  828. pFunc->GetEntityRunInfo(strEntityNames[i], info);
  829. m_listView1.SetItemText(j, 1, info.eDebugLevel > 0 ? "Y" : "N");
  830. }
  831. OutputMsg(CSimpleStringA::Format("共%d个实体\r\n", i));
  832. }
  833. LRESULT CSysInfoView::OnListItemchanged(NMHDR* phdr)
  834. {
  835. NMLISTVIEW* pNMListView = (NMLISTVIEW*) phdr;
  836. if((pNMListView->uChanged==LVIF_STATE) && (pNMListView->uNewState & LVIS_SELECTED))
  837. {
  838. // 选中某项
  839. int nIndex = pNMListView->iItem;
  840. char szName[64] = {};
  841. m_listView1.GetItemText(nIndex, 0, szName, sizeof(szName));
  842. if (m_strOpName == "ViewLog") // 显示日志
  843. {
  844. if (strncmp(szName, " |--", 5) == 0)
  845. {
  846. GetDlgItem(IDC_VARBUTTON1).EnableWindow(FALSE);
  847. GetDlgItem(IDC_VARBUTTON2).EnableWindow(TRUE);
  848. }
  849. else
  850. {
  851. GetDlgItem(IDC_VARBUTTON1).EnableWindow(TRUE);
  852. GetDlgItem(IDC_VARBUTTON2).EnableWindow(FALSE);
  853. }
  854. }
  855. else if (m_strOpName == "ViewInstallDir") // 显示安装目录
  856. {
  857. if (strncmp(szName, "[D]", 3) == 0)
  858. GetDlgItem(IDC_VARBUTTON2).EnableWindow(TRUE);
  859. else
  860. GetDlgItem(IDC_VARBUTTON2).EnableWindow(FALSE);
  861. }
  862. else if (m_strOpName == "MonitorLog") // 监控日志
  863. {
  864. CEntityRunInfo info = {};
  865. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  866. pFunc->GetEntityRunInfo(szName, info);
  867. if (info.eDebugLevel >0)
  868. {
  869. GetDlgItem(IDC_VARBUTTON3).EnableWindow(FALSE);
  870. GetDlgItem(IDC_VARBUTTON4).EnableWindow(TRUE);
  871. }
  872. else
  873. {
  874. GetDlgItem(IDC_VARBUTTON3).EnableWindow(TRUE);
  875. GetDlgItem(IDC_VARBUTTON4).EnableWindow(FALSE);
  876. }
  877. }
  878. }
  879. return 0;
  880. }
  881. // 监控日志处理
  882. void CSysInfoView::OnMonitorLogSubCmd(int nID)
  883. {
  884. if (nID == IDC_VARBUTTON1) // 开始监控
  885. {
  886. auto rc = m_pGUITask->SubscribeLog();
  887. if (rc == Error_Succeed)
  888. {
  889. GetDlgItem(IDC_VARBUTTON1).EnableWindow(FALSE);
  890. GetDlgItem(IDC_VARBUTTON2).EnableWindow(TRUE);
  891. OutputMsg("开始监控日志成功\r\n");
  892. }
  893. else
  894. {
  895. OutputMsg(CSimpleStringA::Format("开始监控日志失败: 0x%X\r\n", rc));
  896. }
  897. }
  898. else if (nID == IDC_VARBUTTON2) // 停止监控
  899. {
  900. auto rc = m_pGUITask->UnSubscribeLog();
  901. if (rc == Error_Succeed)
  902. {
  903. GetDlgItem(IDC_VARBUTTON1).EnableWindow(TRUE);
  904. GetDlgItem(IDC_VARBUTTON2).EnableWindow(FALSE);
  905. OutputMsg("结束监控日志成功\r\n");
  906. }
  907. else
  908. {
  909. OutputMsg(CSimpleStringA::Format("结束监控日志失败: 0x%X\r\n", rc));
  910. }
  911. }
  912. else if (nID == IDC_VARBUTTON3) // 监控实体
  913. {
  914. int nSelected = m_listView1.GetSelectedIndex();
  915. if (nSelected <0)
  916. return;
  917. char szName[64] = {};
  918. m_listView1.GetItemText(nSelected, 0, szName, sizeof(szName));
  919. auto rc = m_pGUITask->SetDebugLevel(szName, 1);
  920. if (rc == Error_Succeed)
  921. {
  922. CEntityRunInfo info = {};
  923. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  924. pFunc->GetEntityRunInfo(szName, info);
  925. assert(info.eDebugLevel >0);
  926. m_listView1.SetItemText(nSelected, 1, "Y");
  927. GetDlgItem(IDC_VARBUTTON3).EnableWindow(FALSE);
  928. GetDlgItem(IDC_VARBUTTON4).EnableWindow(TRUE);
  929. OutputMsg(CSimpleStringA::Format("监控实体{%s}日志成功\r\n", szName));
  930. }
  931. else
  932. {
  933. OutputMsg(CSimpleStringA::Format("监控实体{%s}日志失败: 0x%X\r\n", szName, rc));
  934. }
  935. }
  936. else if (nID == IDC_VARBUTTON4) // 停止监控实体
  937. {
  938. int nSelected = m_listView1.GetSelectedIndex();
  939. if (nSelected <0)
  940. return;
  941. char szName[64] = {};
  942. m_listView1.GetItemText(nSelected, 0, szName, sizeof(szName));
  943. auto rc = m_pGUITask->SetDebugLevel(szName, 0);
  944. if (rc == Error_Succeed)
  945. {
  946. CEntityRunInfo info = {};
  947. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  948. pFunc->GetEntityRunInfo(szName, info);
  949. assert(info.eDebugLevel ==0);
  950. m_listView1.SetItemText(nSelected, 1, "N");
  951. GetDlgItem(IDC_VARBUTTON3).EnableWindow(TRUE);
  952. GetDlgItem(IDC_VARBUTTON4).EnableWindow(FALSE);
  953. OutputMsg(CSimpleStringA::Format("取消监控实体{%s}日志成功\r\n", szName));
  954. }
  955. else
  956. {
  957. OutputMsg(CSimpleStringA::Format("取消监控实体{%s}日志失败: 0x%X\r\n", szName, rc));
  958. }
  959. }
  960. }
  961. // 查看已下载文件
  962. void CSysInfoView::OnViewDownloadFile(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  963. {
  964. ResetListAndButtons("ViewDownload", "已下载文件", NULL, NULL, NULL, NULL, NULL);
  965. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  966. CSimpleStringA strPath;
  967. pFunc->GetPath("Downloads", strPath);
  968. auto pFileList = fileutil_get_sub_files2_a(strPath, 50);
  969. for (int i = 0; i < pFileList->nelts; ++i)
  970. {
  971. char *pszFileName = ARRAY_IDX(pFileList, i, char*);
  972. char *p = strrchr(pszFileName, '\\');
  973. if (p == NULL)
  974. p = pszFileName;
  975. else
  976. p++;
  977. m_listView1.InsertItem( i, p);
  978. }
  979. toolkit_array_free2(pFileList);
  980. }
  981. void CSysInfoView::OnVarButton(UINT /*uNotifyCode*/, int nID, CWindow /*wnd*/)
  982. {
  983. if (m_strOpName == "ViewLog")
  984. {
  985. OnViewLogSubCmd(nID);
  986. }
  987. else if (m_strOpName == "ViewConfig")
  988. {
  989. OnViewConfigSubCmd(nID);
  990. }
  991. else if (m_strOpName == "ViewUpgradeLog")
  992. {
  993. OnViewUpgradeLogSubCmd(nID);
  994. }
  995. else if (m_strOpName == "ViewInstallDir")
  996. {
  997. OnViewInstallDirSubCmd(nID);
  998. }
  999. else if (m_strOpName == "ViewSysVar")
  1000. {
  1001. OnViewSysVarSubCmd(nID);
  1002. }
  1003. else if (m_strOpName == "MonitorLog")
  1004. {
  1005. OnMonitorLogSubCmd(nID);
  1006. }
  1007. }
  1008. LRESULT CSysInitView::OnInitDialog(UINT uMsg, WPARAM wParam, LPARAM lParam)
  1009. {
  1010. DoDataExchange(FALSE);
  1011. InitMessage();
  1012. changeMessageFilter(TRUE);
  1013. InitRect();
  1014. InitWidget();
  1015. InitDll();
  1016. CheckSystemInit();
  1017. return 0;
  1018. }
  1019. void CSysInitView::InitRect()
  1020. {
  1021. CRect tempRect;
  1022. GetClientRect(tempRect);
  1023. m_systemInitBtnRect = CRect(tempRect.Width() / 3 - 55, tempRect.top + 25, tempRect.Width() / 3 + 55, tempRect.top + 40);
  1024. m_systemRetoreBtnRect = CRect(tempRect.Width() / 6 * 5 - 55, tempRect.top + 25, tempRect.Width() / 6 * 5 + 55, tempRect.top + 40);
  1025. m_accountConfigCheckRect = CRect(m_systemInitBtnRect.left - 165, m_systemInitBtnRect.bottom + 10
  1026. , m_systemInitBtnRect.left - 55, m_systemInitBtnRect.bottom + 30);
  1027. m_voiceConfigCheckRect = CRect(m_accountConfigCheckRect.right, m_systemInitBtnRect.bottom + 10
  1028. , m_accountConfigCheckRect.right + 110, m_systemInitBtnRect.bottom + 30);
  1029. m_closeWifiCheckRect = CRect(m_voiceConfigCheckRect.right, m_systemInitBtnRect.bottom + 10
  1030. , m_voiceConfigCheckRect.right + 110, m_systemInitBtnRect.bottom + 30);
  1031. m_closeAutoRotationCheckRect = CRect(m_closeWifiCheckRect.right, m_systemInitBtnRect.bottom + 10, m_closeWifiCheckRect.right + 110, m_systemInitBtnRect.bottom + 30);
  1032. m_defaultDixCheckRect = CRect(m_accountConfigCheckRect.left, m_accountConfigCheckRect.bottom + 5
  1033. , m_accountConfigCheckRect.right, m_accountConfigCheckRect.bottom + 25);
  1034. m_minDPICheckRect = CRect(m_voiceConfigCheckRect.left, m_voiceConfigCheckRect.bottom + 5
  1035. , m_voiceConfigCheckRect.right, m_voiceConfigCheckRect.bottom + 25);
  1036. m_systemMainIntiCheckRect = CRect(m_closeWifiCheckRect.left, m_closeWifiCheckRect.bottom + 5, m_closeWifiCheckRect.right, m_closeWifiCheckRect.bottom + 25);
  1037. m_systemMainRestoreCheckRect = CRect(m_systemRetoreBtnRect.left, m_systemRetoreBtnRect.bottom + 5, m_systemRetoreBtnRect.left + 110, m_systemRetoreBtnRect.bottom + 25);
  1038. m_initStaticRect = CRect(m_accountConfigCheckRect.left - 5, m_systemInitBtnRect.top - 17,
  1039. m_closeAutoRotationCheckRect.right + 5, m_systemMainIntiCheckRect.bottom + 5);
  1040. m_restoreStaticRect = CRect(m_systemRetoreBtnRect.left - 5, m_systemRetoreBtnRect.top - 17,
  1041. m_systemRetoreBtnRect.right + 5, m_systemMainRestoreCheckRect.bottom + 5);
  1042. m_msgListRect = CRect(10, m_systemMainIntiCheckRect.bottom + 10, tempRect.right - 10, tempRect.bottom - 10);
  1043. }
  1044. void CSysInitView::InitWidget()
  1045. {
  1046. m_systemInitBtn.MoveWindow(m_systemInitBtnRect);
  1047. m_systemRetoreBtn.MoveWindow(m_systemRetoreBtnRect);
  1048. m_accountConfigCheck.MoveWindow(&m_accountConfigCheckRect);
  1049. m_voiceConfigCheck.MoveWindow(&m_voiceConfigCheckRect);
  1050. m_closeWifiCheck.MoveWindow(&m_closeWifiCheckRect);
  1051. m_closeAutoRotationCheck.MoveWindow(&m_closeAutoRotationCheckRect);
  1052. m_systemMainIntiCheck.MoveWindow(&m_systemMainIntiCheckRect);
  1053. m_defaultDixCheck.MoveWindow(&m_defaultDixCheckRect);
  1054. m_minDPICheck.MoveWindow(&m_minDPICheckRect);
  1055. m_systemMainRestoreCheck.MoveWindow(&m_systemMainRestoreCheckRect);
  1056. m_msgList.MoveWindow(&m_msgListRect);
  1057. m_initStatic.MoveWindow(&m_initStaticRect);
  1058. m_restoreStatic.MoveWindow(&m_restoreStaticRect);
  1059. m_systemInitBtn.SetCheck(1);
  1060. m_systemMainRestoreCheck.SetCheck(1);
  1061. CRect m_rect;
  1062. GetClientRect(&m_rect); //获取对话框的大小
  1063. m_msgList.AddColumn(_T("初始化步骤"), 0);
  1064. m_msgList.AddColumn(_T("结果"), 1);
  1065. RECT rc = {};
  1066. m_msgList.GetClientRect(&rc);
  1067. m_msgList.SetColumnWidth(0, (rc.right-rc.left)* 15 / 20);
  1068. m_msgList.SetColumnWidth(1, LVSCW_AUTOSIZE_USEHEADER);
  1069. ListView_SetExtendedListViewStyle(m_msgList.m_hWnd, m_msgList.GetStyle() | LVS_EX_GRIDLINES);
  1070. }
  1071. void CSysInitView::InitDll()
  1072. {
  1073. CString dllPath =CString(_T("libSysInit.dll"));
  1074. m_dllWrc = LoadLibrary(dllPath);
  1075. RVCInit_SetLogPath = (RVCINIT_SETLOGPATH)GetProcAddress(m_dllWrc, RVCINITSETLOGPATH);
  1076. RVCInit_sysInitBegin = (RVCINIT_SYSINITBEGIN)GetProcAddress(m_dllWrc, RVCINITSYSINITBEGIN);
  1077. RVCInit_isSystemx64 = (RVCINIT_ISSYSTEMX64)GetProcAddress(m_dllWrc, RVCINITISSYSTEMX64);
  1078. RVCInit_sysTypeCheck = (RVCINIT_SYSTYPECHECK)GetProcAddress(m_dllWrc, RVCINITSYSTYPECHECK);
  1079. RVCInit_EnableAdmin = (RVCINIT_ENABLEADMIN)GetProcAddress(m_dllWrc, RVCINITENABLEADMIN);
  1080. RVCInit_RemoveOtherAccouts = (RVCINIT_REMOVEOTHERACCOUTS)GetProcAddress(m_dllWrc, RVCINITREMOVEOTHERACCOUTS);
  1081. RVCInit_AddCmbUser = (RVCINIT_ADDCMBUSER)GetProcAddress(m_dllWrc, RVCINITADDCMBUSER);
  1082. RVCInit_checkAccounts = (RVCINIT_CHECKACCOUNTS)GetProcAddress(m_dllWrc, RVCINITCHECKACCOUNTS);
  1083. RVCInit_VoiceConfigDefault = (RVCINIT_VOICECONFIGDEFAULT)GetProcAddress(m_dllWrc, RVCINITVOICECONFIGDEFAULT);
  1084. RVCInit_CheckVoiceDefault = (RVCINIT_CHECKVOICEDEFAULT)GetProcAddress(m_dllWrc, RVCINITCHECKVOICEDEFAULT);
  1085. RVCInit_CloseWifi = (RVCINIT_CLOSEWIFI)GetProcAddress(m_dllWrc, RVCINITCLOSEWIFI);
  1086. RVCInit_CheckWifi = (RVCINIT_CHECKWIFI)GetProcAddress(m_dllWrc, RVCINITCHECKWIFI);
  1087. RVCInit_CheckWifiExist = (RVCINIT_CHECKWIFIEXIST)GetProcAddress(m_dllWrc, RVCINITCHECKWIFIEXIST);
  1088. RVCInit_CloseAutoRotation = (RVCINIT_CLOSEAUTOROTATION)GetProcAddress(m_dllWrc, RVCINITCLOSEAUTOROTATION);
  1089. RVCInit_checkAutoRotation = (RVCINIT_CHECKAUTOROTATION)GetProcAddress(m_dllWrc, RVCINITCHECKAUTOROTATION);
  1090. RVCInit_setScreen = (RVCINIT_SETSCREEN)GetProcAddress(m_dllWrc, RVCINITSETSCREEN);
  1091. RVCInit_checkScreen = (RVCINIT_CHECKSCREEN)GetProcAddress(m_dllWrc, RVCINITCHECKSCREEN);
  1092. RVCInit_SetMinDPI = (RVCINIT_SETMINDPI)GetProcAddress(m_dllWrc, RVCINITSETMINDPI);
  1093. RVCInit_checkMinDPI = (RVCINIT_CHECKMINDPI)GetProcAddress(m_dllWrc, RVCINITCHECKMINDPI);
  1094. RVCInit_InitAdmin = (RVCINIT_INITADMIN)GetProcAddress(m_dllWrc, RVCINITINITADMIN);
  1095. RVCInit_InitCmbUser = (RVCINIT_INITCMBUSER)GetProcAddress(m_dllWrc, RVCINITINITCMBUSER);
  1096. RVCInit_checkMainInit = (RVCINIT_CHECKMAININIT)GetProcAddress(m_dllWrc, RVCINITCHECKMAININIT);
  1097. RVCInit_mainInit = (RVCINIT_MAININIT)GetProcAddress(m_dllWrc, RVCINITMAININIT);
  1098. RVCInit_endInit = (RVCINIT_ENDINIT)GetProcAddress(m_dllWrc, RVCINITENDINIT);
  1099. RVCInit_InitRestore = (RVCINIT_INITRESTORE)GetProcAddress(m_dllWrc, RVCINITINITRESTORE);
  1100. if (NULL == m_dllWrc || NULL == RVCInit_SetLogPath || NULL == RVCInit_sysInitBegin || NULL == RVCInit_EnableAdmin || NULL == RVCInit_RemoveOtherAccouts
  1101. || NULL == RVCInit_AddCmbUser || NULL == RVCInit_checkAccounts || NULL == RVCInit_VoiceConfigDefault || NULL == RVCInit_CheckVoiceDefault
  1102. || NULL == RVCInit_CloseWifi || NULL == RVCInit_CloseAutoRotation || NULL == RVCInit_checkAutoRotation || NULL == RVCInit_setScreen
  1103. || NULL == RVCInit_checkScreen || NULL == RVCInit_SetMinDPI || NULL == RVCInit_checkMinDPI || NULL == RVCInit_mainInit
  1104. || NULL == RVCInit_endInit || NULL == RVCInit_InitRestore || NULL == RVCInit_InitAdmin || NULL == RVCInit_InitCmbUser
  1105. || NULL == RVCInit_isSystemx64 || NULL == RVCInit_sysTypeCheck || NULL == RVCInit_checkMainInit || NULL == RVCInit_CheckWifi
  1106. || NULL == RVCInit_CheckWifiExist)
  1107. {
  1108. MessageBox(_T("加载libSysInit.dll失败,请检查文件"));
  1109. }
  1110. CSimpleStringA strDbgPath;
  1111. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  1112. pFunc->GetPath("Dbg", strDbgPath);
  1113. char logPath[300] = "";
  1114. sprintf(logPath, "%s\\SysInit", strDbgPath.GetData());
  1115. RVCInit_SetLogPath(logPath);
  1116. }
  1117. void CSysInitView::OutputMsg(const char *pMsg)
  1118. {
  1119. ::PostMessage(GetTopLevelParent().m_hWnd, WM_SHOW_MSG, 0, (LPARAM) strdup(pMsg));
  1120. }
  1121. void CSysInitView::AddMsgToListView(CString item, CString result)
  1122. {
  1123. m_msgList.InsertItem(nItemCount, item);
  1124. m_msgList.SetItemText(nItemCount, 1, result);
  1125. nItemCount++;
  1126. }
  1127. void CSysInitView::EasyAddMsgToListView(CString item, BOOL isSuccess)
  1128. {
  1129. AddMsgToListView(item, isSuccess ? _T("成功") : _T("失败"));
  1130. }
  1131. void CSysInitView::CleanListView()
  1132. {
  1133. m_msgList.DeleteAllItems();//清空上一次显示内容
  1134. nItemCount = 0;
  1135. }
  1136. void CSysInitView::CheckSystemInit()
  1137. {
  1138. int checkSysInit = 0;
  1139. if (1 == checkSysInit) {
  1140. CloseHandle((HANDLE)_beginthreadex(NULL, 0, (unsigned int(__stdcall*)(void*))SysInitCheck, this, 0, NULL));
  1141. }
  1142. }
  1143. void CSysInitView::modifyCheckStatus(DWORD status)
  1144. {
  1145. m_accountConfigCheck.SetCheck(1);
  1146. /*默认必须设置账户
  1147. if (ENABLE_ACCOUNT_CONFIG == (status & ENABLE_ACCOUNT_CONFIG))
  1148. m_accountConfigCheck.SetCheck(1);
  1149. else
  1150. m_accountConfigCheck.SetCheck(0);
  1151. */
  1152. if (ENABLE_VOICE_CONFIG == (status & ENABLE_VOICE_CONFIG))
  1153. m_voiceConfigCheck.SetCheck(1);
  1154. else
  1155. m_voiceConfigCheck.SetCheck(0);
  1156. if (ENABLE_CLOSE_WIFI == (status & ENABLE_CLOSE_WIFI))
  1157. m_closeWifiCheck.SetCheck(1);
  1158. else
  1159. m_closeWifiCheck.SetCheck(0);
  1160. if (ENABLE_CLOSE_ROTATION == (status & ENABLE_CLOSE_ROTATION))
  1161. m_closeAutoRotationCheck.SetCheck(1);
  1162. else
  1163. m_closeAutoRotationCheck.SetCheck(0);
  1164. if (ENABLE_DEFAULT_DIX == (status & ENABLE_DEFAULT_DIX))
  1165. m_defaultDixCheck.SetCheck(1);
  1166. else
  1167. m_defaultDixCheck.SetCheck(0);
  1168. if(ENABLE_MIN_DPI == (status & ENABLE_MIN_DPI))
  1169. m_minDPICheck.SetCheck(1);
  1170. else
  1171. m_minDPICheck.SetCheck(0);
  1172. if(ENABLE_MAIN_INIT == (status & ENABLE_MAIN_INIT))
  1173. m_systemMainIntiCheck.SetCheck(1);
  1174. else
  1175. m_systemMainIntiCheck.SetCheck(0);
  1176. }
  1177. DWORD SysInitCheck(LPVOID lpv)
  1178. {
  1179. CSysInitView *sysInit = (CSysInitView *)lpv;
  1180. DWORD result = 0;
  1181. if (RVCInit_checkAccounts())
  1182. sysInit->AddMsgToListView(_T("操作系统定制:检查账户状态"), _T("已定制"));
  1183. else
  1184. {
  1185. result |= ENABLE_ACCOUNT_CONFIG;
  1186. sysInit->AddMsgToListView(_T("操作系统定制:检查账户状态"), _T("未定制"));
  1187. }
  1188. if (RVCInit_CheckVoiceDefault())
  1189. sysInit->AddMsgToListView(_T("操作系统定制:检查声音配置"), _T("已定制"));
  1190. else
  1191. {
  1192. result |= ENABLE_VOICE_CONFIG;
  1193. sysInit->AddMsgToListView(_T("操作系统定制:检查声音配置"), _T("未定制"));
  1194. }
  1195. if (RVCInit_CheckWifiExist())
  1196. {
  1197. if (RVCInit_CheckWifi())
  1198. {
  1199. result |= ENABLE_CLOSE_WIFI;
  1200. sysInit->AddMsgToListView(_T("操作系统定制:检查是否关闭无线网卡"), _T("未定制"));
  1201. }
  1202. else
  1203. sysInit->AddMsgToListView(_T("操作系统定制:检查是否关闭无线网卡"), _T("已定制"));
  1204. }
  1205. else
  1206. sysInit->AddMsgToListView(_T("操作系统定制:未检测到无线网卡!!"), _T(""));
  1207. if (RVCInit_checkAutoRotation())
  1208. {
  1209. result |= ENABLE_CLOSE_ROTATION;
  1210. sysInit->AddMsgToListView(_T("操作系统定制:检查是否关闭自动旋转"), _T("未定制"));
  1211. }
  1212. else
  1213. sysInit->AddMsgToListView(_T("操作系统定制:检查是否关闭自动旋转"), _T("已定制"));
  1214. if (RVCInit_checkScreen(1920, 1080))
  1215. sysInit->AddMsgToListView(_T("操作系统定制:检查屏幕分辨率设置为1920*1080"), _T("已定制"));
  1216. else
  1217. {
  1218. result |= ENABLE_DEFAULT_DIX;
  1219. sysInit->AddMsgToListView(_T("操作系统定制:检查屏幕分辨率设置为1920*1080"), _T("未定制"));
  1220. }
  1221. TCHAR userName[256];
  1222. DWORD nameLen = 256;
  1223. if (!GetUserName(userName, &nameLen))
  1224. return FALSE;
  1225. CString showMsg;
  1226. showMsg.Format(_T("操作系统定制:检查当前账户%s设置为最小项目"), userName);
  1227. if (RVCInit_checkMinDPI(NULL, userName))
  1228. sysInit->AddMsgToListView(showMsg, _T("已定制"));
  1229. else
  1230. {
  1231. result |= ENABLE_MIN_DPI;
  1232. sysInit->AddMsgToListView(showMsg, _T("未定制"));
  1233. }
  1234. TCHAR errMsg[1024] = _T("");
  1235. if (RVCInit_checkMainInit(errMsg))
  1236. sysInit->AddMsgToListView(_T("操作系统定制:框架初始化"), _T("已定制"));
  1237. else
  1238. {
  1239. result |= ENABLE_MAIN_INIT;
  1240. sysInit->AddMsgToListView(errMsg, _T("未定制"));
  1241. }
  1242. sysInit->modifyCheckStatus(result);
  1243. if (ENABLE_NONE_CONFIG != result)
  1244. {
  1245. //检查失败,需要进行定制
  1246. ::PostMessage(sysInit->GetParent(), WM_CHECK_SYSINIT_FAIL, NULL, NULL);
  1247. sysInit->OutputMsg("检测到未完成系统定制,请先进行系统定制");
  1248. }
  1249. else
  1250. ::PostMessageA(sysInit->GetParent(), WM_CHECK_SYSINIT_SUCCESS, NULL, NULL);
  1251. return result;
  1252. }
  1253. BOOL CSysInitView::CheckThreadRunning()
  1254. {
  1255. DWORD initCode = 0, restoreCode = 0;
  1256. if (NULL == m_initThread && NULL == m_restoreThread)
  1257. return TRUE;
  1258. if (NULL != m_initThread) ::GetExitCodeThread(m_initThread, &initCode);
  1259. if (NULL != m_restoreThread) ::GetExitCodeThread(m_restoreThread, &restoreCode);
  1260. if (STILL_ACTIVE == initCode)
  1261. {
  1262. MessageBox(_T("正在进行系统定制,请不要重复点击"));
  1263. return FALSE;
  1264. }
  1265. else if (STILL_ACTIVE == restoreCode)
  1266. {
  1267. MessageBox(_T("正在进行系统定制还原,请不要重复点击"));
  1268. return FALSE;
  1269. }
  1270. return TRUE;
  1271. }
  1272. void CSysInitView::TestHighLevelDbg(
  1273. BOOL isShow, BOOL isHighLevel)
  1274. {
  1275. ::PostMessage(this->GetParent(), WM_SHOW_MAINTAIN_VIEW, isShow ? 1 : 0, isHighLevel ? 1 : 0);
  1276. }
  1277. DWORD SysInitBegin(LPVOID lpv)
  1278. {
  1279. CSysInitView *initDlg = (CSysInitView *)lpv;
  1280. initDlg->CleanListView();
  1281. CString showMsg;
  1282. TCHAR errMsg[1024] = _T("");
  1283. char rvcInitDir[1024] = "";
  1284. if (!getRvcInitDir(rvcInitDir))
  1285. return 0;
  1286. initDlg->AddMsgToListView(_T("正在进行文件拷贝..."), _T(""));
  1287. if (!RVCInit_sysInitBegin(rvcInitDir, errMsg))
  1288. {
  1289. initDlg->EasyAddMsgToListView(_T("操作系统定制初始化"), FALSE);
  1290. return 0;
  1291. }
  1292. else
  1293. {
  1294. initDlg->EasyAddMsgToListView(_T("Dll文件拷贝"), TRUE);
  1295. showMsg.Format(_T("当前操作系统版本为%d位"), RVCInit_isSystemx64() ? 64 : 32);
  1296. initDlg->AddMsgToListView(showMsg, _T(""));
  1297. }
  1298. if (1 == initDlg->m_accountConfigCheck.GetCheck())
  1299. {
  1300. showMsg.Format(_T("开启管理员账号"));
  1301. if (!RVCInit_EnableAdmin())
  1302. {
  1303. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1304. return 0;
  1305. }
  1306. else
  1307. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1308. showMsg.Format(_T("删除其他账户"));
  1309. if (!RVCInit_RemoveOtherAccouts())
  1310. {
  1311. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1312. return 0;
  1313. }
  1314. else
  1315. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1316. showMsg.Format(_T("创建CmbUser"));
  1317. if (!RVCInit_AddCmbUser())
  1318. {
  1319. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1320. return 0;
  1321. }
  1322. else
  1323. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1324. }
  1325. if (1 == initDlg->m_voiceConfigCheck.GetCheck())
  1326. {
  1327. showMsg.Format(_T("声音配置"));
  1328. if (!RVCInit_VoiceConfigDefault())
  1329. {
  1330. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1331. return 0;
  1332. }
  1333. else
  1334. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1335. }
  1336. if (1 == initDlg->m_closeWifiCheck.GetCheck())
  1337. {
  1338. if (RVCInit_CheckWifiExist())
  1339. {
  1340. if (!RVCInit_CloseWifi())
  1341. {
  1342. showMsg.Format(_T("未能禁用wifi,请检查是否存在无线网卡"));
  1343. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1344. return 0;
  1345. }
  1346. else
  1347. {
  1348. showMsg.Format(_T("禁用wifi"));
  1349. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1350. }
  1351. }
  1352. else
  1353. initDlg->AddMsgToListView(_T("未检测到无线网卡,未进行相关设置"), _T(""));
  1354. }
  1355. if (1 == initDlg->m_closeAutoRotationCheck.GetCheck())
  1356. {
  1357. showMsg.Format(_T("禁用自动旋转"));
  1358. if (PAD_LIB == RVCInit_sysTypeCheck() || PAD_FLB == RVCInit_sysTypeCheck())
  1359. {
  1360. if (!RVCInit_CloseAutoRotation())
  1361. {
  1362. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1363. return 0;
  1364. }
  1365. else
  1366. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1367. }
  1368. else
  1369. initDlg->AddMsgToListView(_T("检测到当前设备不是PAD,未能禁用自动旋转功能!"), _T(""));
  1370. }
  1371. if (1 == initDlg->m_defaultDixCheck.GetCheck())
  1372. {
  1373. showMsg.Format(_T("设置分辨率为1920*1080"));
  1374. if (!RVCInit_setScreen(1920, 1080))
  1375. {
  1376. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1377. return 0;
  1378. }
  1379. else
  1380. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1381. }
  1382. if (!RVCInit_checkAccounts())
  1383. {
  1384. initDlg->EasyAddMsgToListView(_T("检查到账户信息不正确,请先进行账户配置"), FALSE);
  1385. return 0;
  1386. }
  1387. if (!RVCInit_InitAdmin())
  1388. {
  1389. initDlg->EasyAddMsgToListView(_T("初始化Administrator用户"), FALSE);
  1390. return 0;
  1391. }
  1392. //等待explorer.exe初始化
  1393. Sleep(10 * 1000);
  1394. initDlg->EasyAddMsgToListView(_T("初始化Administrator用户"), TRUE);
  1395. if (1 == initDlg->m_minDPICheck.GetCheck())
  1396. {
  1397. showMsg.Format(_T("为Administrator设置为最小项目"));
  1398. if (!RVCInit_SetMinDPI(NULL, _T("Administrator")))
  1399. {
  1400. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1401. return 0;
  1402. }
  1403. else
  1404. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1405. }
  1406. if (!RVCInit_InitCmbUser())
  1407. {
  1408. initDlg->EasyAddMsgToListView(_T("初始化CmbUser用户"), FALSE);
  1409. return 0;
  1410. }
  1411. //等待explorer.exe初始化
  1412. Sleep(10 * 1000);
  1413. initDlg->EasyAddMsgToListView(_T("初始化CmbUser用户"), TRUE);
  1414. if (1 == initDlg->m_minDPICheck.GetCheck())
  1415. {
  1416. showMsg.Format(_T("为CmbUser设置为最小项目"));
  1417. if (!RVCInit_SetMinDPI(NULL, _T("CmbUser")))
  1418. {
  1419. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1420. return 0;
  1421. }
  1422. else
  1423. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1424. }
  1425. if (1 == initDlg->m_systemMainIntiCheck.GetCheck())
  1426. {
  1427. if (!RVCInit_mainInit(errMsg))
  1428. initDlg->EasyAddMsgToListView(errMsg, FALSE);
  1429. else
  1430. initDlg->EasyAddMsgToListView(_T("框架初始化"), TRUE);
  1431. }
  1432. if (!RVCInit_endInit())
  1433. initDlg->EasyAddMsgToListView(_T("释放资源"), FALSE);
  1434. initDlg->EasyAddMsgToListView(_T("系统定制初始化"), TRUE);
  1435. if (IDOK == MessageBox(NULL, _T("系统定制初始化完成,重启后功能生效(由于账户变化,若不重启可能会影响系统使用)。点击确认重启系统。"), _T("是否重启"), MB_OKCANCEL))
  1436. system("shutdown -f -r -t 00");
  1437. return 0;
  1438. }
  1439. DWORD SysRestoreBegin(LPVOID lpv)
  1440. {
  1441. CSysInitView *initDlg = (CSysInitView *)lpv;
  1442. initDlg->CleanListView();
  1443. CString showMsg;
  1444. showMsg.Format(_T("取消系统定制功能初始化"));
  1445. if (1 == initDlg->m_systemMainRestoreCheck.GetCheck())
  1446. {
  1447. if (!RVCInit_InitRestore())
  1448. initDlg->EasyAddMsgToListView(showMsg, FALSE);
  1449. else
  1450. {
  1451. initDlg->EasyAddMsgToListView(showMsg, TRUE);
  1452. if (IDOK == MessageBox(NULL, _T("已取消系统定制,点击确认重启系统。"), _T("是否重启"), MB_OKCANCEL))
  1453. system("shutdown -f -r -t 00");
  1454. }
  1455. }
  1456. return 0;
  1457. }
  1458. BOOL getRvcInitDir(char *dirPath)
  1459. {
  1460. char pathbuf[1024] = "";
  1461. int pathlen = ::GetModuleFileNameA(NULL, pathbuf, 1024);//获得GuiConsole路径
  1462. // 替换掉单杠
  1463. while (pathlen > 0)
  1464. {
  1465. if (pathbuf[pathlen--] == '\\')
  1466. break;
  1467. }
  1468. pathbuf[++pathlen] = '\0';
  1469. memcpy(dirPath, pathbuf, (pathlen + 1 > 1024 ? 1024 : pathlen + 1));
  1470. return pathlen;
  1471. }
  1472. LRESULT CSysInitView::OnBnClickedSystemInit(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1473. {
  1474. if (0 == m_accountConfigCheck.GetCheck() && 0 == m_voiceConfigCheck.GetCheck() && 0 == m_closeWifiCheck.GetCheck() && 0 == m_closeAutoRotationCheck.GetCheck()
  1475. && 0 == m_defaultDixCheck.GetCheck() && 0 == m_systemMainIntiCheck.GetCheck() && 0 == m_minDPICheck.GetCheck())
  1476. {
  1477. AddMsgToListView(_T("请选择需要初始化的部分"), _T(""));
  1478. return 0;
  1479. }
  1480. if (CheckThreadRunning())
  1481. m_initThread = (HANDLE)_beginthreadex(NULL, 0, (unsigned int (__stdcall *)(void *))SysInitBegin, this, 0, NULL);
  1482. return 0;
  1483. }
  1484. LRESULT CSysInitView::OnBnClickedSystemRestore(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1485. {
  1486. if (CheckThreadRunning())
  1487. if (IDOK == MessageBox("注意:只有框架初始化功能还原,其他功能不会还原。点击确认开始还原初始化。", "警告", MB_OKCANCEL))
  1488. m_restoreThread = (HANDLE)_beginthreadex(NULL, 0, (unsigned int (__stdcall *)(void *))SysRestoreBegin, this, 0, NULL);
  1489. return 0;
  1490. }
  1491. LRESULT CControlView::OnInitDialog(UINT uMsg, WPARAM wParam, LPARAM lParam)
  1492. {
  1493. CComboBox cbBox =(CComboBox) GetDlgItem(IDC_COMBO1);
  1494. cbBox.AddString("请选择物料类型");
  1495. cbBox.AddString("[DebitCard] 普通借记卡");
  1496. cbBox.AddString("[RetainCard] 吞卡登记");
  1497. //cbBox.AddString("[UKey] 专业版证书");
  1498. //cbBox.AddString("[Receipt] 回单打印卷纸");
  1499. //cbBox.AddString("[Paper] 文件打印纸");
  1500. //cbBox.AddString("[RFIDCard] 小额钱包卡");
  1501. cbBox.SetCurSel(0);
  1502. return 0;
  1503. }
  1504. // 通过健康实体重启Shell
  1505. void CControlView::OnRestartShell(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1506. {
  1507. LogEvent(Severity_Middle, EVENT_CONSOLE_REQ_RESTART_SHELL, "请求框架重启");
  1508. }
  1509. // 通过健康实体重启电源
  1510. void CControlView::OnRestartPower(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1511. {
  1512. LogEvent(Severity_Middle, EVENT_CONSOLE_REQ_RESTART_POWER, "请求电源重启");
  1513. }
  1514. // 通过健康实体关闭Shell
  1515. void CControlView::OnShutdownShell(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1516. {
  1517. LogEvent(Severity_Middle, EVENT_CONSOLE_REQ_SHUTDOWN_SHELL, "请求框架退出");
  1518. }
  1519. // 退出准入
  1520. void CControlView::OnExitAccessAuth(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1521. {
  1522. auto pEntity = m_pGUITask->GetEntity();
  1523. AccessAuthService_ClientBase *pClient = new AccessAuthService_ClientBase(pEntity);
  1524. auto rc = pClient->Connect();
  1525. if (rc == Error_Succeed)
  1526. {
  1527. AccessAuthService_Unregist_Info info = {};
  1528. info.nReason = 4;
  1529. info.nWay = 0;
  1530. rc = pClient->Unregist(info);
  1531. if (rc == Error_Succeed)
  1532. OutputMsg("请求退出准入成功\r\n");
  1533. else
  1534. OutputMsg(CSimpleStringA::Format("请求退出准入失败: 0x%X\r\n", rc));
  1535. pClient->GetFunction()->CloseSession();
  1536. }
  1537. else
  1538. {
  1539. OutputMsg(CSimpleStringA::Format("连接准入实体失败: 0x%X\r\n", rc));
  1540. pClient->SafeDelete();
  1541. }
  1542. }
  1543. // 重新准入
  1544. void CControlView::OnRestartAuth(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1545. {
  1546. auto pEntity = m_pGUITask->GetEntity();
  1547. AccessAuthService_ClientBase *pClient = new AccessAuthService_ClientBase(pEntity);
  1548. auto rc = pClient->Connect();
  1549. if (rc == Error_Succeed)
  1550. {
  1551. rc = pClient->Regist();
  1552. if (rc == Error_Succeed)
  1553. OutputMsg("请求重新准入成功\r\n");
  1554. else
  1555. OutputMsg(CSimpleStringA::Format("请求重新准入失败: 0x%X\r\n", rc));
  1556. pClient->GetFunction()->CloseSession();
  1557. }
  1558. else
  1559. {
  1560. OutputMsg(CSimpleStringA::Format("连接准入实体失败: 0x%X\r\n", rc));
  1561. pClient->SafeDelete();
  1562. }
  1563. }
  1564. // 物料维护
  1565. void CControlView::OnMaterialManager(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1566. {
  1567. GetDlgItem(IDC_STATIC1).ShowWindow(SW_SHOW);
  1568. GetDlgItem(IDC_STATIC2).ShowWindow(SW_SHOW);
  1569. GetDlgItem(IDC_COMBO1).ShowWindow(SW_SHOW);
  1570. }
  1571. void CControlView::OnSelectChanged(UINT uNotifyCode, int nID, CWindow wndCtl)
  1572. {
  1573. CComboBox cbBox =(CComboBox) GetDlgItem(IDC_COMBO1);
  1574. int nIndex = cbBox.GetCurSel();
  1575. if (nIndex == 0)
  1576. return;
  1577. // 显示相关控件
  1578. GetDlgItem(IDC_STATIC3).ShowWindow(SW_SHOW);
  1579. GetDlgItem(IDC_STATIC4).ShowWindow(SW_SHOW);
  1580. GetDlgItem(IDC_STATIC5).ShowWindow(SW_SHOW);
  1581. GetDlgItem(IDC_STATIC6).ShowWindow(SW_SHOW);
  1582. GetDlgItem(IDC_STATIC7).ShowWindow(SW_SHOW);
  1583. GetDlgItem(IDC_STATIC8).ShowWindow(SW_SHOW);
  1584. GetDlgItem(IDC_STATIC9).ShowWindow(SW_SHOW);
  1585. GetDlgItem(IDC_EDIT2).ShowWindow(SW_SHOW);
  1586. GetDlgItem(IDC_EDIT3).ShowWindow(SW_SHOW);
  1587. GetDlgItem(IDC_EDIT4).ShowWindow(SW_SHOW);
  1588. GetDlgItem(IDC_EDIT5).ShowWindow(SW_SHOW);
  1589. GetDlgItem(IDC_EDIT6).ShowWindow(SW_SHOW);
  1590. GetDlgItem(IDC_EDIT7).ShowWindow(SW_SHOW);
  1591. GetDlgItem(IDC_EDIT8).ShowWindow(SW_SHOW);
  1592. GetDlgItem(IDC_COMMITRESULT).ShowWindow(SW_SHOW);
  1593. GetDlgItem(IDC_CANCELCHECK).ShowWindow(SW_SHOW);
  1594. auto pEntity =(CGUIConsoleEntity*) m_pGUITask->GetEntity();
  1595. char szText[128] = {};
  1596. cbBox.GetLBText(nIndex, szText);
  1597. char *p = strchr(szText, ']');
  1598. if (p == NULL)
  1599. {
  1600. OutputMsg(CSimpleStringA::Format("无效设备名:%s\r\n", szText));
  1601. return;
  1602. };
  1603. *p = 0;
  1604. unsigned int nCapacity = 0;
  1605. unsigned int nBackEndCount = 0;
  1606. unsigned int nTerminalCount = 0;
  1607. unsigned int nRemainCount = 0;
  1608. CSimpleStringA strDevCode = &szText[1];
  1609. if (strDevCode == "DebitCard" || strDevCode == "RetainCard")
  1610. {
  1611. // 查询发卡器发卡计数\吞卡计数
  1612. GetDlgItem(IDC_EDIT4).SetWindowTextA("0");
  1613. CardIssuerService_ClientBase *pClient = new CardIssuerService_ClientBase(pEntity);
  1614. auto rc = pClient->Connect();
  1615. if (rc == Error_Succeed)
  1616. {
  1617. CardIssuerService_GetMaterialCount_Req req = {};
  1618. CardIssuerService_GetMaterialCount_Ans ret = {};
  1619. rc = pClient->GetMaterialCount(req, ret, 10000);
  1620. if (rc == Error_Succeed)
  1621. {
  1622. if (strDevCode == "DebitCard")
  1623. {
  1624. nTerminalCount = ret.issued;
  1625. nRemainCount = ret.remains;
  1626. GetDlgItem(IDC_EDIT4).SetWindowTextA(CSimpleStringA::Format("%d", nTerminalCount));
  1627. GetDlgItem(IDC_EDIT8).SetWindowTextA(CSimpleStringA::Format("%d", nRemainCount));
  1628. }
  1629. else if (strDevCode == "RetainCard")
  1630. {
  1631. nTerminalCount = ret.captured;
  1632. nRemainCount = ret.captured;
  1633. GetDlgItem(IDC_EDIT4).SetWindowTextA(CSimpleStringA::Format("%d", nRemainCount));
  1634. GetDlgItem(IDC_EDIT8).SetWindowTextA(CSimpleStringA::Format("%d", nRemainCount));
  1635. }
  1636. }
  1637. else
  1638. {
  1639. OutputMsg(CSimpleStringA::Format("调用发卡器实体失败:0x%X\r\n", rc));
  1640. }
  1641. pClient->GetFunction()->CloseSession();
  1642. }
  1643. else
  1644. {
  1645. OutputMsg(CSimpleStringA::Format("连接发卡器实体失败:0x%X\r\n", rc));
  1646. pClient->SafeDelete();
  1647. }
  1648. }
  1649. else
  1650. {
  1651. OutputMsg(CSimpleStringA::Format("暂不支持此设备:%s\r\n", (const char*)strDevCode));
  1652. return;
  1653. }
  1654. // 通讯取后台计数
  1655. GetDlgItem(IDC_EDIT2).SetWindowTextA("0"); // 放置数量
  1656. GetDlgItem(IDC_EDIT3).SetWindowTextA("0"); // 使用数量
  1657. CSystemStaticInfo staticInfo;
  1658. pEntity->GetFunction()->GetSystemStaticInfo(staticInfo);
  1659. CMaterialMgrCnn *pCnn = new CMaterialMgrCnn(pEntity);
  1660. if (pCnn->ConnectFromCentralSetting() && pCnn->IsConnectionOK())
  1661. {
  1662. auto rc = pCnn->GetMaterialCounter(strDevCode, staticInfo.strTerminalID, "", nCapacity, nBackEndCount);
  1663. if (rc == Error_Succeed)
  1664. {
  1665. GetDlgItem(IDC_EDIT2).SetWindowTextA(CSimpleStringA::Format("%d", nCapacity)); // 放置数量
  1666. GetDlgItem(IDC_EDIT3).SetWindowTextA(CSimpleStringA::Format("%d", nBackEndCount)); // 后台数量
  1667. }
  1668. else
  1669. OutputMsg(CSimpleStringA::Format("获取后台物料计数失败: 0x%X\r\n", rc));
  1670. pCnn->Close();
  1671. }
  1672. else
  1673. OutputMsg("连接物料管理服务失败\r\n");
  1674. pCnn->DecRefCount();
  1675. pCnn = NULL;
  1676. }
  1677. // 提交复核结果
  1678. void CControlView::OnCommitResult(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1679. {
  1680. auto pEntity =(CGUIConsoleEntity*) m_pGUITask->GetEntity();
  1681. CSystemStaticInfo staticInfo;
  1682. auto pFunc = pEntity->GetFunction();
  1683. pFunc->GetSystemStaticInfo(staticInfo);
  1684. CComboBox cbBox =(CComboBox) GetDlgItem(IDC_COMBO1);
  1685. char szText[32] = {};
  1686. cbBox.GetWindowTextA(szText, sizeof(szText));
  1687. char *p = strchr(szText, ']');
  1688. if (p == NULL)
  1689. {
  1690. MessageBox(CSimpleStringA::Format("无效设备名:%s\r\n", szText));
  1691. return;
  1692. };
  1693. *p = 0;
  1694. CSimpleStringA strMaterialCode = &szText[1];
  1695. CSimpleStringA strTerminalNo = staticInfo.strTerminalID;
  1696. // 判断计数是否不符
  1697. // 实际剩余
  1698. memset(szText, 0, sizeof(szText));
  1699. GetDlgItem(IDC_EDIT5).GetWindowTextA(szText, sizeof(szText));
  1700. if (strlen(szText) == 0)
  1701. {
  1702. MessageBoxA("请输入实际剩余数量");
  1703. return;
  1704. }
  1705. int nActRemainCount = atoi(szText);
  1706. // 终端剩余计数
  1707. memset(szText, 0, sizeof(szText));
  1708. GetDlgItem(IDC_EDIT8).GetWindowTextA(szText, sizeof(szText));
  1709. int nDevRemainCount = atoi(szText);
  1710. // 终端使用计数
  1711. memset(szText, 0, sizeof(szText));
  1712. GetDlgItem(IDC_EDIT4).GetWindowTextA(szText, sizeof(szText));
  1713. int nUsedCounter = atoi(szText);
  1714. // 重置数量
  1715. memset(szText, 0, sizeof(szText));
  1716. GetDlgItem(IDC_EDIT6).GetWindowTextA(szText, sizeof(szText));
  1717. if (strlen(szText) == 0)
  1718. {
  1719. MessageBoxA("请输入重置数量");
  1720. return;
  1721. }
  1722. int nResetCapacity = atoi(szText);
  1723. // 核对意见
  1724. char szComment[256] = {};
  1725. GetDlgItem(IDC_EDIT7).GetWindowTextA(szComment, sizeof(szComment));
  1726. if (nActRemainCount != nDevRemainCount && strlen(szComment)==0)
  1727. {
  1728. MessageBoxA("剩余计数不符,请输入不符原因");
  1729. return;
  1730. }
  1731. // 重置硬件计数
  1732. ErrorCodeEnum rc = Error_Succeed;
  1733. if (strMaterialCode == "DebitCard" || strMaterialCode == "RetainCard")
  1734. {
  1735. CardIssuerService_ClientBase *pClient = new CardIssuerService_ClientBase(pEntity);
  1736. rc = pClient->Connect();
  1737. if (rc == Error_Succeed)
  1738. {
  1739. CardIssuerService_SetMaterialCount_Req req = {};
  1740. if (strMaterialCode == "DebitCard")
  1741. {
  1742. req.bRemains = true;
  1743. req.remains = nResetCapacity;
  1744. req.bIssued = true;
  1745. req.issued = 0;
  1746. req.bMixed = true;
  1747. req.mixed = 0;
  1748. req.bCaptured = false;
  1749. }
  1750. else if (strMaterialCode == "RetainCard")
  1751. {
  1752. req.bCaptured = true;
  1753. req.captured = 0;
  1754. req.bRemains = false;
  1755. req.bIssued = false;
  1756. req.bMixed = false;
  1757. }
  1758. CardIssuerService_SetMaterialCount_Ans ret = {};
  1759. rc = pClient->SetMaterialCount(req, ret, 10000);
  1760. pClient->GetFunction()->CloseSession();
  1761. }
  1762. else
  1763. {
  1764. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("连接CardIssuer实体失败");
  1765. pClient->SafeDelete();
  1766. }
  1767. }
  1768. else
  1769. {
  1770. rc = Error_Unexpect;
  1771. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("未知物料: {%s}", (const char*)strMaterialCode);
  1772. }
  1773. if (rc != Error_Succeed)
  1774. {
  1775. MessageBoxA(CSimpleStringA::Format("重置终端计数失败(0x%X)", rc));
  1776. LogError(Severity_Middle, rc, 0, CSimpleStringA::Format("重置终端计数失败(0x%X)", rc));
  1777. return;
  1778. }
  1779. // 重置后台计数
  1780. CMaterialMgrCnn *pCnn = new CMaterialMgrCnn(pEntity);
  1781. if (pCnn->ConnectFromCentralSetting() && pCnn->IsConnectionOK())
  1782. {
  1783. auto rc = pCnn->ResetMaterialCounter(strMaterialCode, strTerminalNo, pEntity->GetCurMaintainer(), nResetCapacity, nUsedCounter, nActRemainCount, szComment);
  1784. pCnn->Close();
  1785. }
  1786. pCnn->DecRefCount();
  1787. pCnn = NULL;
  1788. if (rc == Error_Succeed)
  1789. {
  1790. ClearAndHideMaterialEditView();
  1791. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("重置物料{%s}计数成功", (const char*)strMaterialCode);
  1792. MessageBoxA("重置物料计数成功");
  1793. }
  1794. else
  1795. {
  1796. MessageBoxA(CSimpleStringA::Format("重置后端计数失败(0x%X)", rc));
  1797. LogError(Severity_Middle, rc, 0, CSimpleStringA::Format("重置后端计数失败(0x%X)", rc));
  1798. }
  1799. }
  1800. // 取消复核
  1801. void CControlView::OnCancelCheck(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1802. {
  1803. ClearAndHideMaterialEditView();
  1804. }
  1805. void CControlView::ClearAndHideMaterialEditView()
  1806. {
  1807. // 清空内容
  1808. GetDlgItem(IDC_EDIT2).SetWindowTextA("");
  1809. GetDlgItem(IDC_EDIT3).SetWindowTextA("");
  1810. GetDlgItem(IDC_EDIT4).SetWindowTextA("");
  1811. GetDlgItem(IDC_EDIT5).SetWindowTextA("");
  1812. GetDlgItem(IDC_EDIT6).SetWindowTextA("");
  1813. GetDlgItem(IDC_EDIT7).SetWindowTextA("");
  1814. GetDlgItem(IDC_EDIT8).SetWindowTextA("");
  1815. GetDlgItem(IDC_STATIC1).ShowWindow(SW_HIDE);
  1816. GetDlgItem(IDC_STATIC2).ShowWindow(SW_HIDE);
  1817. GetDlgItem(IDC_STATIC3).ShowWindow(SW_HIDE);
  1818. GetDlgItem(IDC_STATIC4).ShowWindow(SW_HIDE);
  1819. GetDlgItem(IDC_STATIC5).ShowWindow(SW_HIDE);
  1820. GetDlgItem(IDC_STATIC6).ShowWindow(SW_HIDE);
  1821. GetDlgItem(IDC_STATIC7).ShowWindow(SW_HIDE);
  1822. GetDlgItem(IDC_STATIC8).ShowWindow(SW_HIDE);
  1823. GetDlgItem(IDC_STATIC9).ShowWindow(SW_HIDE);
  1824. GetDlgItem(IDC_COMBO1).ShowWindow(SW_HIDE);
  1825. GetDlgItem(IDC_EDIT2).ShowWindow(SW_HIDE);
  1826. GetDlgItem(IDC_EDIT3).ShowWindow(SW_HIDE);
  1827. GetDlgItem(IDC_EDIT4).ShowWindow(SW_HIDE);
  1828. GetDlgItem(IDC_EDIT5).ShowWindow(SW_HIDE);
  1829. GetDlgItem(IDC_EDIT6).ShowWindow(SW_HIDE);
  1830. GetDlgItem(IDC_EDIT7).ShowWindow(SW_HIDE);
  1831. GetDlgItem(IDC_EDIT8).ShowWindow(SW_HIDE);
  1832. GetDlgItem(IDC_COMMITRESULT).ShowWindow(SW_HIDE);
  1833. GetDlgItem(IDC_CANCELCHECK).ShowWindow(SW_HIDE);
  1834. CComboBox cbBox =(CComboBox) GetDlgItem(IDC_COMBO1);
  1835. cbBox.SetCurSel(0);
  1836. }
  1837. void CControlView::OutputMsg(const char *pMsg)
  1838. {
  1839. ::PostMessage(GetTopLevelParent().m_hWnd, WM_SHOW_MSG, 0, (LPARAM) strdup(pMsg));
  1840. }
  1841. LRESULT CHighLevelView::OnInitDialog(UINT uMsg, WPARAM wParam, LPARAM lParam)
  1842. {
  1843. return 0;
  1844. }
  1845. // 手工升级
  1846. void CHighLevelView::OnManualUpgrade(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1847. {
  1848. // 选择升级文件
  1849. CFileDialog dlg(TRUE, ".zip", NULL, OFN_READONLY, "zip files\0*.zip\0all files\0*.*\0");
  1850. if (dlg.DoModal() == IDOK)
  1851. {
  1852. CSimpleStringA strPackPath = dlg.m_szFileName;
  1853. if (!strPackPath.IsEndWith(".zip"))
  1854. {
  1855. OutputMsg("升级包必须为zip压缩包\r\n");
  1856. return;
  1857. }
  1858. CSimpleStringA strPackName = strrchr(strPackPath, '\\') +1;
  1859. auto pEntity = m_pGUITask->GetEntity();
  1860. auto pFunc = pEntity->GetFunction();
  1861. CSimpleStringA strDownloadPath;
  1862. pFunc->GetPath("Downloads", strDownloadPath);
  1863. if (!strPackPath.IsStartWith(strDownloadPath))
  1864. {
  1865. strDownloadPath += strrchr(strPackPath, '\\');
  1866. if (CopyFileA(strPackPath, strDownloadPath, FALSE))
  1867. OutputMsg(CSimpleStringA::Format("拷贝升级包{%s}到下载目录成功\r\n", (const char*)strPackName));
  1868. else
  1869. {
  1870. OutputMsg(CSimpleStringA::Format("拷贝升级包{%s}到下载目录失败\r\n", (const char*)strPackName));
  1871. return;
  1872. }
  1873. }
  1874. // 调用升级实体手工升级
  1875. UpgradeMgrService_ClientBase *pClient = new UpgradeMgrService_ClientBase(pEntity);
  1876. auto rc = pClient->Connect();
  1877. if (rc == Error_Succeed)
  1878. {
  1879. UpgradeMgrService_RegistLocalPack_Req req = {};
  1880. UpgradeMgrService_RegistLocalPack_Ans ans = {};
  1881. req.strPackFile = strPackName;
  1882. rc = pClient->RegistLocalPack(req, ans, 10000);
  1883. if (rc == Error_Succeed)
  1884. OutputMsg(CSimpleStringA::Format("手工注册升级包{%s}成功\r\n", (const char*)strPackName));
  1885. else
  1886. OutputMsg(CSimpleStringA::Format("手工注册升级包{%s}失败: 0x%X\r\n", (const char*)strPackName, rc));
  1887. pClient->GetFunction()->CloseSession();
  1888. }
  1889. else
  1890. {
  1891. OutputMsg(CSimpleStringA::Format("连接升级实体失败: 0x%X\r\n", rc));
  1892. pClient->SafeDelete();
  1893. }
  1894. }
  1895. }
  1896. // 设置调试级别
  1897. void CHighLevelView::OnSetDebugLevel(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1898. {
  1899. auto pEntity = m_pGUITask->GetEntity();
  1900. auto pPrevFunc = pEntity->GetFunction()->GetPrivilegeFunction();
  1901. if (pPrevFunc == NULL)
  1902. {
  1903. OutputMsg("获取IEntityFunctionPrivilege接口失败\r\n");
  1904. return;
  1905. }
  1906. pPrevFunc->SetSysDebugLevel("SpShell", Debug_Middle, false);
  1907. OutputMsg("设置框架调试级别成功\r\n");
  1908. }
  1909. // 恢复调试级别
  1910. void CHighLevelView::OnResetDebugLevel(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1911. {
  1912. auto pEntity = m_pGUITask->GetEntity();
  1913. auto pPrevFunc = pEntity->GetFunction()->GetPrivilegeFunction();
  1914. if (pPrevFunc == NULL)
  1915. {
  1916. OutputMsg("获取IEntityFunctionPrivilege接口失败\r\n");
  1917. return;
  1918. }
  1919. pPrevFunc->SetSysDebugLevel("SpShell", Debug_None, false);
  1920. OutputMsg("恢复框架调试级别成功\r\n");
  1921. }
  1922. void CControlView::OnPrintConfig(UINT, int, CWindow)
  1923. {
  1924. char curPath[1024];
  1925. if (!getRvcInitDir(curPath))
  1926. return;
  1927. strcat(curPath, "\\RvcInit\\OtherTools\\printInstall\\PrintInstall.exe");
  1928. STARTUPINFO si = { sizeof(si) };
  1929. PROCESS_INFORMATION pi;
  1930. si.dwFlags = STARTF_USESHOWWINDOW;
  1931. si.wShowWindow = TRUE; //TRUE表示显示创建的进程的窗口
  1932. if (FALSE == ::CreateProcess(NULL, curPath, NULL, NULL, FALSE, CREATE_NEW_CONSOLE, NULL, NULL, &si, &pi))
  1933. {
  1934. char errMsg[1024];
  1935. sprintf(errMsg, "打开%s失败!", curPath);
  1936. MessageBoxA(errMsg);
  1937. }
  1938. }
  1939. void CControlView::OnCameraConfig(UINT, int, CWindow)
  1940. {
  1941. char curPath[1024];
  1942. if (!getRvcInitDir(curPath))
  1943. return;
  1944. strcat(curPath, "\\RvcInit\\OtherTools\\cameraInstall\\CameraInstall.exe");
  1945. STARTUPINFO si = { sizeof(si) };
  1946. PROCESS_INFORMATION pi;
  1947. si.dwFlags = STARTF_USESHOWWINDOW;
  1948. si.wShowWindow = TRUE; //TRUE表示显示创建的进程的窗口
  1949. if (FALSE == ::CreateProcess(NULL, curPath, NULL, NULL, FALSE, CREATE_NEW_CONSOLE, NULL, NULL, &si, &pi))
  1950. {
  1951. char errMsg[1024];
  1952. sprintf(errMsg, "打开%s失败!", curPath);
  1953. MessageBoxA(errMsg);
  1954. }
  1955. }
  1956. // 框架版本导回
  1957. void CHighLevelView::OnRollbackUpgrade(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1958. {
  1959. if (MessageBoxA("你确定要回滚框架版本至前一版本不?", "确认", MB_OKCANCEL) != IDOK)
  1960. return;
  1961. auto pEntity = m_pGUITask->GetEntity();
  1962. auto pPrevFunc = pEntity->GetFunction()->GetPrivilegeFunction();
  1963. if (pPrevFunc == NULL)
  1964. {
  1965. OutputMsg("获取IEntityFunctionPrivilege接口失败\r\n");
  1966. return;
  1967. }
  1968. auto rc = pPrevFunc->RollBackToPreviousVersion();
  1969. if (rc == Error_Succeed)
  1970. OutputMsg("导回框架版本成功,重启框架后生效\r\n");
  1971. else
  1972. OutputMsg(CSimpleStringA::Format("导回框架版本失败: 0x%X\r\n", rc));
  1973. }
  1974. // 终端注销
  1975. void CHighLevelView::OnUnregTerminal(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  1976. {
  1977. if (MessageBoxA("你确定要注销此终端吗?终端注销后,此终端将无法准入,不能进行联机处理!", "确认", MB_OKCANCEL) != IDOK)
  1978. return;
  1979. auto pEntity = m_pGUITask->GetEntity();
  1980. // 先退出准入
  1981. AccessAuthService_ClientBase *pClient = new AccessAuthService_ClientBase(pEntity);
  1982. auto rc = pClient->Connect();
  1983. if (rc == Error_Succeed)
  1984. {
  1985. AccessAuthService_Unregist_Info info = {};
  1986. info.nWay = 0;
  1987. info.nReason = 4;
  1988. rc = pClient->Unregist(info);
  1989. if (rc == Error_Succeed)
  1990. {
  1991. // 通知健康实体注销终端
  1992. LogEvent(Severity_Middle, EVENT_CONSOLE_REQ_UNREG_TERMINAL, "终端注销成功");
  1993. }
  1994. else
  1995. {
  1996. OutputMsg(CSimpleStringA::Format("终端准入退出失败: 0x%X\r\n", rc));
  1997. }
  1998. pClient->GetFunction()->CloseSession();
  1999. }
  2000. else
  2001. {
  2002. OutputMsg(CSimpleStringA::Format("连接准入实体失败: 0x%X\r\n", rc));
  2003. pClient->SafeDelete();
  2004. }
  2005. }
  2006. // 修改登记信息
  2007. void CHighLevelView::OnModifyEnrollInfo(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2008. {
  2009. GetDlgItem(IDC_GROUPINFO).ShowWindow(SW_SHOW);
  2010. GetDlgItem(IDC_LABELGPS).ShowWindow(SW_SHOW);
  2011. GetDlgItem(IDC_LABELADDR).ShowWindow(SW_SHOW);
  2012. GetDlgItem(IDC_EDITGPS).ShowWindow(SW_SHOW);
  2013. GetDlgItem(IDC_EDITADDR).ShowWindow(SW_SHOW);
  2014. GetDlgItem(IDC_MODENROLLINFO2).ShowWindow(SW_SHOW);
  2015. GetDlgItem(IDC_MODENROLLINFO3).ShowWindow(SW_SHOW);
  2016. // 取Root.ini信息
  2017. auto pFunc = m_pGUITask->GetEntity()->GetFunction();
  2018. CSmartPointer<IConfigInfo> pConfig;
  2019. auto rc = pFunc->OpenConfig(Config_Root, pConfig);
  2020. if (rc != Error_Succeed)
  2021. {
  2022. OutputMsg("读取硬件配置失败\r\n");
  2023. return;
  2024. }
  2025. CSimpleStringA strValue;
  2026. pConfig->ReadConfigValue("Terminal", "EnrolGPS", strValue);
  2027. if (strValue.GetLength() >0)
  2028. GetDlgItem(IDC_EDITGPS).SetWindowTextA(strValue);
  2029. pConfig->ReadConfigValue("Terminal", "EnrolAddr", strValue);
  2030. if (strValue.GetLength() >0)
  2031. GetDlgItem(IDC_EDITADDR).SetWindowTextA(strValue);
  2032. }
  2033. // 修改登记信息2
  2034. void CHighLevelView::OnModifyEnrollInfo2(UINT /*uNotifyCode*/, int nID, CWindow /*wnd*/)
  2035. {
  2036. GetDlgItem(IDC_GROUPINFO).ShowWindow(SW_HIDE);
  2037. GetDlgItem(IDC_LABELGPS).ShowWindow(SW_HIDE);
  2038. GetDlgItem(IDC_LABELADDR).ShowWindow(SW_HIDE);
  2039. GetDlgItem(IDC_EDITGPS).ShowWindow(SW_HIDE);
  2040. GetDlgItem(IDC_EDITADDR).ShowWindow(SW_HIDE);
  2041. GetDlgItem(IDC_MODENROLLINFO2).ShowWindow(SW_HIDE);
  2042. GetDlgItem(IDC_MODENROLLINFO3).ShowWindow(SW_HIDE);
  2043. if (nID != IDC_MODENROLLINFO2)
  2044. return;
  2045. char szAddr[256] = {};
  2046. char szGPS[64] = {};
  2047. GetDlgItem(IDC_EDITGPS).GetWindowTextA(szGPS, sizeof(szGPS));
  2048. GetDlgItem(IDC_EDITADDR).GetWindowTextA(szAddr, sizeof(szAddr));
  2049. // 检查GPS值是否合法
  2050. float f1 = 0;
  2051. float f2 = 0;
  2052. int nRet = sscanf(szGPS, "%f,%f", &f1, &f2);
  2053. if (nRet != 2)
  2054. {
  2055. OutputMsg(CSimpleStringA::Format("GPS座标值无效: {%s}\r\n", szGPS));
  2056. return;
  2057. }
  2058. OutputMsg("开始修改登记信息\r\n");
  2059. auto pEntity = m_pGUITask->GetEntity();
  2060. auto pFunc = pEntity->GetFunction();
  2061. // 修改Root.ini
  2062. CSimpleStringA strRootPath;
  2063. pFunc->GetPath("HardwareCfg", strRootPath);
  2064. strRootPath += "\\root.ini";
  2065. inifile_write_str(strRootPath, "Terminal", "EnrolAddr", szAddr);
  2066. inifile_format_write(strRootPath, "Terminal", "EnrolGPS", "\"%s\"", szGPS);
  2067. // 发送到中台
  2068. CMaterialMgrCnn *pCnn = new CMaterialMgrCnn(pEntity);
  2069. if (pCnn->ConnectFromCentralSetting() && pCnn->IsConnectionOK())
  2070. {
  2071. if (pCnn->ModifyEnrolInfo(NULL, NULL, szAddr, szGPS) != Error_Succeed)
  2072. OutputMsg("发送终端部署信息修改请求包失败\r\n");
  2073. else
  2074. OutputMsg("发送终端部署信息修改请求包成功\r\n");
  2075. pCnn->Close();
  2076. }
  2077. else
  2078. OutputMsg("连接物料管理服务失败\r\n");
  2079. pCnn->DecRefCount();
  2080. pCnn = NULL;
  2081. }
  2082. // 启动操作系统Shell
  2083. void CHighLevelView::OnStartOSShell(UINT /*uNotifyCode*/, int nID, CWindow /*wnd*/)
  2084. {
  2085. OutputMsg("启动操作系统Shell\r\n");
  2086. }
  2087. void CHighLevelView::OutputMsg(const char *pMsg)
  2088. {
  2089. ::PostMessage(GetTopLevelParent().m_hWnd, WM_SHOW_MSG, 0, (LPARAM) strdup(pMsg));
  2090. }
  2091. BOOL CMainFrame::PreTranslateMessage( MSG* pMsg )
  2092. {
  2093. if (WM_CHECK_SYSINIT_FAIL == pMsg->message)
  2094. {
  2095. if (FALSE == m_sysInitView.getPageShow())
  2096. {
  2097. m_tabView.AddPage(m_sysInitView, "操作系统定制");
  2098. m_sysInitView.SetPageShow(TRUE);
  2099. }
  2100. m_cansysInitRm = FALSE;
  2101. }
  2102. else if (WM_CHECK_SYSINIT_SUCCESS == pMsg->message)
  2103. m_cansysInitRm = TRUE;
  2104. return CFrameWindowImpl<CMainFrame>::PreTranslateMessage(pMsg);
  2105. }
  2106. BOOL CMainFrame::OnIdle()
  2107. {
  2108. // 控制Toolbar显示
  2109. if (m_tabView.GetActivePage() == 0)
  2110. {
  2111. ::ShowWindow(m_hWndToolBar, SW_SHOWNOACTIVATE);
  2112. UpdateLayout();
  2113. if (m_iSelectIdx != -1)
  2114. {
  2115. EntityEntry e = {};
  2116. auto rc = m_pConsole->GetEntity(GetSelectedEntityName(), e);
  2117. if (rc == Error_Succeed)
  2118. {
  2119. if (e.State == EntityState_NoStart || e.State == EntityState_Close || e.State == EntityState_Killed)
  2120. UIEnable(ID_START, TRUE);
  2121. else
  2122. UIEnable(ID_START, FALSE);
  2123. if (e.State >= EntityState_Idle && e.State <= EntityState_Pause)
  2124. UIEnable(ID_STOP, TRUE);
  2125. else
  2126. UIEnable(ID_STOP, FALSE);
  2127. if (e.State >= EntityState_Idle && e.State <= EntityState_Busy)
  2128. UIEnable(ID_PAUSE, TRUE);
  2129. else
  2130. UIEnable(ID_PAUSE, FALSE);
  2131. if (e.State == EntityState_Pause)
  2132. UIEnable(ID_CONTINUE, TRUE);
  2133. else
  2134. UIEnable(ID_CONTINUE, FALSE);
  2135. if (e.State >= EntityState_Starting && e.State <= EntityState_Close)
  2136. UIEnable(ID_KILL, TRUE);
  2137. else
  2138. UIEnable(ID_KILL, FALSE);
  2139. UIUpdateToolBar();
  2140. return FALSE;
  2141. }
  2142. }
  2143. UIEnable(ID_START, FALSE);
  2144. UIEnable(ID_STOP, FALSE);
  2145. UIEnable(ID_PAUSE, FALSE);
  2146. UIEnable(ID_CONTINUE, FALSE);
  2147. UIEnable(ID_KILL, FALSE);
  2148. UIUpdateToolBar();
  2149. return FALSE;
  2150. }
  2151. else
  2152. {
  2153. ::ShowWindow(m_hWndToolBar, SW_HIDE);
  2154. UpdateLayout();
  2155. return FALSE;
  2156. }
  2157. }
  2158. int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
  2159. {
  2160. CreateSimpleToolBar();
  2161. UIAddToolBar(m_hWndToolBar);
  2162. //CreateSimpleStatusBar();
  2163. m_hWndStatusBar = m_status.Create(m_hWnd, rcDefault, NULL, WS_VISIBLE|WS_CHILD);
  2164. int _parts[] = {400, -1};
  2165. m_status.SetParts(sizeof(_parts)/sizeof(_parts[0]), _parts);
  2166. RECT rc;
  2167. m_status.GetRect(0, &rc);
  2168. m_cmd.SetOwner(this);
  2169. m_cmd.Create(m_hWndStatusBar, &rc, NULL, WS_CHILD|WS_VISIBLE | ES_AUTOHSCROLL | ES_LEFT, WS_EX_STATICEDGE);
  2170. m_status.GetRect(1, &rc);
  2171. m_progressbar.Create(m_hWndStatusBar, &rc, NULL, WS_VISIBLE|WS_CHILD);
  2172. m_progressbar.SetRange(0, 100);
  2173. m_progressbar.SetStep(1);
  2174. m_progressbar.SetPos(0);
  2175. m_hWndClient = m_splitter.Create(m_hWnd, rcDefault, NULL, WS_CHILD | WS_VISIBLE | WS_CLIPSIBLINGS | WS_CLIPCHILDREN);
  2176. UpdateLayout();
  2177. // output
  2178. m_output.Create(m_splitter, rcDefault, NULL,
  2179. WS_CHILD|WS_VISIBLE|ES_AUTOVSCROLL|ES_LEFT|ES_MULTILINE|WS_VSCROLL, WS_EX_STATICEDGE);
  2180. m_output_font.CreateFont(12,0,0,0,FALSE,FALSE,FALSE,0,DEFAULT_CHARSET,
  2181. OUT_CHARACTER_PRECIS, CLIP_CHARACTER_PRECIS,DEFAULT_QUALITY, DEFAULT_PITCH,NULL);
  2182. m_output.SetFont(m_output_font);
  2183. m_wndOutput.SubclassWindow(m_output.m_hWnd);
  2184. CRect rect;
  2185. GetClientRect(rect);
  2186. m_splitter.SetSplitterPos(rect.Height()*3/5);
  2187. // TabView
  2188. m_tabView.Create(m_splitter, rcDefault, NULL, WS_CHILD | WS_VISIBLE | WS_CLIPSIBLINGS | WS_CLIPCHILDREN, WS_EX_CLIENTEDGE);
  2189. //m_tabView.SetTitleBarWindow(m_hWnd);
  2190. m_splitter.SetSplitterPanes(m_tabView, m_output);
  2191. m_verticalSplitter.Create(m_tabView, rcDefault, NULL, WS_CHILD | WS_VISIBLE | WS_CLIPSIBLINGS | WS_CLIPCHILDREN);
  2192. m_tabView.AddPage(m_verticalSplitter, "实体状态");
  2193. m_tabView.SetActivePage(0);
  2194. m_sysInitView.Create(m_tabView, rcDefault);
  2195. m_left_list.Create(m_verticalSplitter, rcDefault, NULL,
  2196. WS_CHILD | WS_VISIBLE | WS_CLIPSIBLINGS | WS_CLIPCHILDREN |
  2197. LVS_REPORT | LVS_AUTOARRANGE | LVS_SHOWSELALWAYS | LVS_SINGLESEL, 0, IDC_LIST1);
  2198. m_left_list.SetExtendedListViewStyle(LVS_EX_GRIDLINES | LVS_EX_FULLROWSELECT, 0);
  2199. m_right_list.Create(m_verticalSplitter, rcDefault, NULL,
  2200. WS_CHILD | WS_VISIBLE | WS_CLIPSIBLINGS | WS_CLIPCHILDREN |
  2201. LVS_REPORT | LVS_AUTOARRANGE | LVS_SHOWSELALWAYS | LVS_SINGLESEL, 0, IDC_LIST2);
  2202. m_right_list.SetExtendedListViewStyle(LVS_EX_GRIDLINES | LVS_EX_FULLROWSELECT, 0);
  2203. m_verticalSplitter.SetSplitterPos((rect.Width()-10)/2);
  2204. m_verticalSplitter.SetSplitterPanes(m_left_list, m_right_list);
  2205. LVCOLUMN col = {0};
  2206. col.mask = LVCF_FMT | LVCF_WIDTH | LVCF_TEXT;
  2207. col.fmt = LVCFMT_LEFT;
  2208. col.cx = 3*rect.Width() / 10-20;
  2209. col.pszText = _T("entity");
  2210. m_left_list.InsertColumn(0, &col);
  2211. m_right_list.InsertColumn(0, &col);
  2212. col.pszText = _T("type");
  2213. col.cx = 3*rect.Width() / 40-1;
  2214. m_left_list.InsertColumn(1, &col);
  2215. m_right_list.InsertColumn(1, &col);
  2216. col.pszText = _T("state");
  2217. col.cx = 3*rect.Width() / 40-1;
  2218. m_left_list.InsertColumn(2, &col);
  2219. m_right_list.InsertColumn(2, &col);
  2220. col.pszText = _T("pid");
  2221. col.cx = rect.Width() / 20-1;
  2222. m_left_list.InsertColumn(3, &col);
  2223. m_right_list.InsertColumn(3, &col);
  2224. CMessageLoop* pLoop = _Module.GetMessageLoop();
  2225. pLoop->AddMessageFilter(this);
  2226. pLoop->AddIdleHandler(this);
  2227. // load all entity
  2228. CAutoArray<EntityEntry> Entities;
  2229. m_pConsole->GetAllEntity(Entities);
  2230. // order by entity name
  2231. int arrOrderIndex[255] = {};
  2232. for(int i=0; i<Entities.GetCount(); i++)
  2233. {
  2234. int nIndex = 0;
  2235. for(int j=0; j<i; j++)
  2236. {
  2237. if (Entities[j].Name .Compare(Entities[i].Name) < 0)
  2238. nIndex++;
  2239. else
  2240. arrOrderIndex[j]++;
  2241. }
  2242. arrOrderIndex[i] = nIndex;
  2243. }
  2244. for (int i = 0; i < Entities.GetCount(); ++i)
  2245. {
  2246. int nIndex = 0;
  2247. for(; nIndex<Entities.GetCount(); nIndex++)
  2248. {
  2249. if (arrOrderIndex[nIndex] == i)
  2250. break;
  2251. }
  2252. LoadEntity(i, Entities[nIndex], Entities.GetCount());
  2253. }
  2254. // load start menu items
  2255. #if _DEBUG
  2256. CAutoArray<StartMenuEntry> StartMenus;
  2257. ErrorCodeEnum Error = m_pConsole->GetCustomizeStartMenuList(StartMenus);
  2258. if (Error == Error_Succeed && StartMenus.GetCount() > 0) {
  2259. CMenuHandle menuMain = GetMenu();
  2260. int i;
  2261. CMenuHandle menuStartList = menuMain.GetSubMenu(2);
  2262. if (menuStartList == NULL) {
  2263. menuStartList.CreatePopupMenu();
  2264. menuMain.AppendMenuA(MF_BYPOSITION, menuStartList, "&StartEntity");
  2265. }
  2266. for (i = 0; i < StartMenus.GetCount(); ++i) {
  2267. char content[512];
  2268. if (i < 9) {
  2269. wsprintfA(content, "%s %s\tctrl+%d", (LPCSTR)StartMenus[i].strEntity, (LPCSTR)StartMenus[i].strCmdLine, i+1);
  2270. } else {
  2271. wsprintfA(content, "%s %s", (LPCSTR)StartMenus[i].strEntity, (LPCSTR)StartMenus[i].strCmdLine);
  2272. }
  2273. menuStartList.AppendMenuA(MF_STRING, ID_STARTMENU_BEGIN+i, content);
  2274. }
  2275. }
  2276. #endif
  2277. ::AtlLoadAccelerators(MAKEINTRESOURCE(IDR_MAINFRAME));
  2278. m_pConsole->SubscribeLog();
  2279. // 标题显示版本和终端号
  2280. CSimpleStringA strInfo;
  2281. auto nRet = m_pConsole->GetFrameworkInfo(strInfo);
  2282. if (nRet == Error_Succeed)
  2283. {
  2284. char szBuf[256] = {};
  2285. GetWindowText(szBuf, 255);
  2286. SetWindowText(CSimpleStringA::Format("%s - %s", szBuf, strInfo));
  2287. }
  2288. CenterWindow();
  2289. #ifdef ALL_FUNCTION_SHOW
  2290. OnShowMaintainView(1, 1, 1);
  2291. OnShowMaintainView(1, 1, 1);
  2292. #endif
  2293. return 0;
  2294. }
  2295. void CMainFrame::OnSysCommand(UINT nID, CPoint point)
  2296. {
  2297. if (nID == SC_CLOSE || nID == SC_MINIMIZE)
  2298. {
  2299. SetMsgHandled(TRUE);
  2300. // bring back window
  2301. //SetWindowPos(HWND_BOTTOM, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE);
  2302. ShowWindow(SW_MINIMIZE);
  2303. }
  2304. else
  2305. SetMsgHandled(FALSE);
  2306. }
  2307. //LRESULT CMainFrame::OnClose(UINT uMsg, WPARAM wParam, LPARAM lParam)
  2308. //{
  2309. // if (wParam != -1 || lParam != -1) {
  2310. // //output_printf("cannot close self!\r\n");
  2311. // ShowWindow(SW_MINIMIZE);
  2312. // } else {
  2313. // SetMsgHandled(FALSE);
  2314. // }
  2315. // return 0;
  2316. //}
  2317. int CMainFrame::FindEntitylistItemIndex(int entity_id)
  2318. {
  2319. int i;
  2320. for (i = 0; i < m_left_list.GetItemCount(); ++i) {
  2321. int id = ((int)m_left_list.GetItemData(i)) >> 16;
  2322. if (id == entity_id)
  2323. return i*2;
  2324. }
  2325. for (i = 0; i < m_right_list.GetItemCount(); ++i) {
  2326. int id = ((int)m_right_list.GetItemData(i)) >> 16;
  2327. if (id == entity_id)
  2328. return i*2+1;
  2329. }
  2330. return -1;
  2331. }
  2332. int CMainFrame::FindEntitylistItemIndex(const char *entity_name)
  2333. {
  2334. int i;
  2335. for (i = 0; i < m_left_list.GetItemCount(); ++i) {
  2336. char str[128];
  2337. m_left_list.GetItemText(i, 0, str, sizeof(str));
  2338. char *p = strchr(str, ':');
  2339. if (p)
  2340. *p = 0;
  2341. if (_stricmp(entity_name, str) == 0)
  2342. return i*2;
  2343. }
  2344. for (i = 0; i < m_right_list.GetItemCount(); ++i) {
  2345. char str[128];
  2346. m_right_list.GetItemText(i, 0, str, sizeof(str));
  2347. char *p = strchr(str, ':');
  2348. if (p)
  2349. *p = 0;
  2350. if (_stricmp(entity_name, str) == 0)
  2351. return i*2+1;
  2352. }
  2353. return -1;
  2354. }
  2355. void CMainFrame::SetEntityState(int entity_id, int state, int pid)
  2356. {
  2357. int idx = FindEntitylistItemIndex(entity_id);
  2358. if (idx != -1) {
  2359. char tmp[16];
  2360. wsprintfA(tmp, "%d", pid);
  2361. if (idx & 1) {
  2362. m_right_list.SetItem((idx-1)/2, 2, LVIF_TEXT, (LPCSTR)EntityEntry::GetStateName(state), 0, 0, 0, NULL);
  2363. m_right_list.SetItem((idx-1)/2, 3, LVIF_TEXT, tmp, 0, 0, 0, NULL);
  2364. } else {
  2365. m_left_list.SetItem(idx/2, 2, LVIF_TEXT, (LPCSTR)EntityEntry::GetStateName(state), 0, 0, 0, NULL);
  2366. m_left_list.SetItem(idx/2, 3, LVIF_TEXT, tmp, 0, 0, 0, NULL);
  2367. }
  2368. }
  2369. }
  2370. void CMainFrame::SetEntityState(const char *entity_name, int state, int pid)
  2371. {
  2372. int idx = FindEntitylistItemIndex(entity_name);
  2373. if (idx != -1) {
  2374. char tmp[16];
  2375. wsprintfA(tmp, "%d", pid);
  2376. if (idx & 1) {
  2377. m_right_list.SetItem((idx-1)/2, 2, LVIF_TEXT, (LPCSTR)EntityEntry::GetStateName(state), 0, 0, 0, NULL);
  2378. m_right_list.SetItem((idx-1)/2, 3, LVIF_TEXT, tmp, 0, 0, 0, NULL);
  2379. } else {
  2380. m_left_list.SetItem(idx/2, 2, LVIF_TEXT, (LPCSTR)EntityEntry::GetStateName(state), 0, 0, 0, NULL);
  2381. m_left_list.SetItem(idx/2, 3, LVIF_TEXT, tmp, 0, 0, 0, NULL);
  2382. }
  2383. }
  2384. }
  2385. void CMainFrame::LoadEntity( int nIndex, EntityEntry &e, int nTotal)
  2386. {
  2387. char tmp[16];
  2388. wsprintfA(tmp, "%d", e.Pid);
  2389. CSimpleStringA strName = CSimpleStringA::Format("%s:%s", (LPCSTR)e.Name, (LPCSTR)e.ModuleName);
  2390. //if (idx & 1) {
  2391. if (nIndex >= (nTotal+1)/2) {
  2392. //idx = (idx-1)/2;
  2393. nIndex = nIndex - (nTotal+1)/2;
  2394. m_right_list.InsertItem(LVIF_PARAM|LVIF_TEXT, nIndex, (LPCSTR)strName, 0, 0, 0, (e.Id & 0xFFFF) << 16 | (e.DebugLevel & 0xFFFF));
  2395. m_right_list.AddItem(nIndex, 1, (LPCSTR)EntityEntry::GetTypeName(e.Type));
  2396. m_right_list.AddItem(nIndex, 2, (LPCSTR)EntityEntry::GetStateName(e.State));
  2397. m_right_list.AddItem(nIndex, 3, tmp);
  2398. } else {
  2399. //idx = idx / 2;
  2400. m_left_list.InsertItem(LVIF_PARAM|LVIF_TEXT, nIndex, (LPCSTR)strName, 0, 0, 0, (e.Id & 0xFFFF) << 16 | (e.DebugLevel & 0xFFFF));
  2401. m_left_list.AddItem(nIndex, 1, (LPCSTR)EntityEntry::GetTypeName(e.Type));
  2402. m_left_list.AddItem(nIndex, 2, (LPCSTR)EntityEntry::GetStateName(e.State));
  2403. m_left_list.AddItem(nIndex, 3, tmp);
  2404. }
  2405. }
  2406. void CMainFrame::OnStartEntityFinished(ErrorCodeEnum ErrorResult, const char *entity_name, void *pData)
  2407. {
  2408. if (ErrorResult == Error_Succeed) {
  2409. output_printf("start %s entity ok!\r\n", entity_name);
  2410. } else {
  2411. output_printf("start %s entity failed! Error = 0x%08X \r\n", entity_name, ErrorResult);
  2412. }
  2413. m_bOperationPending = FALSE;
  2414. KillTimer(0);
  2415. m_progressbar.SetPos(0);
  2416. }
  2417. void CMainFrame::OnStopEntityFinished(ErrorCodeEnum ErrorResult, const char *entity_name, void *pData)
  2418. {
  2419. if (ErrorResult == Error_Succeed) {
  2420. output_printf("stop %s entity ok!\r\n", entity_name);
  2421. } else {
  2422. output_printf("stop %s entity failed! Error = 0x%08X\r\n", entity_name, ErrorResult);
  2423. }
  2424. m_bOperationPending = FALSE;
  2425. KillTimer(0);
  2426. m_progressbar.SetPos(0);
  2427. }
  2428. void CMainFrame::OnPauseEntityFinished(ErrorCodeEnum ErrorResult, const char *entity_name, void *pData)
  2429. {
  2430. if (ErrorResult == Error_Succeed) {
  2431. output_printf("pause %s entity ok!\r\n", entity_name);
  2432. } else {
  2433. output_printf("pause %s entity failed! Error = 0x%08X\r\n", entity_name, ErrorResult);
  2434. }
  2435. m_bOperationPending = FALSE;
  2436. KillTimer(0);
  2437. m_progressbar.SetPos(0);
  2438. }
  2439. void CMainFrame::OnContinueEntityFinished(ErrorCodeEnum ErrorResult, const char *entity_name, void *pData)
  2440. {
  2441. if (ErrorResult == Error_Succeed) {
  2442. output_printf("continue %s entity ok!\r\n", entity_name);
  2443. } else {
  2444. output_printf("continue %s entity failed! Error = 0x%08X\r\n", entity_name, ErrorResult);
  2445. }
  2446. m_bOperationPending = FALSE;
  2447. KillTimer(0);
  2448. m_progressbar.SetPos(0);
  2449. }
  2450. void CMainFrame::OnTerminateEntityFinished(ErrorCodeEnum ErrorResult, const char *entity_name, void *pData)
  2451. {
  2452. if (ErrorResult == Error_Succeed) {
  2453. output_printf("terminate %s entity ok!\r\n", entity_name);
  2454. } else {
  2455. output_printf("terminate %s entity failed! Error = 0x%08X\r\n", entity_name, ErrorResult);
  2456. }
  2457. m_bOperationPending = FALSE;
  2458. KillTimer(0);
  2459. m_progressbar.SetPos(0);
  2460. }
  2461. void CMainFrame::OnEntityStateChanged(const char *entity_name, int new_state, int pid)
  2462. {
  2463. SetEntityState(entity_name, new_state, pid);
  2464. }
  2465. #define PREFIX_LEN 15
  2466. // [16:13:23.123]
  2467. void CMainFrame::output_printf(const char *fmt, ...)
  2468. {
  2469. int len;
  2470. va_list arg;
  2471. va_start(arg, fmt);
  2472. len = _vscprintf(fmt, arg);
  2473. if (len > 0) {
  2474. SYSTEMTIME st;
  2475. char *buf;
  2476. GetLocalTime(&st);
  2477. buf = (char*)malloc(PREFIX_LEN + len+1);
  2478. sprintf(buf, "[%02d:%02d:%02d.%03d] ", st.wHour, st.wMinute, st.wSecond, st.wMilliseconds);
  2479. vsprintf(buf+PREFIX_LEN, fmt, arg);
  2480. m_strOuput += buf;
  2481. m_nLineCount++;
  2482. // 检测最大长度
  2483. CheckOutputMaxLen();
  2484. if (!m_bVScrolling)
  2485. {
  2486. m_output.SetWindowText(m_strOuput);
  2487. //m_output.SetFocus();
  2488. //m_output.ShowCaret();
  2489. m_output.SetSel(m_strOuput.GetLength(), m_strOuput.GetLength());
  2490. m_output.LineScroll(-1);
  2491. }
  2492. free(buf);
  2493. }
  2494. va_end(arg);
  2495. }
  2496. void CMainFrame::CheckOutputMaxLen()
  2497. {
  2498. if (m_nLineCount > 200)
  2499. {
  2500. int count = 0;
  2501. int index = 0;
  2502. while(count < 50 && index < m_strOuput.GetLength())
  2503. {
  2504. index = m_strOuput.Find("\r\n", index);
  2505. if (index == -1)
  2506. break;
  2507. index += 2;
  2508. count++;
  2509. }
  2510. if (index >0 && index < m_strOuput.GetLength())
  2511. {
  2512. m_strOuput.Delete(0, index);
  2513. m_nLineCount -= count;
  2514. }
  2515. else
  2516. {
  2517. m_strOuput = "";
  2518. m_nLineCount = 0;
  2519. }
  2520. }
  2521. }
  2522. #undef PREFIX_LEN
  2523. LRESULT CMainFrame::OnShowMaintainView( UINT uMsg, WPARAM wParam, LPARAM lParam )
  2524. {
  2525. int nPageCount = m_tabView.GetPageCount();
  2526. bool bShowView = wParam == 1;
  2527. bool bHighLevel = lParam == 1;
  2528. int nCurPageIndex = m_tabView.GetActivePage();
  2529. int extendPage = m_sysInitView.getPageShow() ? 1 : 0;
  2530. if (!bShowView)
  2531. {
  2532. while (nPageCount > 1 + (m_cansysInitRm ? 0 : extendPage))
  2533. {
  2534. m_tabView.RemovePage(--nPageCount);
  2535. }
  2536. if (m_cansysInitRm)
  2537. {
  2538. m_sysInitView.SetPageShow(FALSE);
  2539. }
  2540. }
  2541. else
  2542. {
  2543. if (nPageCount == 1 + extendPage)
  2544. {
  2545. if (FALSE == m_sysInitView.getPageShow())
  2546. {
  2547. static BOOL firstTime = TRUE;
  2548. if (!firstTime)
  2549. m_sysInitView.Create(m_tabView, rcDefault);
  2550. else
  2551. firstTime = FALSE;
  2552. m_tabView.AddPage(m_sysInitView.m_hWnd, "操作系统定制");
  2553. m_sysInitView.SetPageShow(TRUE);
  2554. }
  2555. m_sysInfoView.Create(m_tabView);
  2556. m_tabView.AddPage(m_sysInfoView.m_hWnd, "信息浏览");
  2557. m_controlView.Create(m_tabView);
  2558. m_tabView.AddPage(m_controlView.m_hWnd, "常规维护");
  2559. }
  2560. else if (nPageCount == 3 + extendPage && bHighLevel)
  2561. {
  2562. m_highLevelView.Create(m_tabView);
  2563. m_tabView.AddPage(m_highLevelView.m_hWnd, "高级维护");
  2564. }
  2565. else if (nPageCount == 4 + extendPage && !bHighLevel)
  2566. {
  2567. m_tabView.RemovePage(4);
  2568. }
  2569. }
  2570. if (nCurPageIndex <m_tabView.GetPageCount())
  2571. m_tabView.SetActivePage(nCurPageIndex);
  2572. return 0;
  2573. }
  2574. LRESULT CMainFrame::OnShowBeginInitView( UINT uMsg, WPARAM wParam, LPARAM lParam )
  2575. {
  2576. bool bShowView = wParam == 1;
  2577. //初始化按钮显示,add by zl 20170227
  2578. CMenuHandle menuMain = GetMenu();
  2579. if (bShowView)
  2580. {
  2581. menuMain.EnableMenuItem(ID_FILE_INITIALIZE, MF_ENABLED);
  2582. }
  2583. else
  2584. {
  2585. menuMain.EnableMenuItem(ID_FILE_INITIALIZE, MF_GRAYED);
  2586. }
  2587. return 0;
  2588. }
  2589. LRESULT CMainFrame::OnShowMobileDialView( UINT uMsg, WPARAM wParam, LPARAM lParam )
  2590. {
  2591. bool bShowView = wParam == 1;
  2592. CMenuHandle menuMain = GetMenu();
  2593. if (bShowView) {
  2594. menuMain.EnableMenuItem(ID_SETTINGS_DIAL, MF_ENABLED);
  2595. }
  2596. else {
  2597. menuMain.EnableMenuItem(ID_SETTINGS_DIAL, MF_GRAYED);
  2598. }
  2599. return 0;
  2600. }
  2601. LRESULT CMainFrame::OnShowMsg( UINT uMsg, WPARAM wParam, LPARAM lParam )
  2602. {
  2603. char *pMsg = (char*)lParam;
  2604. output_printf(pMsg);
  2605. delete pMsg;
  2606. return 0;
  2607. }
  2608. LRESULT CMainFrame::OnGuiConsole( UINT uMsg, WPARAM wParam, LPARAM lParam )
  2609. {
  2610. callback_entry *entry = static_cast<callback_entry*>((void*)lParam);
  2611. LOG_ASSERT(entry);
  2612. switch (entry->op) {
  2613. case OP_START_ENTITY:
  2614. OnStartEntityFinished(entry->ErrorResult, entry->EntityName, entry->pRawData);
  2615. break;
  2616. case OP_STOP_ENTITY:
  2617. OnStopEntityFinished(entry->ErrorResult, entry->EntityName, entry->pRawData);
  2618. break;
  2619. case OP_PAUSE_ENTITY:
  2620. OnPauseEntityFinished(entry->ErrorResult, entry->EntityName, entry->pRawData);
  2621. break;
  2622. case OP_CONTINUE_ENTITY:
  2623. OnContinueEntityFinished(entry->ErrorResult, entry->EntityName, entry->pRawData);
  2624. break;
  2625. case OP_TERMINATE_ENTITY:
  2626. OnTerminateEntityFinished(entry->ErrorResult, entry->EntityName, entry->pRawData);
  2627. break;
  2628. case OP_FIRE_ENTITY_STATE:
  2629. OnEntityStateChanged(entry->EntityName, entry->state, wParam);
  2630. break;
  2631. default:
  2632. LOG_ASSERT(0);
  2633. break;
  2634. }
  2635. delete entry;
  2636. return 0;
  2637. }
  2638. LRESULT CMainFrame::OnListLeftItemchanged(NMHDR* phdr)
  2639. {
  2640. NMLISTVIEW* pnmlv = (NMLISTVIEW*) phdr;
  2641. m_iSelectIdx = m_left_list.GetSelectedIndex();
  2642. if (m_iSelectIdx != -1) {
  2643. m_iSelectIdx = m_iSelectIdx * 2;
  2644. }
  2645. return 0;
  2646. }
  2647. LRESULT CMainFrame::OnListRightItemchanged(NMHDR* phdr)
  2648. {
  2649. NMLISTVIEW* pnmlv = (NMLISTVIEW*) phdr;
  2650. m_iSelectIdx = m_right_list.GetSelectedIndex();
  2651. if (m_iSelectIdx != -1) {
  2652. m_iSelectIdx = m_iSelectIdx * 2+1;
  2653. }
  2654. return 0;
  2655. }
  2656. LRESULT CMainFrame::OnListLeftItemclicked(NMHDR* phdr)
  2657. {
  2658. m_iSelectIdx = m_left_list.GetSelectedIndex();
  2659. if (m_iSelectIdx != -1) {
  2660. m_iSelectIdx = m_iSelectIdx * 2;
  2661. }
  2662. return 0;
  2663. }
  2664. LRESULT CMainFrame::OnListRightItemclicked(NMHDR* phdr)
  2665. {
  2666. m_iSelectIdx = m_right_list.GetSelectedIndex();
  2667. if (m_iSelectIdx != -1) {
  2668. m_iSelectIdx = m_iSelectIdx * 2+1;
  2669. }
  2670. return 0;
  2671. }
  2672. void CMainFrame::OnTimer(UINT_PTR nIDEvent)
  2673. {
  2674. if (CSmallDateTime::GetNow() - m_OperationBeginTime >= 5)
  2675. {
  2676. output_printf("last operation timeout!\r\n");
  2677. m_bOperationPending = FALSE;
  2678. KillTimer(0);
  2679. m_progressbar.SetPos(0);
  2680. }
  2681. else
  2682. {
  2683. if (m_bOperationPending)
  2684. {
  2685. m_progressbar.StepIt();
  2686. }
  2687. }
  2688. }
  2689. void CMainFrame::OnVScroll(UINT nSBCode, UINT nPos, CScrollBar pScrollBar)
  2690. {
  2691. m_bVScrolling = (nSBCode != SB_ENDSCROLL);
  2692. if(!m_bVScrolling)
  2693. {
  2694. m_output.SetWindowText(m_strOuput);
  2695. m_output.SetFocus();
  2696. m_output.ShowCaret();
  2697. m_output.SetSel(m_strOuput.GetLength(), m_strOuput.GetLength());
  2698. m_output.LineScroll(-1);
  2699. }
  2700. SetMsgHandled(FALSE);
  2701. }
  2702. int CMainFrame::GetEntityDebugLevel(const char *pszEntity)
  2703. {
  2704. int nIndex = FindEntitylistItemIndex(pszEntity);
  2705. if (nIndex != -1)
  2706. {
  2707. if (nIndex & 1)
  2708. {
  2709. return ((int)m_right_list.GetItemData((nIndex-1)/2)) & 0xFFFF;
  2710. }
  2711. else
  2712. {
  2713. return ((int)m_left_list.GetItemData(nIndex/2)) & 0xFFFF;
  2714. }
  2715. }
  2716. return 0;
  2717. }
  2718. CSimpleStringA CMainFrame::GetSelectedEntityName()
  2719. {
  2720. if (m_iSelectIdx == -1)
  2721. return "";
  2722. char entity_name[80];
  2723. if (m_iSelectIdx & 1)
  2724. {
  2725. m_right_list.GetItemText((m_iSelectIdx-1)/2, 0, entity_name, sizeof(entity_name));
  2726. }
  2727. else
  2728. {
  2729. m_left_list.GetItemText(m_iSelectIdx/2, 0, entity_name, sizeof(entity_name));
  2730. }
  2731. char *p = strchr(entity_name, ':');
  2732. if (p)
  2733. *p=0;
  2734. return entity_name;
  2735. }
  2736. void CMainFrame::OnStart(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2737. {
  2738. if (m_iSelectIdx == -1)
  2739. return;
  2740. if (m_bOperationPending) {
  2741. output_printf("operation is doing now, please wait for a result!\r\n");
  2742. } else {
  2743. StartEntity(GetSelectedEntityName(), NULL);
  2744. }
  2745. }
  2746. void CMainFrame::OnStop(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2747. {
  2748. if (m_iSelectIdx == -1)
  2749. return;
  2750. if (m_bOperationPending) {
  2751. output_printf("operation is doing now, please wait for a result!\r\n");
  2752. } else {
  2753. StopEntity(GetSelectedEntityName());
  2754. }
  2755. }
  2756. void CMainFrame::OnPause(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2757. {
  2758. if (m_iSelectIdx == -1)
  2759. return;
  2760. if (m_bOperationPending) {
  2761. output_printf("operation is doing now, please wait for a result!\r\n");
  2762. } else {
  2763. PauseEntity(GetSelectedEntityName());
  2764. }
  2765. }
  2766. void CMainFrame::OnContinue(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2767. {
  2768. if (m_iSelectIdx == -1)
  2769. return;
  2770. if (m_bOperationPending) {
  2771. output_printf("operation is doing now, please wait for a result!\r\n");
  2772. } else {
  2773. ContinueEntity(GetSelectedEntityName());
  2774. }
  2775. }
  2776. void CMainFrame::OnKill(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2777. {
  2778. if (m_iSelectIdx == -1)
  2779. return;
  2780. if (m_bOperationPending) {
  2781. output_printf("operation is doing now, please wait for a result!\r\n");
  2782. } else {
  2783. TerminateEntity(GetSelectedEntityName());
  2784. }
  2785. }
  2786. void CMainFrame::OnFresh(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2787. {
  2788. CAutoArray<EntityEntry> Entities;
  2789. m_pConsole->GetAllEntity(Entities);
  2790. for (int i = 0; i < Entities.GetCount(); ++i) {
  2791. SetEntityState(Entities[i].Name, Entities[i].State, Entities[i].Pid);
  2792. }
  2793. }
  2794. void CMainFrame::OnAbout(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2795. {
  2796. /*ATL::CSimpleDialog<IDD_ABOUTBOX> dlg;
  2797. dlg.DoModal();*/
  2798. CAboutDlg dlg(m_pConsole);
  2799. dlg.DoModal();
  2800. }
  2801. void CMainFrame::OnInitialize(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2802. {
  2803. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("begin initialize...");
  2804. m_pConsole->BeginInitialize();
  2805. }
  2806. void CMainFrame::OnMobileDial(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2807. {
  2808. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("begin show mobiledial dialog...");
  2809. m_pConsole->ShowMobileDialog();
  2810. }
  2811. void CMainFrame::OnDeleteKeySet(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2812. {
  2813. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("delete keyset...");
  2814. m_pConsole->DeleteKeySet();
  2815. }
  2816. void CMainFrame::OnMaintain(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2817. {
  2818. //DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("begin maintain, validate user now");
  2819. CLoginDlg dlg;
  2820. if (dlg.DoModal() == IDOK)
  2821. {
  2822. CMenuHandle menuMain = GetMenu();
  2823. menuMain.EnableMenuItem(ID_FILE_HIGHLEVEL, MF_GRAYED);
  2824. auto pEntity = m_pConsole->GetEntity();
  2825. CMaterialMgrCnn *pCnn = new CMaterialMgrCnn(pEntity);
  2826. if (pCnn->ConnectFromCentralSetting() && pCnn->IsConnectionOK())
  2827. {
  2828. auto rc = pCnn->MaintainerLogin(dlg.m_strUserID, dlg.m_strPassword);
  2829. if (rc == Error_Succeed)
  2830. {
  2831. MessageBoxA("维护用户登录验证通过");
  2832. menuMain.EnableMenuItem(ID_FILE_HIGHLEVEL, MF_ENABLED);
  2833. auto pGUIEntity = (CGUIConsoleEntity*)pEntity;
  2834. pGUIEntity->PostUserLoginEvent(dlg.m_strUserID);
  2835. }
  2836. else
  2837. MessageBoxA(CSimpleStringA::Format("维护用户登录验证失败(0x%X)", rc));
  2838. pCnn->Close();
  2839. }
  2840. else
  2841. MessageBoxA("连接物料管理服务失败");
  2842. pCnn->DecRefCount();
  2843. pCnn = NULL;
  2844. }
  2845. }
  2846. void CMainFrame::OnHighLevel(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2847. {
  2848. auto pEntity = m_pConsole->GetEntity();
  2849. auto pGUIEntity = (CGUIConsoleEntity*)pEntity;
  2850. pGUIEntity->Empower(pGUIEntity->GetCurMaintainer());
  2851. }
  2852. //void CMainFrame::OnReboot(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2853. //{
  2854. // m_pConsole->ReqFrameworkQuit();
  2855. //}
  2856. void CMainFrame::OnShellExit(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2857. {
  2858. m_pConsole->ReqFrameworkQuit(false);
  2859. //ShowWindow(SW_MINIMIZE);
  2860. }
  2861. void CMainFrame::OnOSRestart(UINT /*uNotifyCode*/, int /*nID*/, CWindow /*wnd*/)
  2862. {
  2863. m_pConsole->ReqFrameworkQuit(true);
  2864. //ShowWindow(SW_MINIMIZE);
  2865. }
  2866. void CMainFrame::SetEntityDebugLevel(const char *pszEntity, int nDebugLevel)
  2867. {
  2868. m_pConsole->SetDebugLevel(pszEntity, nDebugLevel);
  2869. }
  2870. void CMainFrame::StartEntity(const char *entity_name, const char *cmdline)
  2871. {
  2872. ErrorCodeEnum Error = m_pConsole->AsyncStartEntity(entity_name, cmdline, NULL);
  2873. if (Error == Error_Succeed) {
  2874. output_printf("starting %s\r\n", entity_name);
  2875. m_bOperationPending = TRUE;
  2876. m_OperationBeginTime = CSmallDateTime::GetNow();
  2877. SetTimer(0, 100, NULL);
  2878. } else {
  2879. output_printf("start %s failed, error = 0x%08X\r\n", entity_name, Error);
  2880. }
  2881. }
  2882. void CMainFrame::StopEntity(const char *entity_name)
  2883. {
  2884. ErrorCodeEnum Error = m_pConsole->AsyncStopEntity(entity_name, NULL);
  2885. if (Error == Error_Succeed) {
  2886. output_printf("stopping %s\r\n", entity_name);
  2887. m_bOperationPending = TRUE;
  2888. m_OperationBeginTime = CSmallDateTime::GetNow();
  2889. SetTimer(0, 100, NULL);
  2890. } else {
  2891. output_printf("stop %s failed, error = 0x%08X\r\n", entity_name, Error);
  2892. }
  2893. }
  2894. void CMainFrame::PauseEntity(const char *entity_name)
  2895. {
  2896. ErrorCodeEnum Error = m_pConsole->AsyncPauseEntity(entity_name, NULL);
  2897. if (Error == Error_Succeed) {
  2898. output_printf("pausing %s\r\n", entity_name);
  2899. m_bOperationPending = TRUE;
  2900. m_OperationBeginTime = CSmallDateTime::GetNow();
  2901. SetTimer(0, 100, NULL);
  2902. } else {
  2903. output_printf("pause %s failed, error = %d\r\n", entity_name, Error);
  2904. }
  2905. }
  2906. void CMainFrame::ContinueEntity(const char *entity_name)
  2907. {
  2908. ErrorCodeEnum Error = m_pConsole->AsyncContinueEntity(entity_name, NULL);
  2909. if (Error == Error_Succeed) {
  2910. output_printf("continuing %s\r\n", entity_name);
  2911. m_bOperationPending = TRUE;
  2912. m_OperationBeginTime = CSmallDateTime::GetNow();
  2913. SetTimer(0, 100, NULL);
  2914. } else {
  2915. output_printf("continue %s failed, error = %d\r\n", entity_name, Error);
  2916. }
  2917. }
  2918. void CMainFrame::TerminateEntity(const char *entity_name)
  2919. {
  2920. ErrorCodeEnum Error = m_pConsole->AsyncTerminateEntity(entity_name, NULL);
  2921. if (Error == Error_Succeed) {
  2922. output_printf("terminating %s\r\n", entity_name);
  2923. m_bOperationPending = TRUE;
  2924. m_OperationBeginTime = CSmallDateTime::GetNow();
  2925. SetTimer(0, 100, NULL);
  2926. } else {
  2927. output_printf("terminate %s failed, error = %d\r\n", entity_name, Error);
  2928. }
  2929. }
  2930. void CMainFrame::OnEditEnter(const char *tmp)
  2931. {
  2932. char entity[128];
  2933. if (_strnicmp(tmp, "start", 5) == 0) { /* start entity */
  2934. const char *p = tmp+5;
  2935. while (*p == ' ') p++;
  2936. if (sscanf(p, "%s", entity) == 1) {
  2937. const char *cmdline = p + strlen(entity);
  2938. while (*cmdline == ' ') cmdline++;
  2939. StartEntity(entity, cmdline);
  2940. } else {
  2941. output_printf("invalid input format!\r\n");
  2942. }
  2943. } else if (_strnicmp(tmp, "stop", 4) == 0) { /* stop entity */
  2944. const char *p = tmp+4;
  2945. while (*p == ' ') p++;
  2946. if (sscanf(p, "%s", entity) == 1) {
  2947. StopEntity(entity);
  2948. } else {
  2949. output_printf("invalid input format!\r\n");
  2950. }
  2951. } else if (_strnicmp(tmp, "pause", 5) == 0) { /* pause entity */
  2952. const char *p = tmp+5;
  2953. while (*p == ' ') p++;
  2954. if (sscanf(p, "%s", entity) == 1) {
  2955. PauseEntity(entity);
  2956. } else {
  2957. output_printf("invalid input format!\r\n");
  2958. }
  2959. } else if (_strnicmp(tmp, "continue", 8) == 0) { /* continue entity */
  2960. const char *p = tmp+8;
  2961. while (*p == ' ') p++;
  2962. if (sscanf(p, "%s", entity) == 1) {
  2963. ContinueEntity(entity);
  2964. } else {
  2965. output_printf("invalid input format!\r\n");
  2966. }
  2967. } else if (_strnicmp(tmp, "terminate", 9) == 0) { /* terminate entity */
  2968. const char *p = tmp+9;
  2969. while (*p == ' ') p++;
  2970. if (sscanf(p, "%s", entity) == 1) {
  2971. TerminateEntity(entity);
  2972. } else {
  2973. output_printf("invalid input format!\r\n");
  2974. }
  2975. } else if (_stricmp(tmp, "help") == 0 || _stricmp(tmp, "?") == 0) {
  2976. Usage();
  2977. }
  2978. else if (_stricmp(tmp, "show console") == 0)
  2979. {
  2980. m_pConsole->ShowOutputConsole();
  2981. }
  2982. else if (_stricmp(tmp, "close console") == 0)
  2983. {
  2984. m_pConsole->CloseOutputConsole();
  2985. }
  2986. m_cmd.SetWindowText(NULL);
  2987. }
  2988. void CMainFrame::Usage()
  2989. {
  2990. output_printf("help -- display help usage\r\n");
  2991. output_printf("start <Entity_Name> [arg1] [arg2] ... [argn] -- start entity with args[optional] \r\n");
  2992. output_printf("stop <Entity_Name> -- stop entity\r\n");
  2993. output_printf("pause <Entity_Name> -- pause entity\r\n");
  2994. output_printf("continue <Entity_Name> -- pause entity\r\n");
  2995. output_printf("terminate <Entity_Name> -- terminate entity\r\n");
  2996. output_printf("show console -- output running info into console\r\n");
  2997. output_printf("close console -- close output console\r\n");
  2998. }
  2999. HBRUSH CMainFrame::OnCtlColorEdit( CDCHandle dc, CEdit edit )
  3000. {
  3001. if (m_output.m_hWnd == edit.m_hWnd)
  3002. {
  3003. dc.SetTextColor(RGB(0, 255, 0));
  3004. dc.SetBkColor(RGB(0,0,0));
  3005. return (HBRUSH)GetStockObject(BLACK_BRUSH);
  3006. } else {
  3007. SetMsgHandled(FALSE);
  3008. return 0;
  3009. }
  3010. }
  3011. HBRUSH CMainFrame::OnCtlColorStatic( CDCHandle dc, CStatic wndStatic )
  3012. {
  3013. if (m_output.m_hWnd == wndStatic.m_hWnd) {
  3014. dc.SetTextColor(RGB(0, 255, 0));
  3015. dc.SetBkColor(RGB(0, 0, 0));
  3016. return (HBRUSH)GetStockObject(BLACK_BRUSH);
  3017. } else {
  3018. SetMsgHandled(FALSE);
  3019. return 0;
  3020. }
  3021. }
  3022. void CMainFrame::OnOutputChanged( UINT uNotifyCode, int nID, CWindow wndCtl )
  3023. {
  3024. int n = m_output.GetWindowTextLength();
  3025. m_strOuput.GetBufferSetLength(n);
  3026. m_output.GetWindowText(m_strOuput.GetBufferSetLength(n), n+1);
  3027. }
  3028. void CMainFrame::OnStartMenuRange(UINT uNotifyCode, int nID, CWindow wndCtl)
  3029. {
  3030. CMenuHandle menuMain = GetMenu();
  3031. CMenuHandle menuStartList = menuMain.GetSubMenu(2);
  3032. WTL::CString strText;
  3033. menuStartList.GetMenuStringA(nID, strText, MF_BYCOMMAND);
  3034. if (strText.GetLength() > 0) {
  3035. int m = strText.Find("\t", 0);
  3036. if (m > 0) {
  3037. strText = strText.Left(m);
  3038. }
  3039. const char *p = strchr(strText, ' ');
  3040. if (p) {
  3041. char name[128];
  3042. memcpy(name, strText, p-(LPCSTR)strText);
  3043. name[p-(LPCSTR)strText] = 0;
  3044. p++;
  3045. StartEntity(name, p);
  3046. }
  3047. }
  3048. }
  3049. void CCommandEdit::OnChar( UINT nChar, UINT nRepCnt, UINT nFlags )
  3050. {
  3051. if (nChar == VK_RETURN) {
  3052. char tmp[512];
  3053. int n = GetWindowText(tmp, sizeof(tmp));
  3054. if (n <= 0)
  3055. return;
  3056. if (m_nHistorySize) {
  3057. int last = (m_nHistoryHead + m_nHistorySize-1) % MAX_HISTORY;
  3058. if (strcmp(tmp, m_strHistoryList[last]) != 0) {
  3059. m_nHistoryCursor = (m_nHistoryHead + m_nHistorySize) % MAX_HISTORY;
  3060. m_strHistoryList[m_nHistoryCursor] = tmp;
  3061. m_nHistorySize = (m_nHistorySize + 1) % MAX_HISTORY;
  3062. }
  3063. } else {
  3064. m_nHistoryCursor = (m_nHistoryHead + m_nHistorySize) % MAX_HISTORY;
  3065. m_strHistoryList[m_nHistoryCursor] = tmp;
  3066. m_nHistorySize = (m_nHistorySize + 1) % MAX_HISTORY;
  3067. }
  3068. m_frm->OnEditEnter(tmp);
  3069. SetWindowText(NULL);
  3070. } else {
  3071. SetMsgHandled(FALSE);
  3072. }
  3073. }
  3074. void CCommandEdit::OnKeyDown( UINT nChar, UINT nRepCnt, UINT nFlags )
  3075. {
  3076. int last = m_nHistoryCursor;
  3077. if (nChar == VK_UP) {
  3078. if (m_nHistoryCursor != m_nHistoryHead)
  3079. m_nHistoryCursor = (m_nHistoryCursor + MAX_HISTORY - 1) % MAX_HISTORY;
  3080. SetWindowText(m_strHistoryList[last]);
  3081. } else if (nChar == VK_DOWN) {
  3082. if (m_nHistorySize && (m_nHistoryCursor != (m_nHistoryHead+m_nHistorySize-1) % MAX_HISTORY))
  3083. m_nHistoryCursor = (m_nHistoryCursor + 1) % MAX_HISTORY;
  3084. SetWindowText(m_strHistoryList[last]);
  3085. } else {
  3086. SetMsgHandled(FALSE);
  3087. }
  3088. }