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