From 14115ff753202c6830e1d206cebf6a07aa4c377f Mon Sep 17 00:00:00 2001 From: George Hazan Date: Tue, 27 Jun 2017 12:12:35 +0300 Subject: - fixes #727; - minor code cleaning --- src/mir_app/src/netlibautoproxy.cpp | 232 ++++++++++++------------------------ 1 file changed, 74 insertions(+), 158 deletions(-) diff --git a/src/mir_app/src/netlibautoproxy.cpp b/src/mir_app/src/netlibautoproxy.cpp index 0172c52e89..c870fa46c4 100644 --- a/src/mir_app/src/netlibautoproxy.cpp +++ b/src/mir_app/src/netlibautoproxy.cpp @@ -27,94 +27,8 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #include -/* -///////////////////////////////////////////////////////////////////// -// ResolveHostName (a helper function) -///////////////////////////////////////////////////////////////////// -DWORD __stdcall ResolveHostName(LPSTR lpszHostName, - LPSTR lpszIPAddress, LPDWORD lpdwIPAddressSize) -{ - if (*lpdwIPAddressSize < 17 || lpszIPAddress == nullptr) - { - *lpdwIPAddressSize = 17; - return ERROR_INSUFFICIENT_BUFFER; - } - - IN_ADDR ip; - ip.s_addr = inet_addr(lpszHostName); - if (ip.s_addr == INADDR_NONE) - { - PHOSTENT myhost = gethostbyname(lpszHostName); - if (myhost != nullptr) - ip = *(PIN_ADDR)myhost->h_addr; - else - return SOCKET_ERROR; - } - mir_snprintf(lpszIPAddress, *lpdwIPAddressSize, "%u.%u.%u.%u", - ip.s_net, ip.s_host, ip.s_lh, ip.s_impno); - - return 0; -} - -///////////////////////////////////////////////////////////////////// -// IsResolvable (a helper function) -///////////////////////////////////////////////////////////////////// -BOOL __stdcall IsResolvable(LPSTR lpszHost) -{ - char szDummy[255]; - DWORD dwDummySize = sizeof (szDummy) - 1; - - if (ResolveHostName(lpszHost, szDummy, &dwDummySize)) - return FALSE; - return TRUE; -} - -///////////////////////////////////////////////////////////////////// -// GetIPAddress (a helper function) -///////////////////////////////////////////////////////////////////// -DWORD __stdcall GetIPAddress(LPSTR lpszIPAddress, LPDWORD lpdwIPAddressSize) -{ - char szHostBuffer[255]; - - if (gethostname(szHostBuffer, sizeof (szHostBuffer) - 1) != ERROR_SUCCESS) - return (ERROR_INTERNET_INTERNAL_ERROR); - return (ResolveHostName(szHostBuffer, lpszIPAddress, lpdwIPAddressSize)); -} - -///////////////////////////////////////////////////////////////////// -// IsInNet (a helper function) -///////////////////////////////////////////////////////////////////// -BOOL __stdcall IsInNet(LPSTR lpszIPAddress, LPSTR lpszDest, LPSTR lpszMask) -{ - DWORD dwDest; - DWORD dwIpAddr; - DWORD dwMask; - - dwIpAddr = inet_addr(lpszIPAddress); - dwDest = inet_addr(lpszDest); - dwMask = inet_addr(lpszMask); - - if ((dwDest == INADDR_NONE) || - (dwIpAddr == INADDR_NONE) || ((dwIpAddr & dwMask) != dwDest)) - return (FALSE); - - return (TRUE); -} - -static const AutoProxyHelperVtbl OurVtbl = -{ - IsResolvable, - GetIPAddress, - ResolveHostName, - IsInNet, - nullptr, - nullptr, - nullptr, - nullptr -}; - -static AutoProxyHelperFunctions HelperFunctions = { &OurVtbl }; -*/ +///////////////////////////////////////////////////////////////////////////////////////// +// local module data static char *szProxyHost[3]; static LIST proxyBypass(5); @@ -127,17 +41,18 @@ static pfnInternetGetProxyInfo pInternetGetProxyInfo; static bool bEnabled, bOneProxy; -static void GetFile(char* szUrl, AUTO_PROXY_SCRIPT_BUFFER &buf) -{ - NetlibUser nlu = {0}; - NETLIBHTTPREQUEST nlhr = {0}; +///////////////////////////////////////////////////////////////////////////////////////// +static void GetFile(char *szUrl, AUTO_PROXY_SCRIPT_BUFFER &buf) +{ + NetlibUser nlu = {}; nlu.handleType = NLH_USER; nlu.user.flags = NUF_OUTGOING | NUF_HTTPCONNS; - nlu.user.szSettingsModule = "(nullptr)"; + nlu.user.szSettingsModule = "(NULL)"; nlu.toLog = 1; // initialize the netlib request + NETLIBHTTPREQUEST nlhr = {}; nlhr.cbSize = sizeof(nlhr); nlhr.requestType = REQUEST_GET; nlhr.flags = NLHRF_HTTP11 | NLHRF_DUMPASTEXT | NLHRF_REDIRECT; @@ -157,22 +72,21 @@ static void GetFile(char* szUrl, AUTO_PROXY_SCRIPT_BUFFER &buf) } } +///////////////////////////////////////////////////////////////////////////////////////// + bool NetlibGetIeProxyConn(NetlibConnection *nlc, bool forceHttps) { bool noHttp = false; bool usingSsl = false; char szUrl[1024]; - if ((nlc->nloc.flags & (NLOCF_HTTP | NLOCF_HTTPGATEWAY) && nlc->nloc.flags & NLOCF_SSL) || - nlc->nloc.wPort == 443 || forceHttps) - { + if ((nlc->nloc.flags & (NLOCF_HTTP | NLOCF_HTTPGATEWAY) && nlc->nloc.flags & NLOCF_SSL) || nlc->nloc.wPort == 443 || forceHttps) { mir_snprintf(szUrl, "https://%s", nlc->nloc.szHost); usingSsl = true; } else if (nlc->nloc.flags & (NLOCF_HTTPGATEWAY | NLOCF_HTTP) || nlc->usingHttpGateway) mir_snprintf(szUrl, "http://%s", nlc->nloc.szHost); - else - { + else { strncpy_s(szUrl, nlc->nloc.szHost, _TRUNCATE); noHttp = true; } @@ -185,49 +99,51 @@ bool NetlibGetIeProxyConn(NetlibConnection *nlc, bool forceHttps) char *m = NEWSTR_ALLOCA(mt); mir_free(mt); - if (m == nullptr) return false; + if (m == nullptr) + return false; // if multiple servers, use the first one char *c = strchr(m, ';'); if (c) *c = 0; // if 'direct' no proxy - if (_stricmp(lrtrim(m), "direct") == 0) return false; + if (_stricmp(lrtrim(m), "direct") == 0) + return false; // find proxy address char *h = strchr(m, ' '); - if (h) { *h = 0; ++h; } else return false; - + if (h == nullptr) + return false; + // find proxy port + *h = 0; ++h; char *p = strchr(h, ':'); if (p) { *p = 0; ++p; } lrtrim(h); ltrim(p); - if (_stricmp(m, "proxy") == 0 && h[0]) - { + if (_stricmp(m, "proxy") == 0 && h[0]) { nlc->proxyType = (usingSsl || noHttp) ? PROXYTYPE_HTTPS : PROXYTYPE_HTTP; nlc->wProxyPort = p ? atol(p) : 8080; nlc->szProxyServer = mir_strdup(h); } - else if (_stricmp(m, "socks") == 0 && h[0]) - { + else if (_stricmp(m, "socks") == 0 && h[0]) { nlc->proxyType = PROXYTYPE_SOCKS4; nlc->wProxyPort = p ? atol(p) : 1080; nlc->szProxyServer = mir_strdup(h); } - else if (_stricmp(m, "socks5") == 0 && h[0]) - { + else if (_stricmp(m, "socks5") == 0 && h[0]) { nlc->proxyType = PROXYTYPE_SOCKS5; nlc->wProxyPort = p ? atol(p) : 1080; nlc->szProxyServer = mir_strdup(h); } - else - return false; + else return false; return true; } +///////////////////////////////////////////////////////////////////////////////////////// + static char szAutoUrlStr[MAX_PATH] = ""; -static AUTO_PROXY_SCRIPT_BUFFER abuf = {0}; +static AUTO_PROXY_SCRIPT_BUFFER abuf = { 0 }; static HANDLE hIeProxyMutex; static bool bAutoProxyInit; @@ -235,29 +151,24 @@ static void NetlibInitAutoProxy(void) { if (bAutoProxyInit) return; - if (!hModJS) - { + if (!hModJS) { if (!(hModJS = LoadLibraryA("jsproxy.dll"))) return; - pInternetInitializeAutoProxyDll = (pfnInternetInitializeAutoProxyDll) - GetProcAddress(hModJS, "InternetInitializeAutoProxyDll"); - - pInternetDeInitializeAutoProxyDll = (pfnInternetDeInitializeAutoProxyDll) - GetProcAddress(hModJS, "InternetDeInitializeAutoProxyDll"); - - pInternetGetProxyInfo = (pfnInternetGetProxyInfo) - GetProcAddress(hModJS, "InternetGetProxyInfo"); + pInternetInitializeAutoProxyDll = (pfnInternetInitializeAutoProxyDll)GetProcAddress(hModJS, "InternetInitializeAutoProxyDll"); + pInternetDeInitializeAutoProxyDll = (pfnInternetDeInitializeAutoProxyDll)GetProcAddress(hModJS, "InternetDeInitializeAutoProxyDll"); + pInternetGetProxyInfo = (pfnInternetGetProxyInfo)GetProcAddress(hModJS, "InternetGetProxyInfo"); } - if (strstr(szAutoUrlStr, "file://") == nullptr && strstr(szAutoUrlStr, "://") != nullptr) - { + if (strstr(szAutoUrlStr, "file://") == nullptr && strstr(szAutoUrlStr, "://") != nullptr) { abuf.dwStructSize = sizeof(abuf); GetFile(szAutoUrlStr, abuf); } bAutoProxyInit = true; } +///////////////////////////////////////////////////////////////////////////////////////// + struct IeProxyParam { char *szUrl; @@ -306,6 +217,8 @@ static void NetlibIeProxyThread(void *arg) else Netlib_Logf(nullptr, "Autoproxy init failed"); } +///////////////////////////////////////////////////////////////////////////////////////// + char* NetlibGetIeProxy(char *szUrl) { char *res = nullptr; @@ -317,15 +230,14 @@ char* NetlibGetIeProxy(char *szUrl) p = strchr(szHost, ':'); if (p) *p = 0; _strlwr(szHost); - if (bEnabled) - { - for (int i=0; i < proxyBypass.getCount(); i++) - { - if (mir_strcmp(proxyBypass[i], "") == 0) - { - if (strchr(szHost, '.') == nullptr) return nullptr; + if (bEnabled) { + for (int i = 0; i < proxyBypass.getCount(); i++) { + if (mir_strcmp(proxyBypass[i], "") == 0) { + if (strchr(szHost, '.') == nullptr) + return nullptr; } - else if (wildcmp(szHost, proxyBypass[i])) return nullptr; + else if (wildcmp(szHost, proxyBypass[i])) + return nullptr; } int ind = -1; @@ -336,7 +248,8 @@ char* NetlibGetIeProxy(char *szUrl) else ind = szProxyHost[2] ? 2 : (bOneProxy ? 0 : (szProxyHost[1] ? 1 : 2)); - if (ind < 0 || !szProxyHost[ind]) return nullptr; + if (ind < 0 || !szProxyHost[ind]) + return nullptr; size_t len = mir_strlen(szHost) + 20; res = (char*)mir_alloc(len); @@ -353,11 +266,12 @@ char* NetlibGetIeProxy(char *szUrl) return res; } +///////////////////////////////////////////////////////////////////////////////////////// + void NetlibLoadIeProxy(void) { HKEY hSettings; - if (RegOpenKeyExA(HKEY_CURRENT_USER, "Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings", - 0, KEY_QUERY_VALUE, &hSettings)) + if (RegOpenKeyExA(HKEY_CURRENT_USER, "Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings", 0, KEY_QUERY_VALUE, &hSettings)) return; DWORD tValueLen, enabled = 0; @@ -379,52 +293,55 @@ void NetlibLoadIeProxy(void) RegCloseKey(hSettings); - if (bEnabled) - { - char* szProxy = ltrim(szHostStr); - if (szProxy[0] == 0) { enabled = false; return; } + if (bEnabled) { + char *szProxy = ltrim(szHostStr); + if (szProxy[0] == 0) { + enabled = false; + return; + } - while(true) - { + while (true) { char *szProxyEnd = strchr(szProxy, ';'); - if (szProxyEnd) *szProxyEnd = 0; + if (szProxyEnd) + *szProxyEnd = 0; int ind = -1; - if (strncmp(szProxy, "http = ", 5) == 0) { ind = 0; szProxy += 5; } - else if (strncmp(szProxy, "https = ", 6) == 0) { ind = 1; szProxy += 6; } - else if (strncmp(szProxy, "socks = ", 6) == 0) { ind = 2; szProxy += 6; } + if (strncmp(szProxy, "http=", 5) == 0) { ind = 0; szProxy += 5; } + else if (strncmp(szProxy, "https=", 6) == 0) { ind = 1; szProxy += 6; } + else if (strncmp(szProxy, "socks=", 6) == 0) { ind = 2; szProxy += 6; } else if (strchr(szProxy, '=')) ind = -2; - if (ind != -2) - { + if (ind != -2) { bOneProxy = ind < 0; if (ind < 0) ind = 0; lrtrim(szProxy); if (strchr(szProxy, ':')) szProxyHost[ind] = mir_strdup(szProxy); - else - { + else { size_t len = mir_strlen(szProxy) + 10; szProxyHost[ind] = (char*)mir_alloc(len); mir_snprintf(szProxyHost[ind], len, "%s:%u", szProxy, ind == 2 ? 1080 : 8080); } - if (bOneProxy) break; + if (bOneProxy) + break; } - if (szProxyEnd == nullptr) break; + if (szProxyEnd == nullptr) + break; szProxy = szProxyEnd + 1; } - char* szProxyBypass = szProxyBypassStr; - while(true) - { + char *szProxyBypass = szProxyBypassStr; + while (true) { char *szProxyBypassEnd = strchr(szProxyBypass, ';'); - if (szProxyBypassEnd) *szProxyBypassEnd = 0; + if (szProxyBypassEnd) + *szProxyBypassEnd = 0; lrtrim(szProxyBypass); proxyBypass.insert(_strlwr(mir_strdup(szProxyBypass))); - if (szProxyBypassEnd == nullptr) break; + if (szProxyBypassEnd == nullptr) + break; szProxyBypass = szProxyBypassEnd + 1; } @@ -437,11 +354,10 @@ void NetlibLoadIeProxy(void) void NetlibUnloadIeProxy(void) { int i; - - for (i=0; i < 3; i++) + for (i = 0; i < 3; i++) mir_free(szProxyHost[i]); - for (i=0; i < proxyBypass.getCount(); i++) + for (i = 0; i < proxyBypass.getCount(); i++) mir_free(proxyBypass[i]); mir_free(abuf.lpszScriptBuffer); -- cgit v1.2.3