mirror of
				https://github.com/2dust/v2rayN.git
				synced 2025-10-26 02:04:40 +00:00 
			
		
		
		
	Fix (#8175)
This commit is contained in:
		
							parent
							
								
									ecf42cb85d
								
							
						
					
					
						commit
						bbedc4dbb1
					
				
					 2 changed files with 20 additions and 7 deletions
				
			
		|  | @ -294,7 +294,7 @@ public partial class CoreConfigSingboxService | ||||||
|                 var tls = new Tls4Sbox() |                 var tls = new Tls4Sbox() | ||||||
|                 { |                 { | ||||||
|                     enabled = true, |                     enabled = true, | ||||||
|                     record_fragment = _config.CoreBasicItem.EnableFragment, |                     record_fragment = _config.CoreBasicItem.EnableFragment ? true : null, | ||||||
|                     server_name = server_name, |                     server_name = server_name, | ||||||
|                     insecure = Utils.ToBool(node.AllowInsecure.IsNullOrEmpty() ? _config.CoreBasicItem.DefAllowInsecure.ToString().ToLower() : node.AllowInsecure), |                     insecure = Utils.ToBool(node.AllowInsecure.IsNullOrEmpty() ? _config.CoreBasicItem.DefAllowInsecure.ToString().ToLower() : node.AllowInsecure), | ||||||
|                     alpn = node.GetAlpn(), |                     alpn = node.GetAlpn(), | ||||||
|  |  | ||||||
|  | @ -86,8 +86,8 @@ public partial class CoreConfigV2rayService | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // Handle outbounds - append instead of override |         var customOutboundsNode = new JsonArray(); | ||||||
|         var customOutboundsNode = fullConfigTemplateNode["outbounds"] is JsonArray outbounds ? outbounds : new JsonArray(); |          | ||||||
|         foreach (var outbound in v2rayConfig.outbounds) |         foreach (var outbound in v2rayConfig.outbounds) | ||||||
|         { |         { | ||||||
|             if (outbound.protocol.ToLower() is "blackhole" or "dns" or "freedom") |             if (outbound.protocol.ToLower() is "blackhole" or "dns" or "freedom") | ||||||
|  | @ -97,14 +97,27 @@ public partial class CoreConfigV2rayService | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             else if ((outbound.streamSettings?.sockopt?.dialerProxy.IsNullOrEmpty() == true) && (!fullConfigTemplate.ProxyDetour.IsNullOrEmpty()) && !(Utils.IsPrivateNetwork(outbound.settings?.servers?.FirstOrDefault()?.address ?? string.Empty) || Utils.IsPrivateNetwork(outbound.settings?.vnext?.FirstOrDefault()?.address ?? string.Empty))) |             else if (!fullConfigTemplate.ProxyDetour.IsNullOrEmpty()) | ||||||
|  |             { | ||||||
|  |                 var outboundAddress = outbound.settings?.servers?.FirstOrDefault()?.address ?? outbound.settings?.vnext?.FirstOrDefault()?.address ?? string.Empty; | ||||||
|  |                 if (!Utils.IsPrivateNetwork(outboundAddress)) | ||||||
|                 { |                 { | ||||||
|                     outbound.streamSettings ??= new StreamSettings4Ray(); |                     outbound.streamSettings ??= new StreamSettings4Ray(); | ||||||
|                     outbound.streamSettings.sockopt ??= new Sockopt4Ray(); |                     outbound.streamSettings.sockopt ??= new Sockopt4Ray(); | ||||||
|                     outbound.streamSettings.sockopt.dialerProxy = fullConfigTemplate.ProxyDetour; |                     outbound.streamSettings.sockopt.dialerProxy = fullConfigTemplate.ProxyDetour; | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
|             customOutboundsNode.Add(JsonUtils.DeepCopy(outbound)); |             customOutboundsNode.Add(JsonUtils.DeepCopy(outbound)); | ||||||
|         } |         } | ||||||
|  |          | ||||||
|  |         if (fullConfigTemplateNode["outbounds"] is JsonArray templateOutbounds) | ||||||
|  |         { | ||||||
|  |             foreach (var outbound in templateOutbounds) | ||||||
|  |             { | ||||||
|  |                 customOutboundsNode.Add(outbound?.DeepClone()); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|         fullConfigTemplateNode["outbounds"] = customOutboundsNode; |         fullConfigTemplateNode["outbounds"] = customOutboundsNode; | ||||||
| 
 | 
 | ||||||
|         return await Task.FromResult(JsonUtils.Serialize(fullConfigTemplateNode)); |         return await Task.FromResult(JsonUtils.Serialize(fullConfigTemplateNode)); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 DHR60
						DHR60