MainDlg.cpp 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629
  1. // MainDlg.cpp : implementation of the CMainDlg class
  2. //
  3. /////////////////////////////////////////////////////////////////////////////
  4. #include "stdafx.h"
  5. #include "MainDlg.h"
  6. #include "StabtypeControl.h"
  7. #include "CLashConfig.h"
  8. #include "SysProxy.h"
  9. CMainDlg::CMainDlg() : SHostWnd(_T("LAYOUT:XML_MAINWND")), m_base_clash(nullptr), pNodeAdapter(nullptr)
  10. {
  11. m_bLayoutInited = FALSE;
  12. m_refresh = false;
  13. m_connect_mage = nullptr;
  14. }
  15. CMainDlg::~CMainDlg()
  16. {
  17. if (m_base_clash)
  18. {
  19. delete m_base_clash;
  20. m_base_clash = nullptr;
  21. }
  22. if (m_connect_mage)
  23. {
  24. delete m_connect_mage;
  25. m_connect_mage = nullptr;
  26. }
  27. }
  28. int CMainDlg::OnCreate(LPCREATESTRUCT lpCreateStruct)
  29. {
  30. SetMsgHandled(FALSE);
  31. return 0;
  32. }
  33. BOOL CMainDlg::OnInitDialog(HWND hWnd, LPARAM lParam)
  34. {
  35. m_bLayoutInited = TRUE;
  36. Init();
  37. OnConnecting_UdateUi(false, CONNECT_NODE_MSG,L"");
  38. /*CManageNetWork m_manageNetwork;
  39. m_manageNetwork.GetNodeList();*/
  40. CManageNetWork::getSingletonPtr()->GetNodeList();
  41. return 0;
  42. }
  43. void CMainDlg::Init()
  44. {
  45. CApp::getSingletonPtr()->SetupDataDirectory();
  46. //FindChildByName2<STabCtrl>(L"tabmain");
  47. if (!m_base_clash)
  48. {
  49. m_base_clash = new CLashConfig();
  50. m_base_clash->InitClash();
  51. m_base_clash->StartClash();
  52. }
  53. if (!m_connect_mage)
  54. {
  55. m_connect_mage = new CConnectMage();
  56. m_connect_mage->SetClashConfig((CLashConfig*)m_base_clash);
  57. m_connect_mage->Init();
  58. }
  59. SysMode list;
  60. list.id = 0;
  61. list.name = L"系统代理";
  62. list.proxy_mode = PROXY_MODE::sys_mode;
  63. SysMode list1;
  64. list1.id = 1;
  65. list1.name = L"网卡代理";
  66. list1.proxy_mode = PROXY_MODE::tun_mode;
  67. m_sysmode_vctor.push_back(list);
  68. m_sysmode_vctor.push_back(list1);
  69. RouteMode route;
  70. route.id = 0;
  71. route.name = L"智能";
  72. route.route_mode = ROUT_MODE::cn_mode;
  73. RouteMode route2;
  74. route2.id = 1;
  75. route2.name = L"全局";
  76. route2.route_mode = ROUT_MODE::qg_mode;
  77. m_route_vctor.push_back(route);
  78. m_route_vctor.push_back(route2);
  79. StabtypeControl* tabtype = FindChildByName2<StabtypeControl>(L"sysmode");
  80. if (tabtype)
  81. {
  82. for (auto i = 0; i < m_sysmode_vctor.size(); i++)
  83. {
  84. tabtype->ItemCreateChildren(m_sysmode_vctor[i].id, m_sysmode_vctor[i].name,i == 0 ? true : false );
  85. }
  86. if (m_sysmode_vctor.size() > 0)
  87. {
  88. CApp::getSingletonPtr()->SetSysMode(PROXY_MODE::sys_mode);
  89. }
  90. tabtype->GetEventSet()->subscribeEvent(EVT_TABTYPE_CONTROL,
  91. Subscriber(&CMainDlg::OnSysModeType, this));
  92. }
  93. StabtypeControl* routetype = FindChildByName2<StabtypeControl>(L"routemode");
  94. if (routetype)
  95. {
  96. for (auto i = 0; i < m_route_vctor.size(); i++)
  97. {
  98. routetype->ItemCreateChildren(m_route_vctor[i].id, m_route_vctor[i].name, i == 0 ? true : false);
  99. }
  100. if (m_route_vctor.size() > 0)
  101. {
  102. CApp::getSingletonPtr()->SetRouteMode(ROUT_MODE::cn_mode);
  103. }
  104. routetype->GetEventSet()->subscribeEvent(EVT_TABTYPE_CONTROL,
  105. Subscriber(&CMainDlg::OnRouteModeType, this));
  106. }
  107. auto funRecent2 = std::bind(&CMainDlg::ShowView, this, std::placeholders::_1, std::placeholders::_2);
  108. auto funRecent3 = std::bind(&CMainDlg::ItemRClick, this, std::placeholders::_1);
  109. STileView* pTileView = FindChildByName2<STileView>("nodeList");
  110. if (pTileView)
  111. {
  112. /*std::vector<SStringT> vctInfo{ L"Test1",L"Fun1", L"Ming", L"Get" };*/
  113. pNodeAdapter = new CNodeAdapter(pTileView);
  114. pTileView->SetAdapter(pNodeAdapter);
  115. pNodeAdapter->SetShowView(funRecent2);
  116. pNodeAdapter->SetItemClickCallBack(funRecent3);
  117. //pNodeAdapter->Release();
  118. }
  119. UpDateUserInfo();
  120. }
  121. void CMainDlg::OnNode()
  122. {
  123. STabCtrl* m_tab_main = FindChildByName2<STabCtrl>(L"tabmain");
  124. if (m_tab_main)
  125. {
  126. m_tab_main->SetCurSel(1);
  127. m_tab_main->Invalidate();
  128. }
  129. }
  130. void CMainDlg::OnBackNode()
  131. {
  132. STabCtrl* m_tab_main = FindChildByName2<STabCtrl>(L"tabmain");
  133. if (m_tab_main)
  134. {
  135. m_tab_main->SetCurSel(0);
  136. m_tab_main->Invalidate();
  137. }
  138. }
  139. bool CMainDlg::OnSysModeType(SOUI::EventArgs* pEvt)
  140. {
  141. SOUI::EventTabtypeControl* pTestControlEvent =
  142. SOUI::sobj_cast<SOUI::EventTabtypeControl>(pEvt);
  143. if (!pTestControlEvent)
  144. {
  145. return false;
  146. }
  147. CApp::getSingletonPtr()->SetSysMode(m_sysmode_vctor[pTestControlEvent->nIndex].proxy_mode);
  148. return true;
  149. }
  150. bool CMainDlg::OnRouteModeType(SOUI::EventArgs* pEvt)
  151. {
  152. SOUI::EventTabtypeControl* pTestControlEvent =
  153. SOUI::sobj_cast<SOUI::EventTabtypeControl>(pEvt);
  154. if (!pTestControlEvent)
  155. {
  156. return false;
  157. }
  158. CApp::getSingletonPtr()->SetRouteMode(m_route_vctor[pTestControlEvent->nIndex].route_mode);
  159. return true;
  160. }
  161. void CMainDlg::OnServerListFinish(SOUI::EventArgs* pEvt)
  162. {
  163. EventNodeList* e2 = sobj_cast<EventNodeList>(pEvt);
  164. if (!e2)
  165. {
  166. return;
  167. }
  168. if (e2->status != 200 )
  169. {
  170. if (m_refresh)
  171. {
  172. SStatic* refresh_status = FindChildByName2<SStatic>(L"refresh_status");
  173. if (refresh_status)
  174. {
  175. refresh_status->SetWindowTextW(e2->msg);
  176. refresh_status->Invalidate();
  177. }
  178. m_refresh = false;
  179. }
  180. else {
  181. UPdateMsgStatus(e2->msg);
  182. }
  183. }
  184. else if (e2->status == 200)
  185. {
  186. if (m_refresh)
  187. {
  188. SStatic* refresh_status = FindChildByName2<SStatic>(L"refresh_status");
  189. if (refresh_status)
  190. {
  191. refresh_status->SetWindowTextW(L"更新完成..");
  192. refresh_status->Invalidate();
  193. }
  194. m_refresh = false;
  195. }
  196. else {
  197. OnConnecting_UdateUi(TRUE, SUEECS_NODE_MSG);
  198. CManageNetWork::getSingletonPtr()->GetVersion();
  199. }
  200. //更新 节点数据
  201. if (pNodeAdapter)
  202. {
  203. pNodeAdapter->SetCount(CApp::getSingletonPtr()->GetServerList()->vectlistmode.size());
  204. }
  205. }
  206. }
  207. void CMainDlg::OnVersionFinish(SOUI::EventArgs* pEvt)
  208. {
  209. EventVerions* e2 = sobj_cast<EventVerions>(pEvt);
  210. if (!e2)
  211. {
  212. return;
  213. }
  214. if (e2->status == 200)
  215. {
  216. UPdateVersionMsgStatus(e2->msg, S_CA2W(CApp::getSingletonPtr()->GetVerinfo()->appdownload.c_str()));
  217. }
  218. else {
  219. UPdateVersionMsgStatus(e2->msg);
  220. }
  221. }
  222. void CMainDlg::OnConnectFinish(SOUI::EventArgs* pEvt)
  223. {
  224. EventConnect* e2 = sobj_cast<EventConnect>(pEvt);
  225. if (!e2)
  226. {
  227. return;
  228. }
  229. if (e2->status == ConnectState::Stop)
  230. {
  231. OnConnecting_UdateUi(true, e2->msg, L"", false);
  232. } else if (e2->status == ConnectState::SwitchConfigSuccEss)
  233. {
  234. OnConnecting_UdateUi(true, e2->msg, L"", true);
  235. } else if (e2->status == ConnectState::SwitchNodeSuccEss)
  236. {
  237. OnConnecting_UdateUi(true, e2->msg, L"", true);
  238. }
  239. }
  240. void CMainDlg::OnClashPreoceeQutFinish(SOUI::EventArgs* pEvt)
  241. {
  242. if (m_base_clash)
  243. {
  244. m_base_clash->StartClash();
  245. }
  246. if (m_connect_mage)
  247. {
  248. m_connect_mage->ReqConfig();
  249. }
  250. }
  251. void CMainDlg::UPdateMsgStatus(SStringW msg)
  252. {
  253. //text_touch
  254. SStatic* text_touch = FindChildByName2<SStatic>(L"text_touch");
  255. if (text_touch)
  256. {
  257. text_touch->SetWindowTextW(msg);
  258. text_touch->EnableWindow(FALSE);
  259. text_touch->Invalidate();
  260. }
  261. }
  262. void CMainDlg::UPdateVersionMsgStatus(SStringW msg, SStringW url)
  263. {
  264. SLink* app_version = FindChildByName2<SLink>(L"app_version");
  265. if (app_version)
  266. {
  267. if (!url.IsEmpty())
  268. {
  269. app_version->SetAttribute(L"href", url);
  270. }
  271. app_version->SetWindowTextW(msg);
  272. app_version->EnableWindow(true);
  273. app_version->Invalidate();
  274. }
  275. }
  276. void CMainDlg::UpDateUserInfo()
  277. {
  278. CUserInfo* userinfo = CApp::getSingletonPtr()->GetUserinfo();
  279. if (!userinfo)
  280. {
  281. return;
  282. }
  283. SStatic* username = FindChildByName2<SStatic>(L"username");
  284. if (username)
  285. {
  286. username->SetWindowTextW(SStringW().Format(L"用户名:%s", S_CA2W(userinfo->username.c_str())));
  287. username->EnableWindow(FALSE);
  288. username->Invalidate();
  289. }
  290. SStatic* username_time = FindChildByName2<SStatic>(L"username_time");
  291. if (username_time)
  292. {
  293. username_time->SetWindowTextW(SStringW().Format(L"到期时间:%s", S_CA2W(userinfo->expiretime.c_str())));
  294. username_time->EnableWindow(FALSE);
  295. username_time->Invalidate();
  296. }
  297. SStatic* username_liulaing = FindChildByName2<SStatic>(L"username_liulaing");
  298. if (username_liulaing)
  299. {
  300. username_liulaing->SetWindowTextW(SStringW().Format(L"到期时间:%s", S_CA2W(userinfo->unusedTraffic.c_str())));
  301. username_liulaing->EnableWindow(FALSE);
  302. username_liulaing->Invalidate();
  303. }
  304. SLink* username_jiaocheng = FindChildByName2<SLink>(L"username_jiaocheng");
  305. if (username_jiaocheng)
  306. {
  307. username_jiaocheng->SetAttribute(L"href", S_CA2W(userinfo->swoftdownload.c_str()));
  308. username_jiaocheng->EnableWindow(true);
  309. username_jiaocheng->Invalidate();
  310. }
  311. SLink* username_chongzhi = FindChildByName2<SLink>(L"username_chongzhi");
  312. if (username_chongzhi)
  313. {
  314. username_chongzhi->SetAttribute(L"href", S_CA2W(userinfo->user_login_url.c_str()));
  315. username_chongzhi->EnableWindow(true);
  316. username_chongzhi->Invalidate();
  317. }
  318. SLink* username_tuiguang = FindChildByName2<SLink>(L"username_tuiguang");
  319. if (username_tuiguang)
  320. {
  321. username_tuiguang->SetAttribute(L"href", S_CA2W(userinfo->affurl.c_str()));
  322. username_tuiguang->EnableWindow(true);
  323. username_tuiguang->Invalidate();
  324. }
  325. if (m_base_clash)
  326. {
  327. auto http_prot = m_base_clash->GetHttpPort();
  328. auto sock_prot = m_base_clash->GetSocketPort();
  329. SStatic* httpproxy = FindChildByName2<SStatic>(L"httpproxy");
  330. if (httpproxy)
  331. {
  332. httpproxy->SetWindowTextW(SStringW().Format(L"http proxy 127.0.0.1:%d", http_prot));
  333. httpproxy->EnableWindow(FALSE);
  334. httpproxy->Invalidate();
  335. }
  336. SStatic* socksproxy = FindChildByName2<SStatic>(L"socksproxy");
  337. if (socksproxy)
  338. {
  339. socksproxy->SetWindowTextW(SStringW().Format(L"socks proxy 127.0.0.1:%d", sock_prot));
  340. socksproxy->EnableWindow(FALSE);
  341. socksproxy->Invalidate();
  342. }
  343. }
  344. }
  345. void CMainDlg::ShowView(int nItem, SWindow* pItem)
  346. {
  347. if (!pNodeAdapter)
  348. {
  349. return;
  350. }
  351. CServerList* p = CApp::getSingletonPtr()->GetServerList();
  352. if (!p)
  353. {
  354. return;
  355. }
  356. auto vectorserverlist = p->vectlistmode;
  357. SStatic* servername = pItem->FindChildByName2<SStatic>(L"servername");
  358. if (servername)
  359. {
  360. servername->SetWindowTextW(S_CA2W(vectorserverlist[nItem].name.c_str(),CP_UTF8));
  361. }
  362. SStatic* serverms = pItem->FindChildByName2<SStatic>(L"serverms");
  363. if (serverms)
  364. {
  365. SStringW msg = L"推荐";
  366. SStringW color = L"";
  367. SLOG_DEBUG(vectorserverlist[nItem].online_users);
  368. if(vectorserverlist[nItem].online_users < 21 || vectorserverlist[nItem].online_users < 30) { //空闲
  369. msg = L"空闲";
  370. color = L"#6aa84f";
  371. }
  372. else if (vectorserverlist[nItem].online_users < 31 || vectorserverlist[nItem].online_users < 80) { //繁忙
  373. msg = L"繁忙";
  374. color = L"#7c7c7c";
  375. }
  376. else if (vectorserverlist[nItem].online_users < 81 || vectorserverlist[nItem].online_users < 150) { //拥挤
  377. msg = L"拥挤";
  378. color = L"#f50061";
  379. }
  380. else if (vectorserverlist[nItem].online_users < 151 || vectorserverlist[nItem].online_users < 500) { //爆满
  381. msg = L"拥挤";
  382. color = L"#585858";
  383. }
  384. serverms->SetWindowTextW(msg);
  385. serverms->SetAttribute(L"colorText", color);
  386. }
  387. }
  388. void CMainDlg::ItemRClick(int nItem)
  389. {
  390. CServerList* p = CApp::getSingletonPtr()->GetServerList();
  391. if (!p)
  392. {
  393. return;
  394. }
  395. auto vectorserverlist = p->vectlistmode;
  396. auto name = vectorserverlist[nItem].name;
  397. OnBackNode();
  398. SLOG_DEBUG(name.c_str());
  399. //切换CLash api
  400. if (m_connect_mage)
  401. {
  402. m_connect_mage->SetNodeName(name);
  403. m_connect_mage->ReqConfig();
  404. }
  405. CApp::getSingletonPtr()->SetSelect_node(name);
  406. OnUpdataNodeName();
  407. }
  408. void CMainDlg::OnRefresh()
  409. {
  410. if (m_refresh)
  411. {
  412. return;
  413. }
  414. //更新 节点数据
  415. if (pNodeAdapter)
  416. {
  417. pNodeAdapter->SetCount(0);
  418. }
  419. CManageNetWork::getSingletonPtr()->GetNodeList();
  420. m_refresh = true;
  421. //refresh_status
  422. SStatic* refresh_status = FindChildByName2<SStatic>(L"refresh_status");
  423. if (refresh_status)
  424. {
  425. refresh_status->SetWindowTextW(L"正在刷新节点...");
  426. refresh_status->Invalidate();
  427. }
  428. }
  429. void CMainDlg::OnConnect()
  430. {
  431. if (!m_connect_mage)
  432. {
  433. return;
  434. }
  435. if (m_connect_mage->GetConnectStatus() == ConnectState::Stop)
  436. {
  437. m_connect_mage->ReqConfig();
  438. OnConnecting_UdateUi(false, L"正在启动中..", L"", false);
  439. }
  440. else {
  441. m_connect_mage->Stop();
  442. DisableSystemProxy();
  443. OnConnecting_UdateUi(true, L"停止成功", L"", false);
  444. }
  445. }
  446. void CMainDlg::OnUpdataNodeName()
  447. {
  448. SStatic* node_name = FindChildByName2<SStatic>(L"node_name");
  449. if (node_name)
  450. {
  451. node_name->SetWindowTextW(S_CA2W(CApp::getSingletonPtr()->GetSelect_node().c_str(),CP_UTF8));
  452. node_name->Invalidate();
  453. }
  454. }
  455. //连接状态 更新UI
  456. void CMainDlg::OnConnecting_UdateUi(bool b,SStringW msg,SStringW acc_msg,bool connect)
  457. {
  458. SWindow* selectnode = FindChildByName2<SWindow>(L"selectnode");
  459. if (selectnode)
  460. {
  461. selectnode->EnableWindow(b);
  462. selectnode->Invalidate();
  463. }
  464. SStatic* text_touch = FindChildByName2<SStatic>(L"text_touch");
  465. if (text_touch)
  466. {
  467. text_touch->SetWindowTextW(msg);
  468. text_touch->EnableWindow(b);
  469. text_touch->Invalidate();
  470. }
  471. SImageButton* connect_touch = FindChildByName2<SImageButton>(L"connect_touch");
  472. if (connect_touch)
  473. {
  474. if (connect)
  475. {
  476. connect_touch->SetAttribute(L"skin", L"skin_btnswitchon");
  477. }
  478. else {
  479. connect_touch->SetAttribute(L"skin", L"skin_btnswitchoff");
  480. }
  481. connect_touch->EnableWindow(b);
  482. connect_touch->Invalidate();
  483. }
  484. }
  485. //TODO:消息映射
  486. void CMainDlg::OnClose()
  487. {
  488. OnMinimize();
  489. }
  490. void CMainDlg::OnMaximize()
  491. {
  492. SendMessage(WM_SYSCOMMAND, SC_MAXIMIZE);
  493. }
  494. void CMainDlg::OnRestore()
  495. {
  496. SendMessage(WM_SYSCOMMAND, SC_RESTORE);
  497. }
  498. void CMainDlg::OnMinimize()
  499. {
  500. SendMessage(WM_SYSCOMMAND, SC_MINIMIZE);
  501. }
  502. void ShowConsoleWindow(bool show) {
  503. const HWND hWnd = CProcessManager::getSingletonPtr()->GetConsoleWindow();
  504. if (hWnd)
  505. {
  506. ShowWindow(hWnd, show ? SW_SHOW : SW_HIDE);
  507. if (show)
  508. SetForegroundWindow(hWnd);
  509. }
  510. }
  511. void CMainDlg::OnCommand(UINT uNotifyCode, int nID, HWND wndCtl) {
  512. if (uNotifyCode == 0)
  513. {
  514. if (nID == 2)
  515. {
  516. const HWND hWndConsole = CProcessManager::getSingletonPtr()->GetConsoleWindow();
  517. if (hWndConsole)
  518. {
  519. ShowConsoleWindow(!::IsWindowVisible(hWndConsole));
  520. }
  521. else
  522. ShowConsoleWindow(false);
  523. }
  524. else if (nID == 6) {
  525. if (m_base_clash)
  526. {
  527. CProcessManager::getSingletonPtr()->SendStopSignal();
  528. WaitForSingleObject(CProcessManager::getSingletonPtr()->GetClashProcessInfo().hProcess, 3000);
  529. CProcessManager::getSingletonPtr()->Stop();
  530. m_base_clash->StopClash();
  531. delete m_base_clash;
  532. m_base_clash = nullptr;
  533. }
  534. CSimpleWnd::DestroyWindow();
  535. }
  536. }
  537. }