mirror of
				https://github.com/2dust/v2rayN.git
				synced 2025-10-25 17:54:41 +00:00 
			
		
		
		
	Compare commits
	
		
			No commits in common. "cf3846fbfd67507b438b88ff3e24cc958c761f22" and "3d1bcffdc544b8908ea0c1b7c79b4bcbcfb55a6e" have entirely different histories.
		
	
	
		
			cf3846fbfd
			...
			3d1bcffdc5
		
	
		
					 7 changed files with 38 additions and 41 deletions
				
			
		|  | @ -13,7 +13,7 @@ Check [Release files introduction](https://github.com/2dust/v2rayN/wiki/Release- | |||
| ### Windows | ||||
| - Run `v2rayN.exe` | ||||
| ### Linux | ||||
| - `chmod +x v2rayN` Run `./v2rayN` under user permissions | ||||
| - `chmod +x v2rayN` Run `./v2rayN` | ||||
| ``` | ||||
| Debian 9+ | ||||
| Ubuntu 16.04+ | ||||
|  |  | |||
|  | @ -324,8 +324,7 @@ namespace ServiceLib.Models | |||
| 
 | ||||
|     public class WsSettings4Ray | ||||
|     { | ||||
|         public string? path { get; set; } | ||||
|         public string? host { get; set; } | ||||
|         public string path { get; set; } | ||||
| 
 | ||||
|         public Headers4Ray headers { get; set; } | ||||
|     } | ||||
|  |  | |||
|  | @ -18,7 +18,7 @@ | |||
| 		<PackageReference Include="QRCoder" Version="1.6.0" /> | ||||
| 		<PackageReference Include="CliWrap" Version="3.7.0" />  | ||||
| 		<PackageReference Include="SkiaSharp.QrCode" Version="0.7.0" /> | ||||
| 		<PackageReference Include="ZXing.Net.Bindings.SkiaSharp" Version="0.16.14" /> | ||||
| 		<PackageReference Include="ZXing.Net.Bindings.SkiaSharp" Version="0.16.20" /> | ||||
| 		<PackageReference Include="TaskScheduler" Version="2.11.0" /> | ||||
| 
 | ||||
| 	</ItemGroup> | ||||
|  |  | |||
|  | @ -442,7 +442,7 @@ namespace ServiceLib.Services.CoreConfig | |||
| 
 | ||||
|         #region private gen function | ||||
| 
 | ||||
|         private async Task<int> GenLog(SingboxConfig singboxConfig) | ||||
|         public async Task<int> GenLog(SingboxConfig singboxConfig) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -570,7 +570,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return inbound; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenOutbound(ProfileItem node, Outbound4Sbox outbound) | ||||
|         public async Task<int> GenOutbound(ProfileItem node, Outbound4Sbox outbound) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -694,7 +694,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenOutboundMux(ProfileItem node, Outbound4Sbox outbound) | ||||
|         public async Task<int> GenOutboundMux(ProfileItem node, Outbound4Sbox outbound) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -717,7 +717,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenOutboundTls(ProfileItem node, Outbound4Sbox outbound) | ||||
|         public async Task<int> GenOutboundTls(ProfileItem node, Outbound4Sbox outbound) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -767,7 +767,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenOutboundTransport(ProfileItem node, Outbound4Sbox outbound) | ||||
|         public async Task<int> GenOutboundTransport(ProfileItem node, Outbound4Sbox outbound) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -994,7 +994,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             } | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenRoutingUserRule(RulesItem item, List<Rule4Sbox> rules) | ||||
|         public async Task<int> GenRoutingUserRule(RulesItem item, List<Rule4Sbox> rules) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -1152,7 +1152,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return true; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenDns(ProfileItem? node, SingboxConfig singboxConfig) | ||||
|         public async Task<int> GenDns(ProfileItem? node, SingboxConfig singboxConfig) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -1183,7 +1183,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenDnsDomains(ProfileItem? node, SingboxConfig singboxConfig, DNSItem? dNSItem) | ||||
|         public async Task<int> GenDnsDomains(ProfileItem? node, SingboxConfig singboxConfig, DNSItem? dNSItem) | ||||
|         { | ||||
|             var dns4Sbox = singboxConfig.dns ?? new(); | ||||
|             dns4Sbox.servers ??= []; | ||||
|  | @ -1236,7 +1236,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenExperimental(SingboxConfig singboxConfig) | ||||
|         public async Task<int> GenExperimental(SingboxConfig singboxConfig) | ||||
|         { | ||||
|             //if (_config.guiItem.enableStatistics) | ||||
|             { | ||||
|  |  | |||
|  | @ -359,7 +359,7 @@ namespace ServiceLib.Services.CoreConfig | |||
| 
 | ||||
|         #region private gen function | ||||
| 
 | ||||
|         private async Task<int> GenLog(V2rayConfig v2rayConfig) | ||||
|         public async Task<int> GenLog(V2rayConfig v2rayConfig) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -384,7 +384,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenInbounds(V2rayConfig v2rayConfig) | ||||
|         public async Task<int> GenInbounds(V2rayConfig v2rayConfig) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -481,7 +481,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenRoutingUserRule(RulesItem4Ray? rule, V2rayConfig v2rayConfig) | ||||
|         public async Task<int> GenRoutingUserRule(RulesItem4Ray? rule, V2rayConfig v2rayConfig) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -559,7 +559,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenOutbound(ProfileItem node, Outbounds4Ray outbound) | ||||
|         public async Task<int> GenOutbound(ProfileItem node, Outbounds4Ray outbound) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -754,7 +754,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenOutboundMux(ProfileItem node, Outbounds4Ray outbound, bool enabled) | ||||
|         public async Task<int> GenOutboundMux(ProfileItem node, Outbounds4Ray outbound, bool enabled) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -778,15 +778,14 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenBoundStreamSettings(ProfileItem node, StreamSettings4Ray streamSettings) | ||||
|         public async Task<int> GenBoundStreamSettings(ProfileItem node, StreamSettings4Ray streamSettings) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|                 streamSettings.network = node.GetNetwork(); | ||||
|                 var host = node.RequestHost.TrimEx(); | ||||
|                 var path = node.Path.TrimEx(); | ||||
|                 var sni = node.Sni.TrimEx(); | ||||
|                 var useragent = ""; | ||||
|                 string host = node.RequestHost.TrimEx(); | ||||
|                 string sni = node.Sni; | ||||
|                 string useragent = ""; | ||||
|                 if (!_config.CoreBasicItem.DefUserAgent.IsNullOrEmpty()) | ||||
|                 { | ||||
|                     try | ||||
|  | @ -859,9 +858,9 @@ namespace ServiceLib.Services.CoreConfig | |||
|                         { | ||||
|                             type = node.HeaderType | ||||
|                         }; | ||||
|                         if (Utils.IsNotEmpty(path)) | ||||
|                         if (Utils.IsNotEmpty(node.Path)) | ||||
|                         { | ||||
|                             kcpSettings.seed = path; | ||||
|                             kcpSettings.seed = node.Path; | ||||
|                         } | ||||
|                         streamSettings.kcpSettings = kcpSettings; | ||||
|                         break; | ||||
|  | @ -869,10 +868,9 @@ namespace ServiceLib.Services.CoreConfig | |||
|                     case nameof(ETransport.ws): | ||||
|                         WsSettings4Ray wsSettings = new(); | ||||
|                         wsSettings.headers = new Headers4Ray(); | ||||
|                      | ||||
|                         string path = node.Path; | ||||
|                         if (Utils.IsNotEmpty(host)) | ||||
|                         { | ||||
|                             wsSettings.host = host; | ||||
|                             wsSettings.headers.Host = host; | ||||
|                         } | ||||
|                         if (Utils.IsNotEmpty(path)) | ||||
|  | @ -890,9 +888,9 @@ namespace ServiceLib.Services.CoreConfig | |||
|                     case nameof(ETransport.httpupgrade): | ||||
|                         HttpupgradeSettings4Ray httpupgradeSettings = new(); | ||||
| 
 | ||||
|                         if (Utils.IsNotEmpty(path)) | ||||
|                         if (Utils.IsNotEmpty(node.Path)) | ||||
|                         { | ||||
|                             httpupgradeSettings.path = path; | ||||
|                             httpupgradeSettings.path = node.Path; | ||||
|                         } | ||||
|                         if (Utils.IsNotEmpty(host)) | ||||
|                         { | ||||
|  | @ -911,9 +909,9 @@ namespace ServiceLib.Services.CoreConfig | |||
|                             scMinPostsIntervalMs = "30-50" | ||||
|                         }; | ||||
| 
 | ||||
|                         if (Utils.IsNotEmpty(path)) | ||||
|                         if (Utils.IsNotEmpty(node.Path)) | ||||
|                         { | ||||
|                             xhttpSettings.path = path; | ||||
|                             xhttpSettings.path = node.Path; | ||||
|                         } | ||||
|                         if (Utils.IsNotEmpty(host)) | ||||
|                         { | ||||
|  | @ -939,7 +937,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|                         { | ||||
|                             httpSettings.host = Utils.String2List(host); | ||||
|                         } | ||||
|                         httpSettings.path = path; | ||||
|                         httpSettings.path = node.Path; | ||||
| 
 | ||||
|                         streamSettings.httpSettings = httpSettings; | ||||
| 
 | ||||
|  | @ -949,7 +947,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|                         QuicSettings4Ray quicsettings = new() | ||||
|                         { | ||||
|                             security = host, | ||||
|                             key = path, | ||||
|                             key = node.Path, | ||||
|                             header = new Header4Ray | ||||
|                             { | ||||
|                                 type = node.HeaderType | ||||
|  | @ -973,7 +971,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|                         GrpcSettings4Ray grpcSettings = new() | ||||
|                         { | ||||
|                             authority = Utils.IsNullOrEmpty(host) ? null : host, | ||||
|                             serviceName = path, | ||||
|                             serviceName = node.Path, | ||||
|                             multiMode = node.HeaderType == Global.GrpcMultiMode, | ||||
|                             idle_timeout = _config.GrpcItem.IdleTimeout, | ||||
|                             health_check_timeout = _config.GrpcItem.HealthCheckTimeout, | ||||
|  | @ -1003,9 +1001,9 @@ namespace ServiceLib.Services.CoreConfig | |||
|                             request = request.Replace("$requestUserAgent$", $"{useragent.AppendQuotes()}"); | ||||
|                             //Path | ||||
|                             string pathHttp = @"/"; | ||||
|                             if (Utils.IsNotEmpty(path)) | ||||
|                             if (Utils.IsNotEmpty(node.Path)) | ||||
|                             { | ||||
|                                 string[] arrPath = path.Split(','); | ||||
|                                 string[] arrPath = node.Path.Split(','); | ||||
|                                 pathHttp = string.Join(",".AppendQuotes(), arrPath); | ||||
|                             } | ||||
|                             request = request.Replace("$requestPath$", $"{pathHttp.AppendQuotes()}"); | ||||
|  | @ -1023,7 +1021,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenDns(ProfileItem? node, V2rayConfig v2rayConfig) | ||||
|         public async Task<int> GenDns(ProfileItem? node, V2rayConfig v2rayConfig) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|  | @ -1086,7 +1084,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenDnsDomains(ProfileItem? node, JsonNode dns, DNSItem? dNSItem) | ||||
|         public async Task<int> GenDnsDomains(ProfileItem? node, JsonNode dns, DNSItem? dNSItem) | ||||
|         { | ||||
|             if (node == null) | ||||
|             { return 0; } | ||||
|  | @ -1106,7 +1104,7 @@ namespace ServiceLib.Services.CoreConfig | |||
|             return 0; | ||||
|         } | ||||
| 
 | ||||
|         private async Task<int> GenStatistic(V2rayConfig v2rayConfig) | ||||
|         public async Task<int> GenStatistic(V2rayConfig v2rayConfig) | ||||
|         { | ||||
|             if (_config.GuiItem.EnableStatistics) | ||||
|             { | ||||
|  |  | |||
|  | @ -23,7 +23,7 @@ | |||
|                 </StackPanel> | ||||
| 
 | ||||
|                 <StackPanel | ||||
|                     Width="120" | ||||
|                     Width="240" | ||||
|                     Margin="8,0" | ||||
|                     VerticalAlignment="Center" | ||||
|                     DockPanel.Dock="Left"> | ||||
|  |  | |||
|  | @ -27,7 +27,7 @@ | |||
|                 </StackPanel> | ||||
| 
 | ||||
|                 <StackPanel | ||||
|                     Width="120" | ||||
|                     Width="240" | ||||
|                     Margin="{StaticResource MarginLeftRight8}" | ||||
|                     VerticalAlignment="Center" | ||||
|                     DockPanel.Dock="Left"> | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue