mirror of
				https://github.com/2dust/v2rayN.git
				synced 2025-10-26 02:04:40 +00:00 
			
		
		
		
	Update ProxySettingWindows.cs
AI-optimized code
This commit is contained in:
		
							parent
							
								
									8092481d26
								
							
						
					
					
						commit
						0a8ce0f961
					
				
					 1 changed files with 25 additions and 25 deletions
				
			
		|  | @ -60,7 +60,7 @@ namespace ServiceLib.Handler.SysProxy | ||||||
|             try |             try | ||||||
|             { |             { | ||||||
|                 // set proxy for LAN |                 // set proxy for LAN | ||||||
|                 bool result = SetConnectionProxy(null, strProxy, exceptions, type); |                 var result = SetConnectionProxy(null, strProxy, exceptions, type); | ||||||
|                 // set proxy for dial up connections |                 // set proxy for dial up connections | ||||||
|                 var connections = EnumerateRasEntries(); |                 var connections = EnumerateRasEntries(); | ||||||
|                 foreach (var connection in connections) |                 foreach (var connection in connections) | ||||||
|  | @ -71,16 +71,16 @@ namespace ServiceLib.Handler.SysProxy | ||||||
|             } |             } | ||||||
|             catch |             catch | ||||||
|             { |             { | ||||||
|                 SetProxyFallback(strProxy, exceptions, type); |                 _ = SetProxyFallback(strProxy, exceptions, type); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private static bool SetConnectionProxy(string? connectionName, string? strProxy, string? exceptions, int type) |         private static bool SetConnectionProxy(string? connectionName, string? strProxy, string? exceptions, int type) | ||||||
|         { |         { | ||||||
|             InternetPerConnOptionList list = new(); |             var list = new InternetPerConnOptionList(); | ||||||
| 
 | 
 | ||||||
|             int optionCount = 1; |             var optionCount = 1; | ||||||
|             if (type == 1) // No proxy |             if (type == 1) // No proxy | ||||||
|             { |             { | ||||||
|                 optionCount = 1; |                 optionCount = 1; | ||||||
|  | @ -90,8 +90,8 @@ namespace ServiceLib.Handler.SysProxy | ||||||
|                 optionCount = string.IsNullOrEmpty(exceptions) ? 2 : 3; |                 optionCount = string.IsNullOrEmpty(exceptions) ? 2 : 3; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             int m_Int = (int)PerConnFlags.PROXY_TYPE_DIRECT; |             var m_Int = (int)PerConnFlags.PROXY_TYPE_DIRECT; | ||||||
|             PerConnOption m_Option = PerConnOption.INTERNET_PER_CONN_FLAGS; |             var m_Option = PerConnOption.INTERNET_PER_CONN_FLAGS; | ||||||
|             if (type == 2) // named proxy |             if (type == 2) // named proxy | ||||||
|             { |             { | ||||||
|                 m_Int = (int)(PerConnFlags.PROXY_TYPE_DIRECT | PerConnFlags.PROXY_TYPE_PROXY); |                 m_Int = (int)(PerConnFlags.PROXY_TYPE_DIRECT | PerConnFlags.PROXY_TYPE_PROXY); | ||||||
|  | @ -103,11 +103,9 @@ namespace ServiceLib.Handler.SysProxy | ||||||
|                 m_Option = PerConnOption.INTERNET_PER_CONN_AUTOCONFIG_URL; |                 m_Option = PerConnOption.INTERNET_PER_CONN_AUTOCONFIG_URL; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             //int optionCount = Utile.IsNullOrEmpty(strProxy) ? 1 : (Utile.IsNullOrEmpty(exceptions) ? 2 : 3); |             var options = new InternetConnectionOption[optionCount]; | ||||||
|             InternetConnectionOption[] options = new InternetConnectionOption[optionCount]; |  | ||||||
|             // USE a proxy server ... |             // USE a proxy server ... | ||||||
|             options[0].m_Option = PerConnOption.INTERNET_PER_CONN_FLAGS; |             options[0].m_Option = PerConnOption.INTERNET_PER_CONN_FLAGS; | ||||||
|             //options[0].m_Value.m_Int = (int)((optionCount < 2) ? PerConnFlags.PROXY_TYPE_DIRECT : (PerConnFlags.PROXY_TYPE_DIRECT | PerConnFlags.PROXY_TYPE_PROXY)); |  | ||||||
|             options[0].m_Value.m_Int = m_Int; |             options[0].m_Value.m_Int = m_Int; | ||||||
|             // use THIS proxy server |             // use THIS proxy server | ||||||
|             if (optionCount > 1) |             if (optionCount > 1) | ||||||
|  | @ -135,20 +133,20 @@ namespace ServiceLib.Handler.SysProxy | ||||||
|             list.dwOptionCount = options.Length; |             list.dwOptionCount = options.Length; | ||||||
|             list.dwOptionError = 0; |             list.dwOptionError = 0; | ||||||
| 
 | 
 | ||||||
|             int optSize = Marshal.SizeOf(typeof(InternetConnectionOption)); |             var optSize = Marshal.SizeOf(typeof(InternetConnectionOption)); | ||||||
|             // make a pointer out of all that ... |             // make a pointer out of all that ... | ||||||
|             nint optionsPtr = Marshal.AllocCoTaskMem(optSize * options.Length); // !! remember to deallocate memory 4 |             var optionsPtr = Marshal.AllocCoTaskMem(optSize * options.Length); // !! remember to deallocate memory 4 | ||||||
|             // copy the array over into that spot in memory ... |             // copy the array over into that spot in memory ... | ||||||
|             for (int i = 0; i < options.Length; ++i) |             for (var i = 0; i < options.Length; ++i) | ||||||
|             { |             { | ||||||
|                 if (Environment.Is64BitOperatingSystem) |                 if (Environment.Is64BitOperatingSystem) | ||||||
|                 { |                 { | ||||||
|                     nint opt = new(optionsPtr.ToInt64() + (i * optSize)); |                     var opt = new nint(optionsPtr.ToInt64() + (i * optSize)); | ||||||
|                     Marshal.StructureToPtr(options[i], opt, false); |                     Marshal.StructureToPtr(options[i], opt, false); | ||||||
|                 } |                 } | ||||||
|                 else |                 else | ||||||
|                 { |                 { | ||||||
|                     nint opt = new(optionsPtr.ToInt32() + (i * optSize)); |                     var opt = new nint(optionsPtr.ToInt32() + (i * optSize)); | ||||||
|                     Marshal.StructureToPtr(options[i], opt, false); |                     Marshal.StructureToPtr(options[i], opt, false); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | @ -156,14 +154,14 @@ namespace ServiceLib.Handler.SysProxy | ||||||
|             list.options = optionsPtr; |             list.options = optionsPtr; | ||||||
| 
 | 
 | ||||||
|             // and then make a pointer out of the whole list |             // and then make a pointer out of the whole list | ||||||
|             nint ipcoListPtr = Marshal.AllocCoTaskMem(list.dwSize); // !! remember to deallocate memory 5 |             var ipcoListPtr = Marshal.AllocCoTaskMem(list.dwSize); // !! remember to deallocate memory 5 | ||||||
|             Marshal.StructureToPtr(list, ipcoListPtr, false); |             Marshal.StructureToPtr(list, ipcoListPtr, false); | ||||||
| 
 | 
 | ||||||
|             // and finally, call the API method! |             // and finally, call the API method! | ||||||
|             bool isSuccess = NativeMethods.InternetSetOption(nint.Zero, |             var isSuccess = NativeMethods.InternetSetOption(nint.Zero, | ||||||
|                InternetOption.INTERNET_OPTION_PER_CONNECTION_OPTION, |                InternetOption.INTERNET_OPTION_PER_CONNECTION_OPTION, | ||||||
|                ipcoListPtr, list.dwSize); |                ipcoListPtr, list.dwSize); | ||||||
|             int returnvalue = 0; // ERROR_SUCCESS |             var returnvalue = 0; // ERROR_SUCCESS | ||||||
|             if (!isSuccess) |             if (!isSuccess) | ||||||
|             {  // get the error codes, they might be helpful |             {  // get the error codes, they might be helpful | ||||||
|                 returnvalue = Marshal.GetLastPInvokeError(); |                 returnvalue = Marshal.GetLastPInvokeError(); | ||||||
|  | @ -171,13 +169,15 @@ namespace ServiceLib.Handler.SysProxy | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 // Notify the system that the registry settings have been changed and cause them to be refreshed |                 // Notify the system that the registry settings have been changed and cause them to be refreshed | ||||||
|                 NativeMethods.InternetSetOption(nint.Zero, InternetOption.INTERNET_OPTION_SETTINGS_CHANGED, nint.Zero, 0); |                 _ = NativeMethods.InternetSetOption(nint.Zero, InternetOption.INTERNET_OPTION_SETTINGS_CHANGED, nint.Zero, 0); | ||||||
|                 NativeMethods.InternetSetOption(nint.Zero, InternetOption.INTERNET_OPTION_REFRESH, nint.Zero, 0); |                 _ = NativeMethods.InternetSetOption(nint.Zero, InternetOption.INTERNET_OPTION_REFRESH, nint.Zero, 0); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             // FREE the data ASAP |             // FREE the data ASAP | ||||||
|             if (list.szConnection != nint.Zero) |             if (list.szConnection != nint.Zero) | ||||||
|  |             { | ||||||
|                 Marshal.FreeHGlobal(list.szConnection); // release mem 3 |                 Marshal.FreeHGlobal(list.szConnection); // release mem 3 | ||||||
|  |             } | ||||||
|             if (optionCount > 1) |             if (optionCount > 1) | ||||||
|             { |             { | ||||||
|                 Marshal.FreeHGlobal(options[1].m_Value.m_StringPtr); // release mem 1 |                 Marshal.FreeHGlobal(options[1].m_Value.m_StringPtr); // release mem 1 | ||||||
|  | @ -204,18 +204,18 @@ namespace ServiceLib.Handler.SysProxy | ||||||
|         /// <exception cref="ApplicationException">Error message with win32 error code</exception> |         /// <exception cref="ApplicationException">Error message with win32 error code</exception> | ||||||
|         private static IEnumerable<string> EnumerateRasEntries() |         private static IEnumerable<string> EnumerateRasEntries() | ||||||
|         { |         { | ||||||
|             int entries = 0; |             var entries = 0; | ||||||
|             // attempt to query with 1 entry buffer |             // attempt to query with 1 entry buffer | ||||||
|             RASENTRYNAME[] rasEntryNames = new RASENTRYNAME[1]; |             var rasEntryNames = new RASENTRYNAME[1]; | ||||||
|             int bufferSize = Marshal.SizeOf(typeof(RASENTRYNAME)); |             var bufferSize = Marshal.SizeOf(typeof(RASENTRYNAME)); | ||||||
|             rasEntryNames[0].dwSize = Marshal.SizeOf(typeof(RASENTRYNAME)); |             rasEntryNames[0].dwSize = Marshal.SizeOf(typeof(RASENTRYNAME)); | ||||||
| 
 | 
 | ||||||
|             uint result = NativeMethods.RasEnumEntries(null, null, rasEntryNames, ref bufferSize, ref entries); |             var result = NativeMethods.RasEnumEntries(null, null, rasEntryNames, ref bufferSize, ref entries); | ||||||
|             // increase buffer if the buffer is not large enough |             // increase buffer if the buffer is not large enough | ||||||
|             if (result == (uint)ErrorCode.ERROR_BUFFER_TOO_SMALL) |             if (result == (uint)ErrorCode.ERROR_BUFFER_TOO_SMALL) | ||||||
|             { |             { | ||||||
|                 rasEntryNames = new RASENTRYNAME[bufferSize / Marshal.SizeOf(typeof(RASENTRYNAME))]; |                 rasEntryNames = new RASENTRYNAME[bufferSize / Marshal.SizeOf(typeof(RASENTRYNAME))]; | ||||||
|                 for (int i = 0; i < rasEntryNames.Length; i++) |                 for (var i = 0; i < rasEntryNames.Length; i++) | ||||||
|                 { |                 { | ||||||
|                     rasEntryNames[i].dwSize = Marshal.SizeOf(typeof(RASENTRYNAME)); |                     rasEntryNames[i].dwSize = Marshal.SizeOf(typeof(RASENTRYNAME)); | ||||||
|                 } |                 } | ||||||
|  | @ -225,7 +225,7 @@ namespace ServiceLib.Handler.SysProxy | ||||||
|             if (result == 0) |             if (result == 0) | ||||||
|             { |             { | ||||||
|                 var entryNames = new List<string>(); |                 var entryNames = new List<string>(); | ||||||
|                 for (int i = 0; i < entries; i++) |                 for (var i = 0; i < entries; i++) | ||||||
|                 { |                 { | ||||||
|                     entryNames.Add(rasEntryNames[i].szEntryName); |                     entryNames.Add(rasEntryNames[i].szEntryName); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 2dust
						2dust