Require GeoLite2 database path to be specified by the server operator.
This commit is contained in:
@@ -54,13 +54,16 @@ namespace OpenRA.Network
|
||||
|
||||
static Reader database;
|
||||
|
||||
public static void Initialize()
|
||||
public static void Initialize(string databasePath)
|
||||
{
|
||||
if (string.IsNullOrEmpty(databasePath))
|
||||
return;
|
||||
|
||||
try
|
||||
{
|
||||
using (var fileStream = new FileStream("GeoLite2-Country.mmdb.gz", FileMode.Open, FileAccess.Read))
|
||||
using (var gzipStream = new GZipInputStream(fileStream))
|
||||
database = new Reader(gzipStream);
|
||||
using (var fileStream = new FileStream(databasePath, FileMode.Open, FileAccess.Read))
|
||||
using (var gzipStream = new GZipInputStream(fileStream))
|
||||
database = new Reader(gzipStream);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
@@ -68,23 +71,23 @@ namespace OpenRA.Network
|
||||
}
|
||||
}
|
||||
|
||||
public static string LookupCountry(string ip)
|
||||
public static string LookupCountry(IPAddress ip)
|
||||
{
|
||||
const string Unknown = "Unknown Location";
|
||||
if (database != null)
|
||||
{
|
||||
try
|
||||
{
|
||||
var record = database.Find<GeoIP2Record>(ip);
|
||||
if (record != null)
|
||||
return record.Country.Names.English;
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Log.Write("geoip", "LookupCountry failed: {0}", e);
|
||||
}
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
var record = database.Find<GeoIP2Record>(IPAddress.Parse(ip));
|
||||
if (record != null)
|
||||
return record.Country.Names.English;
|
||||
else
|
||||
return Unknown;
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Log.Write("geoip", "LookupCountry failed: {0}", e);
|
||||
return Unknown;
|
||||
}
|
||||
return "Unknown Location";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -149,7 +149,7 @@ namespace OpenRA.Server
|
||||
|
||||
randomSeed = (int)DateTime.Now.ToBinary();
|
||||
|
||||
GeoIP.Initialize();
|
||||
GeoIP.Initialize(settings.GeoIPDatabase);
|
||||
|
||||
if (UPnP.Status == UPnPStatus.Enabled)
|
||||
UPnP.ForwardPort(Settings.ListenPort, Settings.ListenPort).Wait();
|
||||
@@ -348,7 +348,7 @@ namespace OpenRA.Server
|
||||
{
|
||||
Name = OpenRA.Settings.SanitizedPlayerName(handshake.Client.Name),
|
||||
IpAddress = ipAddress.ToString(),
|
||||
Location = GeoIP.LookupCountry(ipAddress.ToString()),
|
||||
Location = GeoIP.LookupCountry(ipAddress),
|
||||
Index = newConn.PlayerIndex,
|
||||
PreferredColor = handshake.Client.PreferredColor,
|
||||
Color = handshake.Client.Color,
|
||||
|
||||
@@ -82,6 +82,10 @@ namespace OpenRA
|
||||
[Desc("Sets the timestamp format. Defaults to the ISO 8601 standard.")]
|
||||
public string TimestampFormat = "yyyy-MM-ddTHH:mm:ss";
|
||||
|
||||
[Desc("Path to a MaxMind GeoLite2 database to use for player geo-location.",
|
||||
"Database files can be downloaded from https://dev.maxmind.com/geoip/geoip2/geolite2/")]
|
||||
public string GeoIPDatabase = null;
|
||||
|
||||
public ServerSettings Clone()
|
||||
{
|
||||
return (ServerSettings)MemberwiseClone();
|
||||
|
||||
Reference in New Issue
Block a user