mirror of
https://github.com/Sonarr/Sonarr
synced 2025-01-21 06:39:06 +00:00
Simplify X-Forwarded-For handling
This happens in asp.net middleware now Co-Authored-By: ta264 <ta264@users.noreply.github.com>
This commit is contained in:
parent
fd98a179ab
commit
16e2d130e6
1 changed files with 1 additions and 33 deletions
|
@ -168,39 +168,7 @@ namespace Sonarr.Http.Extensions
|
||||||
remoteIP = remoteIP.MapToIPv4();
|
remoteIP = remoteIP.MapToIPv4();
|
||||||
}
|
}
|
||||||
|
|
||||||
var remoteAddress = remoteIP.ToString();
|
return remoteIP.ToString();
|
||||||
|
|
||||||
// Only check if forwarded by a local network reverse proxy
|
|
||||||
if (remoteIP.IsLocalAddress())
|
|
||||||
{
|
|
||||||
var realIPHeader = request.Headers["X-Real-IP"];
|
|
||||||
if (realIPHeader.Any())
|
|
||||||
{
|
|
||||||
return realIPHeader.First().ToString();
|
|
||||||
}
|
|
||||||
|
|
||||||
var forwardedForHeader = request.Headers["X-Forwarded-For"];
|
|
||||||
if (forwardedForHeader.Any())
|
|
||||||
{
|
|
||||||
// Get the first address that was forwarded by a local IP to prevent remote clients faking another proxy
|
|
||||||
foreach (var forwardedForAddress in forwardedForHeader.SelectMany(v => v.Split(',')).Select(v => v.Trim()).Reverse())
|
|
||||||
{
|
|
||||||
if (!IPAddress.TryParse(forwardedForAddress, out remoteIP))
|
|
||||||
{
|
|
||||||
return remoteAddress;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!remoteIP.IsLocalAddress())
|
|
||||||
{
|
|
||||||
return forwardedForAddress;
|
|
||||||
}
|
|
||||||
|
|
||||||
remoteAddress = forwardedForAddress;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return remoteAddress;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void DisableCache(this IHeaderDictionary headers)
|
public static void DisableCache(this IHeaderDictionary headers)
|
||||||
|
|
Loading…
Reference in a new issue