Added unban & unbanip commands (see #868)

This commit is contained in:
Joonas Rikkonen
2018-12-10 14:39:38 +02:00
parent b1b443143f
commit ed37345317
7 changed files with 112 additions and 6 deletions

View File

@@ -1522,6 +1522,16 @@ namespace Barotrauma.Networking
client.SendMessage(msg, NetDeliveryMethod.ReliableUnordered);
}
public override void UnbanPlayer(string playerName, string playerIP)
{
NetOutgoingMessage msg = client.CreateMessage();
msg.Write((byte)ClientPacketHeader.SERVER_COMMAND);
msg.Write((byte)ClientPermissions.Unban);
msg.Write(string.IsNullOrEmpty(playerName) ? "" : playerName);
msg.Write(string.IsNullOrEmpty(playerIP) ? "" : playerIP);
client.SendMessage(msg, NetDeliveryMethod.ReliableUnordered);
}
public void SendCampaignState()
{
MultiPlayerCampaign campaign = GameMain.GameSession.GameMode as MultiPlayerCampaign;

View File

@@ -38,6 +38,8 @@
<Command name="ban"/>
<Command name="banid"/>
<Command name="banip"/>
<Command name="unban"/>
<Command name="unbanip"/>
<Command name="teleportcharacter"/>
<Command name="godmode"/>
<Command name="lockx"/>

View File

@@ -1079,6 +1079,37 @@ namespace Barotrauma
};
}));
commands.Add(new Command("unban", "unban [name]: Unban a specific client.", (string[] args) =>
{
if (GameMain.NetworkMember == null || args.Length == 0) return;
string clientName = string.Join(" ", args);
GameMain.NetworkMember.UnbanPlayer(clientName, "");
},
() =>
{
if (GameMain.Server == null) return null;
return new string[][]
{
GameMain.Server.BanList.BannedNames.Where(name => !string.IsNullOrEmpty(name)).ToArray()
};
}));
commands.Add(new Command("unbanip", "unbanip [ip]: Unban a specific IP.", (string[] args) =>
{
if (GameMain.NetworkMember == null || args.Length == 0) return;
GameMain.NetworkMember.UnbanPlayer("", args[0]);
},
() =>
{
if (GameMain.Server == null) return null;
return new string[][]
{
GameMain.Server.BanList.BannedIPs.Where(ip => !string.IsNullOrEmpty(ip)).ToArray()
};
}));
commands.Add(new Command("banid", "banid [id]: Kick and ban the player with the specified client ID from the server.", (string[] args) =>
{
if (GameMain.NetworkMember == null || args.Length == 0) return;

View File

@@ -41,6 +41,16 @@ namespace Barotrauma.Networking
private List<BannedPlayer> bannedPlayers;
public IEnumerable<string> BannedNames
{
get { return bannedPlayers.Select(bp => bp.Name); }
}
public IEnumerable<string> BannedIPs
{
get { return bannedPlayers.Select(bp => bp.IP); }
}
public BanList()
{
bannedPlayers = new List<BannedPlayer>();
@@ -106,6 +116,36 @@ namespace Barotrauma.Networking
Save();
}
public void UnbanPlayer(string name)
{
var player = bannedPlayers.Find(bp => bp.Name == name);
if (player == null)
{
DebugConsole.Log("Could not unban player \""+name+"\". Matching player not found.");
}
else
{
DebugConsole.Log("Unbanned \"" + name + ".");
bannedPlayers.Remove(player);
Save();
}
}
public void UnbanIP(string ip)
{
var player = bannedPlayers.Find(bp => bp.IP == ip);
if (player == null)
{
DebugConsole.Log("Could not unban IP \"" + ip + "\". Matching player not found.");
}
else
{
DebugConsole.Log("Unbanned \"" + ip + ".");
bannedPlayers.Remove(player);
Save();
}
}
public bool IsBanned(string IP)
{
bannedPlayers.RemoveAll(bp => bp.ExpirationTime.HasValue && DateTime.Now > bp.ExpirationTime.Value);

View File

@@ -16,16 +16,18 @@ namespace Barotrauma.Networking
Kick = 2,
[Description("Ban")]
Ban = 4,
[Description("Revoke Ban")]
Unban = 8,
[Description("Select submarine")]
SelectSub = 8,
SelectSub = 16,
[Description("Select game mode")]
SelectMode = 16,
SelectMode = 32,
[Description("Manage campaign")]
ManageCampaign = 32,
ManageCampaign = 64,
[Description("Console commands")]
ConsoleCommands = 64,
ConsoleCommands = 128,
[Description("Access server log")]
ServerLog = 128
ServerLog = 256
}
class PermissionPreset

View File

@@ -872,6 +872,12 @@ namespace Barotrauma.Networking
}
}
break;
case ClientPermissions.Unban:
string unbannedName = inc.ReadString().ToLowerInvariant();
string unbannedIP = inc.ReadString();
UnbanPlayer(unbannedIP, unbannedIP);
break;
case ClientPermissions.EndRound:
if (gameStarted)
{
@@ -1662,7 +1668,20 @@ namespace Barotrauma.Networking
BanClient(client, reason, range, duration);
}
public override void UnbanPlayer(string playerName, string playerIP)
{
playerName = playerName.ToLowerInvariant();
if (!string.IsNullOrEmpty(playerIP))
{
banList.UnbanIP(playerIP);
}
else if (!string.IsNullOrEmpty(playerName))
{
banList.UnbanPlayer(playerName);
}
}
public void BanClient(Client client, string reason, bool range = false, TimeSpan? duration = null)
{
if (client == null) return;

View File

@@ -216,6 +216,8 @@ namespace Barotrauma.Networking
public virtual void BanPlayer(string kickedName, string reason, bool range = false, TimeSpan? duration = null) { }
public virtual void UnbanPlayer(string playerName, string playerIP) { }
public virtual void Update(float deltaTime)
{
#if CLIENT