diff --git a/TShockAPI/BanManager.cs b/TShockAPI/BanManager.cs
index f7905914..7d67bdf1 100644
--- a/TShockAPI/BanManager.cs
+++ b/TShockAPI/BanManager.cs
@@ -74,6 +74,7 @@ namespace TShockAPI
public void RemoveBan(Ban ban)
{
Bans.Remove(ban);
+ SaveBans();
}
///
diff --git a/TShockAPI/Commands.cs b/TShockAPI/Commands.cs
index 629945b6..e9853157 100755
--- a/TShockAPI/Commands.cs
+++ b/TShockAPI/Commands.cs
@@ -44,11 +44,6 @@ namespace TShockAPI
get { return Player.TPlayer; }
}
- public int PlayerID
- {
- get { return Player.Index; }
- }
-
public CommandArgs(string message, TSPlayer ply, List args)
{
Message = message;
@@ -80,6 +75,7 @@ namespace TShockAPI
}
catch (Exception e)
{
+ ply.SendMessage("Command failed, check logs for more details.");
Log.Error(e.ToString());
}
@@ -97,14 +93,112 @@ namespace TShockAPI
}
public static class Commands
{
- public static List ChatCommands = new List();
+ private static List ChatCommands = new List();
+
+ public static void InitCommands()
+ {
+ ChatCommands.Add(new Command("kick", "kick", Kick));
+ ChatCommands.Add(new Command("ban", "ban", Ban));
+ ChatCommands.Add(new Command("banip", "ban", BanIP));
+ ChatCommands.Add(new Command("unban", "unban", UnBan));
+ ChatCommands.Add(new Command("unbanip", "unban", UnBanIP));
+ ChatCommands.Add(new Command("off", "maintenance", Off));
+ ChatCommands.Add(new Command("off-nosave", "maintenance", OffNoSave));
+ ChatCommands.Add(new Command("checkupdates", "maintenance", CheckUpdates));
+ ChatCommands.Add(new Command("dropmeteor", "causeevents", DropMeteor));
+ ChatCommands.Add(new Command("star", "causeevents", Star));
+ ChatCommands.Add(new Command("bloodmoon", "causeevents", Bloodmoon));
+ ChatCommands.Add(new Command("invade", "causeevents", Invade));
+ ChatCommands.Add(new Command("eater", "spawnboss", Eater));
+ ChatCommands.Add(new Command("eye", "spawnboss", Eye));
+ ChatCommands.Add(new Command("skeletron", "spawnboss", Skeletron));
+ ChatCommands.Add(new Command("hardcore", "spawnboss", Hardcore));
+ ChatCommands.Add(new Command("spawnmob", "spawnmob", SpawnMob));
+ ChatCommands.Add(new Command("sm", "spawnmob", SpawnMob));
+ ChatCommands.Add(new Command("home", "tp", Home));
+ ChatCommands.Add(new Command("spawn", "tp", Spawn));
+ ChatCommands.Add(new Command("tp", "tp", TP));
+ ChatCommands.Add(new Command("tphere", "tp", TPHere));
+ ChatCommands.Add(new Command("reload", "cfg", Reload));
+ ChatCommands.Add(new Command("debug-config", "cfg", DebugConfiguration));
+ ChatCommands.Add(new Command("password", "cfg", Password));
+ ChatCommands.Add(new Command("save", "cfg", Save));
+ ChatCommands.Add(new Command("maxspawns", "cfg", MaxSpawns));
+ ChatCommands.Add(new Command("spawnrate", "cfg", SpawnRate));
+ ChatCommands.Add(new Command("time", "cfg", Time));
+ ChatCommands.Add(new Command("slap", "pvpfun", Slap));
+ ChatCommands.Add(new Command("antibuild", "editspawn", ToggleAntiBuild));
+ ChatCommands.Add(new Command("protectspawn", "editspawn", ProtectSpawn));
+ ChatCommands.Add(new Command("help", "", Help));
+ ChatCommands.Add(new Command("playing", "", Playing));
+ ChatCommands.Add(new Command("online", "", Playing));
+ ChatCommands.Add(new Command("who", "", Playing));
+ ChatCommands.Add(new Command("auth", "", AuthToken));
+ ChatCommands.Add(new Command("me", "", ThirdPerson));
+ ChatCommands.Add(new Command("p", "", PartyChat));
+ ChatCommands.Add(new Command("rules", "", Rules));
+ if (ConfigurationManager.DistributationAgent != "terraria-online")
+ {
+ ChatCommands.Add(new Command("kill", "kill", Kill));
+ ChatCommands.Add(new Command("butcher", "cheat", Butcher));
+ ChatCommands.Add(new Command("i", "cheat", Item));
+ ChatCommands.Add(new Command("item", "cheat", Item));
+ ChatCommands.Add(new Command("give", "cheat", Give));
+ ChatCommands.Add(new Command("heal", "cheat", Heal));
+ }
+ }
+
+ public static void AddUpdateCommand()
+ {
+ Commands.ChatCommands.Add(new Command("updatenow", "maintenance", Commands.UpdateNow));
+ }
+
+ public static bool HandleCommand(TSPlayer player, string text)
+ {
+ string cmdText = text.Remove(0, 1);
+
+ var args = Commands.ParseParameters(cmdText);
+ if (args.Count < 1)
+ return false;
+
+ string cmdName = args[0];
+ args.RemoveAt(0);
+
+ Command cmd = null;
+ foreach (Command command in Commands.ChatCommands)
+ {
+ if (command.Name.Equals(cmdName))
+ {
+ cmd = command;
+ }
+ }
+
+ if (cmd == null)
+ {
+ player.SendMessage("That command does not exist, try /help", Color.Red);
+ }
+ else
+ {
+ if (!cmd.CanRun(player))
+ {
+ Tools.SendLogs(string.Format("{0} tried to execute {1}", player.Name, cmd.Name), Color.Red);
+ player.SendMessage("You do not have access to that command.", Color.Red);
+ }
+ else
+ {
+ Tools.SendLogs(string.Format("{0} executed: /{1}", player.Name, cmdText), Color.Red);
+ cmd.Run(cmdText, player, args);
+ }
+ }
+ return true;
+ }
///
/// Parses a string of parameters into a list. Handles quotes.
///
///
///
- public static List ParseParameters(string str)
+ private static List ParseParameters(string str)
{
var ret = new List();
var sb = new StringBuilder();
@@ -161,7 +255,7 @@ namespace TShockAPI
return ret;
}
- static char GetEscape(char c)
+ private static char GetEscape(char c)
{
switch (c)
{
@@ -176,105 +270,14 @@ namespace TShockAPI
}
}
- static bool IsWhiteSpace(char c)
+ private static bool IsWhiteSpace(char c)
{
return c == ' ' || c == '\t' || c == '\n';
}
- public static void InitCommands()
- {
- ChatCommands.Add(new Command("kick", "kick", Kick));
- ChatCommands.Add(new Command("ban", "ban", Ban));
- ChatCommands.Add(new Command("banip", "ban", BanIP));
- ChatCommands.Add(new Command("unban", "unban", UnBan));
- ChatCommands.Add(new Command("unbanip", "unban", UnBanIP));
- ChatCommands.Add(new Command("off", "maintenance", Off));
- ChatCommands.Add(new Command("off-nosave", "maintenance", OffNoSave));
- ChatCommands.Add(new Command("checkupdates", "maintenance", CheckUpdates));
- ChatCommands.Add(new Command("dropmeteor", "causeevents", DropMeteor));
- ChatCommands.Add(new Command("star", "causeevents", Star));
- ChatCommands.Add(new Command("bloodmoon", "causeevents", Bloodmoon));
- ChatCommands.Add(new Command("invade", "causeevents", Invade));
- ChatCommands.Add(new Command("eater", "spawnboss", Eater));
- ChatCommands.Add(new Command("eye", "spawnboss", Eye));
- ChatCommands.Add(new Command("skeletron", "spawnboss", Skeletron));
- ChatCommands.Add(new Command("hardcore", "spawnboss", Hardcore));
- ChatCommands.Add(new Command("spawnmob", "spawnmob", SpawnMob));
- ChatCommands.Add(new Command("home", "tp", Home));
- ChatCommands.Add(new Command("spawn", "tp", Spawn));
- ChatCommands.Add(new Command("tp", "tp", TP));
- ChatCommands.Add(new Command("tphere", "tp", TPHere));
- ChatCommands.Add(new Command("reload", "cfg", Reload));
- ChatCommands.Add(new Command("debug-config", "cfg", DebugConfiguration));
- ChatCommands.Add(new Command("password", "cfg", Password));
- ChatCommands.Add(new Command("save", "cfg", Save));
- ChatCommands.Add(new Command("maxspawns", "cfg", MaxSpawns));
- ChatCommands.Add(new Command("spawnrate", "cfg", SpawnRate));
- ChatCommands.Add(new Command("time", "cfg", Time));
- ChatCommands.Add(new Command("slap", "pvpfun", Slap));
- ChatCommands.Add(new Command("antibuild", "editspawn", ToggleAntiBuild));
- ChatCommands.Add(new Command("protectspawn", "editspawn", ProtectSpawn));
- ChatCommands.Add(new Command("help", "", Help));
- ChatCommands.Add(new Command("playing", "", Playing));
- ChatCommands.Add(new Command("online", "", Playing));
- ChatCommands.Add(new Command("who", "", Playing));
- ChatCommands.Add(new Command("auth", "", AuthToken));
- ChatCommands.Add(new Command("me", "", ThirdPerson));
- ChatCommands.Add(new Command("p", "", PartyChat));
- ChatCommands.Add(new Command("rules", "", Rules));
- if (ConfigurationManager.DistributationAgent != "terraria-online")
- {
- ChatCommands.Add(new Command("kill", "kill", Kill));
- ChatCommands.Add(new Command("butcher", "cheat", Butcher));
- ChatCommands.Add(new Command("i", "cheat", Item));
- ChatCommands.Add(new Command("item", "cheat", Item));
- ChatCommands.Add(new Command("give", "cheat", Give));
- ChatCommands.Add(new Command("heal", "cheat", Heal));
- }
- }
+ #region Player Management Commands
- #region Command Methods
-
- public static void Rules(CommandArgs args)
- {
- Tools.ShowFileToUser(args.Player, "rules.txt");
- }
-
- public static void CheckUpdates(CommandArgs args)
- {
- ThreadPool.QueueUserWorkItem(UpdateManager.CheckUpdate);
- }
-
- public static void PartyChat(CommandArgs args)
- {
- int playerTeam = args.Player.Team;
- if (playerTeam != 0)
- {
- string msg = string.Format("<{0}> {1}", args.Player.Name, args.Message.Remove(0, 2));
- foreach (TSPlayer player in TShock.Players)
- {
- if (player != null && player.Active && player.Team == playerTeam)
- player.SendMessage(msg, Main.teamColor[playerTeam].R, Main.teamColor[playerTeam].G, Main.teamColor[playerTeam].B);
- }
- }
- else
- {
- args.Player.SendMessage("You are not in a party!", 255, 240, 20);
- }
- }
-
- public static void ThirdPerson(CommandArgs args)
- {
- string msg = args.Message.Remove(0, 3);
- Tools.Broadcast(string.Format("*{0} {1}", args.Player.Name, msg), 205, 133, 63);
- }
-
- public static void Playing(CommandArgs args)
- {
- args.Player.SendMessage(string.Format("Current players: {0}.", Tools.GetPlayers()), 255, 240, 20);
- }
-
- public static void Kick(CommandArgs args)
+ private static void Kick(CommandArgs args)
{
if (args.Parameters.Count < 1)
{
@@ -307,10 +310,8 @@ namespace TShockAPI
}
}
- public static void Ban(CommandArgs args)
+ private static void Ban(CommandArgs args)
{
- int adminplr = args.PlayerID;
-
if (args.Parameters.Count < 1)
{
args.Player.SendMessage("Invalid syntax! Proper syntax: /ban [reason]", Color.Red);
@@ -342,7 +343,7 @@ namespace TShockAPI
}
}
- public static void BanIP(CommandArgs args)
+ private static void BanIP(CommandArgs args)
{
if (args.Parameters.Count < 1)
{
@@ -360,7 +361,7 @@ namespace TShockAPI
TShock.Bans.AddBan(ip, "", reason);
}
- public static void UnBan(CommandArgs args)
+ private static void UnBan(CommandArgs args)
{
if (args.Parameters.Count < 1)
{
@@ -386,7 +387,7 @@ namespace TShockAPI
}
}
- public static void UnBanIP(CommandArgs args)
+ private static void UnBanIP(CommandArgs args)
{
if (args.Parameters.Count < 1)
{
@@ -412,54 +413,66 @@ namespace TShockAPI
}
}
- public static void Off(CommandArgs args)
+ #endregion Player Management Commands
+
+ #region Server Maintenence Commands
+
+ private static void Off(CommandArgs args)
{
Tools.ForceKickAll("Server shutting down!");
WorldGen.saveWorld();
Netplay.disconnect = true;
}
- public static void OffNoSave(CommandArgs args)
+ private static void OffNoSave(CommandArgs args)
{
Tools.ForceKickAll("Server shutting down!");
Netplay.disconnect = true;
}
- public static void DebugConfiguration(CommandArgs args)
+ private static void CheckUpdates(CommandArgs args)
{
- args.Player.SendMessage("TShock Config:");
- string lineOne = string.Format("BanCheater : {0}, KickCheater : {1}, BanGriefer : {2}, KickGriefer : {3}",
- ConfigurationManager.BanCheater, ConfigurationManager.KickCheater,
- ConfigurationManager.BanGriefer, ConfigurationManager.KickGriefer);
- args.Player.SendMessage(lineOne, Color.Yellow);
- string lineTwo = string.Format("BanTnt : {0}, KickTnt : {1}, BanBoom : {2}, KickBoom : {3}",
- ConfigurationManager.BanTnt, ConfigurationManager.KickTnt,
- ConfigurationManager.BanBoom, ConfigurationManager.KickBoom);
- args.Player.SendMessage(lineTwo, Color.Yellow);
- string lineThree = string.Format("RangeChecks : {0}, DisableBuild : {1}, ProtectSpawn : {2}, ProtectRadius : {3}",
- ConfigurationManager.RangeChecks, ConfigurationManager.DisableBuild,
- ConfigurationManager.SpawnProtect, ConfigurationManager.SpawnProtectRadius);
- args.Player.SendMessage(lineThree, Color.Yellow);
- string lineFour = string.Format("MaxSlots : {0}, SpamChecks : {1}, InvMultiplier : {2}, DMS : {3}, SpawnRate {4}",
- ConfigurationManager.MaxSlots, ConfigurationManager.SpamChecks,
- ConfigurationManager.InvasionMultiplier, ConfigurationManager.DefaultMaxSpawns,
- ConfigurationManager.DefaultSpawnRate);
- args.Player.SendMessage(lineFour, Color.Yellow);
+ ThreadPool.QueueUserWorkItem(UpdateManager.CheckUpdate);
}
- public static void Reload(CommandArgs args)
+ private static void UpdateNow(CommandArgs args)
{
- FileTools.SetupConfig();
- args.Player.SendMessage("Configuration reload complete. Some changes may require server restart.");
+ Process TServer = Process.GetCurrentProcess();
+
+ StreamWriter sw = new StreamWriter("pid");
+ sw.Write(TServer.Id);
+ sw.Close();
+
+ sw = new StreamWriter("pn");
+ sw.Write(TServer.ProcessName + " " + Environment.CommandLine);
+ sw.Close();
+
+ WebClient client = new WebClient();
+ client.Headers.Add("user-agent", "TShock");
+ byte[] updatefile = client.DownloadData("http://tsupdate.shankshock.com/UpdateTShock.exe");
+
+ BinaryWriter bw = new BinaryWriter(new FileStream("UpdateTShock.exe", FileMode.Create));
+ bw.Write(updatefile);
+ bw.Close();
+
+ Process.Start(new ProcessStartInfo("UpdateTShock.exe"));
+
+ Tools.ForceKickAll("Server shutting down for update!");
+ WorldGen.saveWorld();
+ Netplay.disconnect = true;
}
- public static void DropMeteor(CommandArgs args)
+ #endregion Server Maintenence Commands
+
+ #region Cause Events and Spawn Monsters Commands
+
+ private static void DropMeteor(CommandArgs args)
{
WorldGen.spawnMeteor = false;
WorldGen.dropMeteor();
}
- public static void Star(CommandArgs args)
+ private static void Star(CommandArgs args)
{
int penis56 = 12;
int penis57 = Main.rand.Next(Main.maxTilesX - 50) + 100;
@@ -475,7 +488,7 @@ namespace TShockAPI
Projectile.NewProjectile(vector.X, vector.Y, speedX, speedY, 12, 0x3e8, 10f, Main.myPlayer);
}
- public static void Bloodmoon(CommandArgs args)
+ private static void Bloodmoon(CommandArgs args)
{
Tools.Broadcast(string.Format("{0} turned on blood moon.", args.Player.Name));
Main.bloodMoon = true;
@@ -485,34 +498,7 @@ namespace TShockAPI
NetMessage.syncPlayers();
}
- public static void Eater(CommandArgs args)
- {
- Tools.NewNPC(NPCList.WORLD_EATER, args.Player);
- Tools.Broadcast(string.Format("{0} has spawned an eater of worlds!", args.Player.Name));
- }
-
- public static void Eye(CommandArgs args)
- {
- Tools.NewNPC(NPCList.EYE, args.Player);
- Tools.Broadcast(string.Format("{0} has spawned an eye!", args.Player.Name));
- }
-
- public static void Skeletron(CommandArgs args)
- {
- Tools.NewNPC(NPCList.SKELETRON, args.Player);
- Tools.Broadcast(string.Format("{0} has spawned skeletron!", args.Player.Name));
- }
-
- public static void Hardcore(CommandArgs args)
- {
- foreach (NPCList type in Enum.GetValues(typeof(NPCList)))
- {
- Tools.NewNPC(type, args.Player);
- }
- Tools.Broadcast(string.Format("{0} has spawned all bosses!", args.Player.Name));
- }
-
- public static void Invade(CommandArgs args)
+ private static void Invade(CommandArgs args)
{
if (Main.invasionSize <= 0)
{
@@ -526,107 +512,34 @@ namespace TShockAPI
}
}
- public static void Password(CommandArgs args)
+ private static void Eater(CommandArgs args)
{
- string passwd = args.Message.Remove(0, 9).Trim();
- Netplay.password = passwd;
- args.Player.SendMessage(string.Format("Server password changed to: {0}", passwd));
+ Tools.NewNPC(NPCList.WORLD_EATER, args.Player);
+ Tools.Broadcast(string.Format("{0} has spawned an eater of worlds!", args.Player.Name));
}
- public static void Save(CommandArgs args)
+ private static void Eye(CommandArgs args)
{
- WorldGen.saveWorld();
- args.Player.SendMessage("World saved.");
+ Tools.NewNPC(NPCList.EYE, args.Player);
+ Tools.Broadcast(string.Format("{0} has spawned an eye!", args.Player.Name));
}
- public static void Home(CommandArgs args)
+ private static void Skeletron(CommandArgs args)
{
- int ply = args.PlayerID;
- TShock.Teleport(ply, Main.player[args.PlayerID].SpawnX * 16 + 8 - Main.player[ply].width / 2,
- Main.player[args.PlayerID].SpawnY * 16 - Main.player[ply].height);
- args.Player.SendMessage("Teleported to your spawnpoint.");
+ Tools.NewNPC(NPCList.SKELETRON, args.Player);
+ Tools.Broadcast(string.Format("{0} has spawned skeletron!", args.Player.Name));
}
- public static void Spawn(CommandArgs args)
+ private static void Hardcore(CommandArgs args)
{
- int ply = args.PlayerID;
- TShock.Teleport(ply, Main.spawnTileX * 16 + 8 - Main.player[ply].width / 2,
- Main.spawnTileY * 16 - Main.player[ply].height);
- args.Player.SendMessage("Teleported to the map's spawnpoint.");
+ foreach (NPCList type in Enum.GetValues(typeof(NPCList)))
+ {
+ Tools.NewNPC(type, args.Player);
+ }
+ Tools.Broadcast(string.Format("{0} has spawned all bosses!", args.Player.Name));
}
- public static void AuthToken(CommandArgs args)
- {
- if (ConfigurationManager.AuthToken == 0)
- {
- return;
- }
- int givenCode = Convert.ToInt32(args.Parameters[0]);
- if (givenCode == ConfigurationManager.AuthToken)
- {
- TextWriter tw = new StreamWriter(FileTools.UsersPath, true);
- tw.Write("\n" +
- Tools.GetRealIP(
- Convert.ToString(Netplay.serverSock[args.PlayerID].tcpClient.Client.RemoteEndPoint)) +
- " superadmin");
- args.Player.SendMessage("SuperAdmin authenticated. Please re-connect using the same IP.");
- ConfigurationManager.AuthToken = 0;
- tw.Close();
- }
- }
-
- public static void TP(CommandArgs args)
- {
- int adminplr = args.PlayerID;
-
- if (args.Parameters.Count < 1)
- {
- args.Player.SendMessage("Invalid syntax! Proper syntax: /tp ", Color.Red);
- return;
- }
-
- string plStr = String.Join(" ", args.Parameters);
- var player = Tools.FindPlayer(plStr);
- if (player.Count == 0)
- args.Player.SendMessage("Invalid player!", Color.Red);
- else if (player.Count > 1)
- args.Player.SendMessage("More than one player matched!", Color.Red);
- else
- {
- var plr = player[0];
- TShock.Teleport(adminplr, plr.TPlayer.position.X, plr.TPlayer.position.Y);
- args.Player.SendMessage(string.Format("Teleported to {0}", plr.Name));
- }
- }
-
- public static void TPHere(CommandArgs args)
- {
- if (args.Parameters.Count < 1)
- {
- args.Player.SendMessage("Invalid syntax! Proper syntax: /tphere ", Color.Red);
- return;
- }
-
- string plStr = String.Join(" ", args.Parameters);
- var player = Tools.FindPlayer(plStr);
- if (player.Count == 0)
- {
- args.Player.SendMessage("Invalid player!", Color.Red);
- }
- else if (player.Count > 1)
- {
- args.Player.SendMessage("More than one player matched!", Color.Red);
- }
- else
- {
- var plr = player[0];
- TShock.Teleport(plr.Index, args.TPlayer.position.X, args.TPlayer.position.Y);
- plr.SendMessage(string.Format("You were teleported to {0}.", plr.Name));
- args.Player.SendMessage(string.Format("You brought {0} here.", plr.Name));
- }
- }
-
- public static void SpawnMob(CommandArgs args)
+ private static void SpawnMob(CommandArgs args)
{
if (args.Parameters.Count < 1 || args.Parameters.Count > 2)
{
@@ -661,79 +574,55 @@ namespace TShockAPI
args.Player.SendMessage("Invalid mob type!", Color.Red);
}
- public static void Item(CommandArgs args)
+ #endregion Cause Events and Spawn Monsters Commands
+
+ #region Teleport Commands
+
+ private static void Home(CommandArgs args)
{
- int adminplr = args.PlayerID;
-
- if (args.Parameters.Count < 1)
- {
- args.Player.SendMessage("Invalid syntax! Proper syntax: /item - ", Color.Red);
- return;
- }
- if (args.Parameters[0].Length == 0)
- {
- args.Player.SendMessage("Missing item name/id", Color.Red);
- return;
- }
-
- int type = -1;
- if (!int.TryParse(args.Parameters[0], out type))
- type = TShock.GetItemID(String.Join(" ", args.Parameters));
-
- if (type < 1 || type >= Main.maxItemTypes)
- {
- args.Player.SendMessage("Invalid item type!", Color.Red);
- return;
- }
-
- bool flag = false;
- for (int i = 0; i < 40; i++)
- {
- if (!Main.player[adminplr].inventory[i].active)
- {
- int id = Terraria.Item.NewItem(0, 0, 0, 0, type, 1, true);
- Main.item[id].position.X = args.Player.X;
- Main.item[id].position.Y = args.Player.Y;
- Main.item[id].stack = Main.item[id].maxStack;
- NetMessage.SendData(21, -1, -1, "", id, 0f, 0f, 0f);
- args.Player.SendMessage(string.Format("Got some {0}.", Main.item[id].name));
- flag = true;
- break;
- }
- }
- if (!flag)
- args.Player.SendMessage("You don't have free slots!", Color.Red);
+ TShock.Teleport(args.Player.Index, args.TPlayer.SpawnX * 16 + 8 - args.TPlayer.width / 2,
+ args.TPlayer.SpawnY * 16 - args.TPlayer.height);
+ args.Player.SendMessage("Teleported to your spawnpoint.");
}
- public static void Give(CommandArgs args)
+ private static void Spawn(CommandArgs args)
{
- if (args.Parameters.Count != 2)
+ TShock.Teleport(args.Player.Index, Main.spawnTileX * 16 + 8 - args.TPlayer.width / 2,
+ Main.spawnTileY * 16 - args.TPlayer.height);
+ args.Player.SendMessage("Teleported to the map's spawnpoint.");
+ }
+
+ private static void TP(CommandArgs args)
+ {
+ if (args.Parameters.Count < 1)
{
- args.Player.SendMessage("Invalid syntax! Proper syntax: /give
- ", Color.Red);
- return;
- }
- if (args.Parameters[0].Length == 0)
- {
- args.Player.SendMessage("Missing item name/id", Color.Red);
- return;
- }
- if (args.Parameters[1].Length == 0)
- {
- args.Player.SendMessage("Missing player name", Color.Red);
+ args.Player.SendMessage("Invalid syntax! Proper syntax: /tp ", Color.Red);
return;
}
- int type = -1;
- if (!int.TryParse(args.Parameters[0], out type))
- type = TShock.GetItemID(args.Parameters[0]);
-
- if (type < 1 || type >= Main.maxItemTypes)
+ string plStr = String.Join(" ", args.Parameters);
+ var player = Tools.FindPlayer(plStr);
+ if (player.Count == 0)
+ args.Player.SendMessage("Invalid player!", Color.Red);
+ else if (player.Count > 1)
+ args.Player.SendMessage("More than one player matched!", Color.Red);
+ else
{
- args.Player.SendMessage("Invalid item type!", Color.Red);
+ var plr = player[0];
+ TShock.Teleport(args.Player.Index, plr.X, plr.Y);
+ args.Player.SendMessage(string.Format("Teleported to {0}", plr.Name));
+ }
+ }
+
+ private static void TPHere(CommandArgs args)
+ {
+ if (args.Parameters.Count < 1)
+ {
+ args.Player.SendMessage("Invalid syntax! Proper syntax: /tphere ", Color.Red);
return;
}
- string plStr = args.Parameters[1];
+ string plStr = String.Join(" ", args.Parameters);
var player = Tools.FindPlayer(plStr);
if (player.Count == 0)
{
@@ -746,90 +635,58 @@ namespace TShockAPI
else
{
var plr = player[0];
- bool flag = false;
- for (int i = 0; i < 40; i++)
- {
- if (!plr.TPlayer.inventory[i].active)
- {
- //Main.player[player].inventory[i].SetDefaults(type);
- //Main.player[player].inventory[i].stack = Main.player[player].inventory[i].maxStack;
- int id = Terraria.Item.NewItem(0, 0, 0, 0, type, 1, true);
- Main.item[id].position.X = plr.TPlayer.position.X;
- Main.item[id].position.Y = plr.TPlayer.position.Y;
- Main.item[id].stack = Main.item[id].maxStack;
- //TShock.SendDataAll(21, -1, "", id);
- NetMessage.SendData(21, -1, -1, "", id, 0f, 0f, 0f);
- args.Player.SendMessage(
- string.Format("Gave {0} some {1}.", plr.Name, Main.item[id].name));
- plr.SendMessage(
- string.Format("{0} gave you some {1}.", args.Player.Name,
- Main.item[id].name));
- //TShock.UpdateInventories();
- flag = true;
- break;
- }
- }
- if (!flag)
- args.Player.SendMessage("Player does not have free slots!", Color.Red);
+ TShock.Teleport(plr.Index, args.Player.X, args.Player.Y);
+ plr.SendMessage(string.Format("You were teleported to {0}.", plr.Name));
+ args.Player.SendMessage(string.Format("You brought {0} here.", plr.Name));
}
}
- public static void Heal(CommandArgs args)
+ #endregion Teleport Commands
+
+ #region Server Config Commands
+
+ private static void DebugConfiguration(CommandArgs args)
{
- if (args.Parameters.Count > 0)
- {
- string plStr = String.Join(" ", args.Parameters);
- var player = Tools.FindPlayer(plStr);
- if (player.Count == 0)
- {
- args.Player.SendMessage("Invalid player!", Color.Red);
- }
- else if (player.Count > 1)
- {
- args.Player.SendMessage("More than one player matched!", Color.Red);
- }
- else
- {
- var plr = player[0];
- DropHearts(plr.TPlayer.position.X, plr.TPlayer.position.Y, 20);
- args.Player.SendMessage(string.Format("You just healed {0}", plr.Name));
- plr.SendMessage(string.Format("{0} just healed you!", plr.Name));
- }
- }
- else
- {
- DropHearts(args.Player.X, args.Player.Y, 20);
- args.Player.SendMessage("You just got healed!");
- }
+ args.Player.SendMessage("TShock Config:");
+ string lineOne = string.Format("BanCheater : {0}, KickCheater : {1}, BanGriefer : {2}, KickGriefer : {3}",
+ ConfigurationManager.BanCheater, ConfigurationManager.KickCheater,
+ ConfigurationManager.BanGriefer, ConfigurationManager.KickGriefer);
+ args.Player.SendMessage(lineOne, Color.Yellow);
+ string lineTwo = string.Format("BanTnt : {0}, KickTnt : {1}, BanBoom : {2}, KickBoom : {3}",
+ ConfigurationManager.BanTnt, ConfigurationManager.KickTnt,
+ ConfigurationManager.BanBoom, ConfigurationManager.KickBoom);
+ args.Player.SendMessage(lineTwo, Color.Yellow);
+ string lineThree = string.Format("RangeChecks : {0}, DisableBuild : {1}, ProtectSpawn : {2}, ProtectRadius : {3}",
+ ConfigurationManager.RangeChecks, ConfigurationManager.DisableBuild,
+ ConfigurationManager.SpawnProtect, ConfigurationManager.SpawnProtectRadius);
+ args.Player.SendMessage(lineThree, Color.Yellow);
+ string lineFour = string.Format("MaxSlots : {0}, SpamChecks : {1}, InvMultiplier : {2}, DMS : {3}, SpawnRate {4}",
+ ConfigurationManager.MaxSlots, ConfigurationManager.SpamChecks,
+ ConfigurationManager.InvasionMultiplier, ConfigurationManager.DefaultMaxSpawns,
+ ConfigurationManager.DefaultSpawnRate);
+ args.Player.SendMessage(lineFour, Color.Yellow);
}
- private static void DropHearts(float x, float y, int count)
+ private static void Reload(CommandArgs args)
{
- for (int i = 0; i < count; i++)
- {
- int itemid = Terraria.Item.NewItem(1, 1, 1, 1, 58);
- Main.item[itemid].position.X = x;
- Main.item[itemid].position.Y = y;
- NetMessage.SendData(21, -1, -1, "", itemid, 0f, 0f, 0f);
- }
+ FileTools.SetupConfig();
+ args.Player.SendMessage("Configuration reload complete. Some changes may require server restart.");
}
- public static void Butcher(CommandArgs args)
+ private static void Password(CommandArgs args)
{
- int killcount = 0;
- for (int i = 0; i < Main.npc.Length; i++)
- {
- if (!Main.npc[i].townNPC && Main.npc[i].active)
- {
- Main.npc[i].StrikeNPC(99999, 90f, 1);
- NetMessage.SendData(28, -1, -1, "", i, 99999, 90f, 1);
- killcount++;
- }
- }
- Tools.Broadcast(string.Format("Killed {0} NPCs.", killcount));
+ string passwd = args.Message.Remove(0, 9).Trim();
+ Netplay.password = passwd;
+ args.Player.SendMessage(string.Format("Server password changed to: {0}", passwd));
}
- public static void MaxSpawns(CommandArgs args)
+ private static void Save(CommandArgs args)
+ {
+ WorldGen.saveWorld();
+ args.Player.SendMessage("World saved.");
+ }
+
+ private static void MaxSpawns(CommandArgs args)
{
if (args.Parameters.Count != 1)
@@ -845,7 +702,7 @@ namespace TShockAPI
Tools.Broadcast(string.Format("{0} changed the maximum spawns to: {1}", args.Player.Name, amount));
}
- public static void SpawnRate(CommandArgs args)
+ private static void SpawnRate(CommandArgs args)
{
if (args.Parameters.Count != 1)
{
@@ -860,47 +717,7 @@ namespace TShockAPI
Tools.Broadcast(string.Format("{0} changed the spawn rate to: {1}", args.Player.Name, amount));
}
- public static void Help(CommandArgs args)
- {
- args.Player.SendMessage("TShock Commands:");
- int page = 1;
- if (args.Parameters.Count > 0)
- int.TryParse(args.Parameters[0], out page);
- var cmdlist = new List();
- for (int j = 0; j < ChatCommands.Count; j++)
- {
- if (ChatCommands[j].CanRun(args.Player))
- {
- cmdlist.Add(ChatCommands[j]);
- }
- }
- var sb = new StringBuilder();
- if (cmdlist.Count > (15 * (page - 1)))
- {
- for (int j = (15 * (page - 1)); j < (15 * page); j++)
- {
- if (sb.Length != 0)
- sb.Append(", ");
- sb.Append("/").Append(cmdlist[j].Name);
- if (j == cmdlist.Count - 1)
- {
- args.Player.SendMessage(sb.ToString(), Color.Yellow);
- break;
- }
- if ((j + 1) % 5 == 0)
- {
- args.Player.SendMessage(sb.ToString(), Color.Yellow);
- sb.Clear();
- }
- }
- }
- if (cmdlist.Count > (15 * page))
- {
- args.Player.SendMessage(string.Format("Type /help {0} for more commands.", (page + 1)), Color.Yellow);
- }
- }
-
- public static void Time(CommandArgs args)
+ private static void Time(CommandArgs args)
{
if (args.Parameters.Count != 1)
{
@@ -951,10 +768,160 @@ namespace TShockAPI
}
}
- public static void Kill(CommandArgs args)
- {
- int adminplr = args.PlayerID;
+ #endregion Server Config Commands
+ #region World Protection Commands
+
+ private static void ToggleAntiBuild(CommandArgs args)
+ {
+ ConfigurationManager.DisableBuild = (ConfigurationManager.DisableBuild == false);
+ Tools.Broadcast(string.Format("Anti-build is now {0}.", (ConfigurationManager.DisableBuild ? "on" : "off")));
+ }
+
+ private static void ProtectSpawn(CommandArgs args)
+ {
+ ConfigurationManager.SpawnProtect = (ConfigurationManager.SpawnProtect == false);
+ Tools.Broadcast(string.Format("Spawn is now {0}.", (ConfigurationManager.SpawnProtect ? "protected" : "open")));
+ }
+
+ #endregion World Protection Commands
+
+ #region General Commands
+
+ private static void Help(CommandArgs args)
+ {
+ args.Player.SendMessage("TShock Commands:");
+ int page = 1;
+ if (args.Parameters.Count > 0)
+ int.TryParse(args.Parameters[0], out page);
+ var cmdlist = new List();
+ for (int j = 0; j < ChatCommands.Count; j++)
+ {
+ if (ChatCommands[j].CanRun(args.Player))
+ {
+ cmdlist.Add(ChatCommands[j]);
+ }
+ }
+ var sb = new StringBuilder();
+ if (cmdlist.Count > (15 * (page - 1)))
+ {
+ for (int j = (15 * (page - 1)); j < (15 * page); j++)
+ {
+ if (sb.Length != 0)
+ sb.Append(", ");
+ sb.Append("/").Append(cmdlist[j].Name);
+ if (j == cmdlist.Count - 1)
+ {
+ args.Player.SendMessage(sb.ToString(), Color.Yellow);
+ break;
+ }
+ if ((j + 1) % 5 == 0)
+ {
+ args.Player.SendMessage(sb.ToString(), Color.Yellow);
+ sb.Clear();
+ }
+ }
+ }
+ if (cmdlist.Count > (15 * page))
+ {
+ args.Player.SendMessage(string.Format("Type /help {0} for more commands.", (page + 1)), Color.Yellow);
+ }
+ }
+
+ private static void Playing(CommandArgs args)
+ {
+ args.Player.SendMessage(string.Format("Current players: {0}.", Tools.GetPlayers()), 255, 240, 20);
+ }
+
+ private static void AuthToken(CommandArgs args)
+ {
+ if (ConfigurationManager.AuthToken == 0)
+ {
+ return;
+ }
+ int givenCode = Convert.ToInt32(args.Parameters[0]);
+ if (givenCode == ConfigurationManager.AuthToken)
+ {
+ TextWriter tw = new StreamWriter(FileTools.UsersPath, true);
+ tw.Write("\n" + args.Player.IP + " superadmin");
+ args.Player.SendMessage("SuperAdmin authenticated. Please re-connect using the same IP.");
+ ConfigurationManager.AuthToken = 0;
+ tw.Close();
+ }
+ }
+
+ private static void ThirdPerson(CommandArgs args)
+ {
+ string msg = args.Message.Remove(0, 3);
+ Tools.Broadcast(string.Format("*{0} {1}", args.Player.Name, msg), 205, 133, 63);
+ }
+
+ private static void PartyChat(CommandArgs args)
+ {
+ int playerTeam = args.Player.Team;
+ if (playerTeam != 0)
+ {
+ string msg = string.Format("<{0}> {1}", args.Player.Name, args.Message.Remove(0, 2));
+ foreach (TSPlayer player in TShock.Players)
+ {
+ if (player != null && player.Active && player.Team == playerTeam)
+ player.SendMessage(msg, Main.teamColor[playerTeam].R, Main.teamColor[playerTeam].G, Main.teamColor[playerTeam].B);
+ }
+ }
+ else
+ {
+ args.Player.SendMessage("You are not in a party!", 255, 240, 20);
+ }
+ }
+
+ private static void Rules(CommandArgs args)
+ {
+ Tools.ShowFileToUser(args.Player, "rules.txt");
+ }
+
+ #endregion General Commands
+
+ #region Cheat Commands
+
+ private static void Slap(CommandArgs args)
+ {
+ if (args.Parameters.Count < 1 || args.Parameters.Count > 2)
+ {
+ args.Player.SendMessage("Invalid syntax! Proper syntax: /slap [dmg]", Color.Red);
+ return;
+ }
+ if (args.Parameters[0].Length == 0)
+ {
+ args.Player.SendMessage("Missing player name", Color.Red);
+ return;
+ }
+
+ string plStr = args.Parameters[0];
+ var player = Tools.FindPlayer(plStr);
+ if (player.Count == 0)
+ {
+ args.Player.SendMessage("Invalid player!", Color.Red);
+ }
+ else if (player.Count > 1)
+ {
+ args.Player.SendMessage("More than one player matched!", Color.Red);
+ }
+ else
+ {
+ var plr = player[0];
+ int damage = 5;
+ if (args.Parameters.Count == 2)
+ {
+ int.TryParse(args.Parameters[1], out damage);
+ }
+ TShock.PlayerDamage(plr, damage);
+ Tools.Broadcast(string.Format("{0} slapped {1} for {2} damage.",
+ args.Player.Name, plr.Name, damage));
+ }
+ }
+
+ private static void Kill(CommandArgs args)
+ {
if (args.Parameters.Count < 1)
{
args.Player.SendMessage("Invalid syntax! Proper syntax: /kill ", Color.Red);
@@ -976,86 +943,186 @@ namespace TShockAPI
var plr = player[0];
args.Player.SendMessage(string.Format("You just killed {0}!", plr.Name));
plr.SendMessage(string.Format("{0} just killed you!", args.Player.Name));
- TShock.PlayerDamage(plr.Index, 999999);
+ TShock.PlayerDamage(plr, 999999);
}
}
- public static void Slap(CommandArgs args)
+ private static void Butcher(CommandArgs args)
{
- if (args.Parameters.Count < 1 || args.Parameters.Count > 2)
+ int killcount = 0;
+ for (int i = 0; i < Main.npc.Length; i++)
{
- args.Player.SendMessage( "Invalid syntax! Proper syntax: /slap [dmg]", Color.Red);
+ if (!Main.npc[i].townNPC && Main.npc[i].active)
+ {
+ Main.npc[i].StrikeNPC(99999, 90f, 1);
+ NetMessage.SendData(28, -1, -1, "", i, 99999, 90f, 1);
+ killcount++;
+ }
+ }
+ Tools.Broadcast(string.Format("Killed {0} NPCs.", killcount));
+ }
+
+ private static void Item(CommandArgs args)
+ {
+ if (args.Parameters.Count < 1)
+ {
+ args.Player.SendMessage("Invalid syntax! Proper syntax: /item
- ", Color.Red);
return;
}
if (args.Parameters[0].Length == 0)
{
- args.Player.SendMessage( "Missing player name", Color.Red);
+ args.Player.SendMessage("Missing item name/id", Color.Red);
return;
}
- string plStr = args.Parameters[0];
+ int type = -1;
+ if (!int.TryParse(args.Parameters[0], out type))
+ type = TShock.GetItemID(String.Join(" ", args.Parameters));
+
+ if (type < 1 || type >= Main.maxItemTypes)
+ {
+ args.Player.SendMessage("Invalid item type!", Color.Red);
+ return;
+ }
+
+ if (!args.Player.RealPlayer)
+ {
+ args.Player.SendMessage("You cant get items!");
+ return;
+ }
+
+ bool flag = false;
+ for (int i = 0; i < 40; i++)
+ {
+ if (!args.TPlayer.inventory[i].active)
+ {
+ int id = Terraria.Item.NewItem(0, 0, 0, 0, type, 1, true);
+ Main.item[id].position.X = args.Player.X;
+ Main.item[id].position.Y = args.Player.Y;
+ Main.item[id].stack = Main.item[id].maxStack;
+ NetMessage.SendData(21, -1, -1, "", id, 0f, 0f, 0f);
+ args.Player.SendMessage(string.Format("Got some {0}.", Main.item[id].name));
+ flag = true;
+ break;
+ }
+ }
+ if (!flag)
+ args.Player.SendMessage("You don't have free slots!", Color.Red);
+ }
+
+ private static void Give(CommandArgs args)
+ {
+ if (args.Parameters.Count != 2)
+ {
+ args.Player.SendMessage("Invalid syntax! Proper syntax: /give
- ", Color.Red);
+ return;
+ }
+ if (args.Parameters[0].Length == 0)
+ {
+ args.Player.SendMessage("Missing item name/id", Color.Red);
+ return;
+ }
+ if (args.Parameters[1].Length == 0)
+ {
+ args.Player.SendMessage("Missing player name", Color.Red);
+ return;
+ }
+
+ int type = -1;
+ if (!int.TryParse(args.Parameters[0], out type))
+ type = TShock.GetItemID(args.Parameters[0]);
+
+ if (type < 1 || type >= Main.maxItemTypes)
+ {
+ args.Player.SendMessage("Invalid item type!", Color.Red);
+ return;
+ }
+
+ string plStr = args.Parameters[1];
var player = Tools.FindPlayer(plStr);
if (player.Count == 0)
{
- args.Player.SendMessage( "Invalid player!", Color.Red);
+ args.Player.SendMessage("Invalid player!", Color.Red);
}
else if (player.Count > 1)
{
- args.Player.SendMessage( "More than one player matched!", Color.Red);
+ args.Player.SendMessage("More than one player matched!", Color.Red);
}
else
{
var plr = player[0];
- int damage = 5;
- if (args.Parameters.Count == 2)
+ bool flag = false;
+ for (int i = 0; i < 40; i++)
{
- int.TryParse(args.Parameters[1], out damage);
+ if (!plr.TPlayer.inventory[i].active)
+ {
+ int id = Terraria.Item.NewItem(0, 0, 0, 0, type, 1, true);
+ Main.item[id].position.X = plr.X;
+ Main.item[id].position.Y = plr.Y;
+ Main.item[id].stack = Main.item[id].maxStack;
+ NetMessage.SendData(21, -1, -1, "", id, 0f, 0f, 0f);
+ args.Player.SendMessage(string.Format("Gave {0} some {1}.", plr.Name, Main.item[id].name));
+ plr.SendMessage(string.Format("{0} gave you some {1}.", args.Player.Name, Main.item[id].name));
+ flag = true;
+ break;
+ }
}
- TShock.PlayerDamage(plr.Index, damage);
- Tools.Broadcast(string.Format("{0} slapped {1} for {2} damage.",
- args.Player.Name, plr.Name, damage));
+ if (!flag)
+ args.Player.SendMessage("Player does not have free slots!", Color.Red);
}
}
- public static void ToggleAntiBuild(CommandArgs args)
+ private static void Heal(CommandArgs args)
{
- ConfigurationManager.DisableBuild = (ConfigurationManager.DisableBuild == false);
- Tools.Broadcast(string.Format("Anti-build is now {0}.", (ConfigurationManager.DisableBuild ? "on" : "off")));
+ if (args.Parameters.Count > 0)
+ {
+ string plStr = String.Join(" ", args.Parameters);
+ var player = Tools.FindPlayer(plStr);
+ if (player.Count == 0)
+ {
+ args.Player.SendMessage("Invalid player!", Color.Red);
+ }
+ else if (player.Count > 1)
+ {
+ args.Player.SendMessage("More than one player matched!", Color.Red);
+ }
+ else
+ {
+ var plr = player[0];
+ DropHearts(plr.X, plr.Y, 20);
+ if (plr == args.Player)
+ {
+ args.Player.SendMessage("You just got healed!");
+ }
+ else
+ {
+ args.Player.SendMessage(string.Format("You just healed {0}", plr.Name));
+ plr.SendMessage(string.Format("{0} just healed you!", args.Player.Name));
+ }
+ }
+ }
+ else if (!args.Player.RealPlayer)
+ {
+ args.Player.SendMessage("You cant heal yourself!");
+ }
+ else
+ {
+ DropHearts(args.Player.X, args.Player.Y, 20);
+ args.Player.SendMessage("You just got healed!");
+ }
}
- public static void ProtectSpawn(CommandArgs args)
+ private static void DropHearts(float x, float y, int count)
{
- ConfigurationManager.SpawnProtect = (ConfigurationManager.SpawnProtect == false);
- Tools.Broadcast(string.Format("Spawn is now {0}.", (ConfigurationManager.SpawnProtect ? "protected" : "open")));
+ for (int i = 0; i < count; i++)
+ {
+ int itemid = Terraria.Item.NewItem(1, 1, 1, 1, 58);
+ Main.item[itemid].position.X = x;
+ Main.item[itemid].position.Y = y;
+ NetMessage.SendData(21, -1, -1, "", itemid, 0f, 0f, 0f);
+ }
}
- public static void UpdateNow(CommandArgs args)
- {
- Process TServer = Process.GetCurrentProcess();
-
- StreamWriter sw = new StreamWriter("pid");
- sw.Write(TServer.Id);
- sw.Close();
-
- sw = new StreamWriter("pn");
- sw.Write(TServer.ProcessName + " " + Environment.CommandLine);
- sw.Close();
-
- WebClient client = new WebClient();
- client.Headers.Add("user-agent", "TShock");
- byte[] updatefile = client.DownloadData("http://tsupdate.shankshock.com/UpdateTShock.exe");
-
- BinaryWriter bw = new BinaryWriter(new FileStream("UpdateTShock.exe", FileMode.Create));
- bw.Write(updatefile);
- bw.Close();
-
- Process.Start(new ProcessStartInfo("UpdateTShock.exe"));
-
- Tools.ForceKickAll("Server shutting down for update!");
- WorldGen.saveWorld();
- Netplay.disconnect = true;
- }
-
- #endregion Command Methods
+ #endregion Cheat Comamnds
}
}
\ No newline at end of file
diff --git a/TShockAPI/FileTools.cs b/TShockAPI/FileTools.cs
index 773691b1..a87f94af 100644
--- a/TShockAPI/FileTools.cs
+++ b/TShockAPI/FileTools.cs
@@ -66,6 +66,8 @@ namespace TShockAPI
if (File.Exists(ConfigPath))
{
ConfigurationManager.ReadJsonConfiguration();
+ // Add all the missing config properties in the json file
+ ConfigurationManager.WriteJsonConfiguration();
}
else
{
diff --git a/TShockAPI/GetDataHandlers.cs b/TShockAPI/GetDataHandlers.cs
new file mode 100755
index 00000000..9f43c8d1
--- /dev/null
+++ b/TShockAPI/GetDataHandlers.cs
@@ -0,0 +1,426 @@
+/*
+TShock, a server mod for Terraria
+Copyright (C) 2011 The TShock Team
+
+This program is free software: you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation, either version 3 of the License, or
+(at your option) any later version.
+
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program. If not, see .
+*/
+using System;
+using System.Collections.Generic;
+using System.Diagnostics;
+using System.IO;
+using System.Text;
+using Microsoft.Xna.Framework;
+using StreamBinary;
+using Terraria;
+using TerrariaAPI;
+
+namespace TShockAPI
+{
+ public delegate bool GetDataHandlerDelegate(GetDataHandlerArgs args);
+ public class GetDataHandlerArgs : EventArgs
+ {
+ public TSPlayer Player { get; private set; }
+ public MemoryStream Data { get; private set; }
+
+ public Player TPlayer
+ {
+ get { return Player.TPlayer; }
+ }
+
+ public GetDataHandlerArgs(TSPlayer player, MemoryStream data)
+ {
+ Player = player;
+ Data = data;
+ }
+ }
+ public static class GetDataHandlers
+ {
+ private static Dictionary GetDataHandlerDelegates;
+ private static bool[] BlacklistTiles;
+
+ public static void InitGetDataHandler()
+ {
+ #region Blacklisted tiles
+
+ BlacklistTiles = new bool[Main.maxTileSets];
+ BlacklistTiles[0] = true;
+ BlacklistTiles[1] = true;
+ BlacklistTiles[2] = true;
+ BlacklistTiles[6] = true;
+ BlacklistTiles[7] = true;
+ BlacklistTiles[8] = true;
+ BlacklistTiles[9] = true;
+ BlacklistTiles[22] = true;
+ BlacklistTiles[23] = true;
+ BlacklistTiles[25] = true;
+ BlacklistTiles[30] = true;
+ BlacklistTiles[37] = true;
+ BlacklistTiles[38] = true;
+ BlacklistTiles[39] = true;
+ BlacklistTiles[40] = true;
+ BlacklistTiles[41] = true;
+ BlacklistTiles[43] = true;
+ BlacklistTiles[44] = true;
+ BlacklistTiles[45] = true;
+ BlacklistTiles[46] = true;
+ BlacklistTiles[47] = true;
+ BlacklistTiles[53] = true;
+ BlacklistTiles[54] = true;
+ BlacklistTiles[56] = true;
+ BlacklistTiles[57] = true;
+ BlacklistTiles[58] = true;
+ BlacklistTiles[59] = true;
+ BlacklistTiles[60] = true;
+ BlacklistTiles[63] = true;
+ BlacklistTiles[64] = true;
+ BlacklistTiles[65] = true;
+ BlacklistTiles[66] = true;
+ BlacklistTiles[67] = true;
+ BlacklistTiles[68] = true;
+ BlacklistTiles[70] = true;
+ BlacklistTiles[75] = true;
+ BlacklistTiles[76] = true;
+
+ #endregion Blacklisted tiles
+
+ GetDataHandlerDelegates = new Dictionary
+ {
+ {PacketTypes.PlayerInfo, HandlePlayerInfo},
+ {PacketTypes.TileSendSection, HandleSendSection},
+ {PacketTypes.PlayerUpdate, HandlePlayerUpdate},
+ {PacketTypes.Tile, HandleTile},
+ {PacketTypes.TileSendSquare, HandleSendTileSquare},
+ {PacketTypes.NPCUpdate, HandleNpcUpdate},
+ {PacketTypes.PlayerDamage, HandlePlayerDamage},
+ {PacketTypes.ProjectileNew, HandleProjectileNew},
+ {PacketTypes.TogglePVP, HandleTogglePvp},
+ {PacketTypes.TileKill, HandleTileKill},
+ {PacketTypes.PlayerKillMe, HandlePlayerKillMe},
+ {PacketTypes.LiquidSet, HandleLiquidSet},
+ };
+ }
+
+ public static bool HandlerGetData(PacketTypes type, TSPlayer player, MemoryStream data)
+ {
+ GetDataHandlerDelegate handler;
+ if (GetDataHandlerDelegates.TryGetValue(type, out handler))
+ {
+ try
+ {
+ return handler(new GetDataHandlerArgs(player, data));
+ }
+ catch (Exception ex)
+ {
+ Log.Error(ex.ToString());
+ }
+ }
+ return false;
+ }
+
+ private static bool HandlePlayerInfo(GetDataHandlerArgs args)
+ {
+ byte playerid = args.Data.ReadInt8();
+ byte hair = args.Data.ReadInt8();
+ Color hairColor = new Color(args.Data.ReadInt8(), args.Data.ReadInt8(), args.Data.ReadInt8());
+ Color skinColor = new Color(args.Data.ReadInt8(), args.Data.ReadInt8(), args.Data.ReadInt8());
+ Color eyeColor = new Color(args.Data.ReadInt8(), args.Data.ReadInt8(), args.Data.ReadInt8());
+ Color shirtColor = new Color(args.Data.ReadInt8(), args.Data.ReadInt8(), args.Data.ReadInt8());
+ Color underShirtColor = new Color(args.Data.ReadInt8(), args.Data.ReadInt8(), args.Data.ReadInt8());
+ Color pantsColor = new Color(args.Data.ReadInt8(), args.Data.ReadInt8(), args.Data.ReadInt8());
+ Color shoeColor = new Color(args.Data.ReadInt8(), args.Data.ReadInt8(), args.Data.ReadInt8());
+ string name = Encoding.ASCII.GetString(args.Data.ReadBytes((int) (args.Data.Length - args.Data.Position - 1)));
+
+ if (hair >= Main.maxHair)
+ {
+ Tools.ForceKick(args.Player, "Hair crash exploit.");
+ return true;
+ }
+
+ if (name.Length > 32)
+ {
+ Tools.ForceKick(args.Player, "Name exceeded 32 characters.");
+ return true;
+ }
+ if (name.Trim().Length == 0)
+ {
+ Tools.ForceKick(args.Player, "Empty Name.");
+ return true;
+ }
+ var ban = TShock.Bans.GetBanByName(name);
+ if (ban != null)
+ {
+ Tools.ForceKick(args.Player, string.Format("You are banned: {0}", ban.Reason));
+ return true;
+ }
+ if (args.Player.ReceivedInfo)
+ {
+ return Tools.HandleGriefer(args.Player, "Sent client info more than once");
+ }
+
+ args.Player.ReceivedInfo = true;
+ return false;
+ }
+
+ private static bool HandleSendTileSquare(GetDataHandlerArgs args)
+ {
+ short size = args.Data.ReadInt16();
+ int x = args.Data.ReadInt32();
+ int y = args.Data.ReadInt32();
+ int plyX = Math.Abs(args.Player.TileX);
+ int plyY = Math.Abs(args.Player.TileY);
+ int tileX = Math.Abs(x);
+ int tileY = Math.Abs(y);
+ if (size > 5 || (ConfigurationManager.RangeChecks && (Math.Abs(plyX - tileX) > 32 || Math.Abs(plyY - tileY) > 32)))
+ {
+ Log.Debug(string.Format("SendTileSquare(PlyXY:{0}_{1}, TileXY:{2}_{3}, Result:{4}_{5}, Size:{6})",
+ plyX, plyY, tileX, tileY, Math.Abs(plyX - tileX), Math.Abs(plyY - tileY), size));
+ return Tools.HandleGriefer(args.Player, "Send Tile Square Abuse");
+ }
+ return false;
+ }
+
+ private static bool HandleTile(GetDataHandlerArgs args)
+ {
+ byte type = args.Data.ReadInt8();
+ int x = args.Data.ReadInt32();
+ int y = args.Data.ReadInt32();
+ byte tiletype = args.Data.ReadInt8();
+ if (type == 1 || type == 3)
+ {
+ int plyX = Math.Abs(args.Player.TileX);
+ int plyY = Math.Abs(args.Player.TileY);
+ int tileX = Math.Abs(x);
+ int tileY = Math.Abs(y);
+
+ if (ConfigurationManager.RangeChecks && ((Math.Abs(plyX - tileX) > 32) || (Math.Abs(plyY - tileY) > 32)))
+ {
+ Log.Debug(string.Format("TilePlaced(PlyXY:{0}_{1}, TileXY:{2}_{3}, Result:{4}_{5}, Type:{6})",
+ plyX, plyY, tileX, tileY, Math.Abs(plyX - tileX), Math.Abs(plyY - tileY), tiletype));
+ return Tools.HandleGriefer(args.Player, "Placing impossible to place blocks.");
+ }
+ }
+ if (ConfigurationManager.DisableBuild)
+ {
+ if (!args.Player.Group.HasPermission("editspawn"))
+ {
+ args.Player.SendMessage("World protected from changes.", Color.Red);
+ TShock.SendTileSquare(args.Player, x, y);
+ return true;
+ }
+ }
+ if (ConfigurationManager.SpawnProtect)
+ {
+ if (!args.Player.Group.HasPermission("editspawn"))
+ {
+ var flag = TShock.CheckSpawn(x, y);
+ if (flag)
+ {
+ args.Player.SendMessage("Spawn protected from changes.", Color.Red);
+ TShock.SendTileSquare(args.Player, x, y);
+ return true;
+ }
+ }
+ }
+ if (type == 0 && BlacklistTiles[Main.tile[x, y].type] && args.Player.Active)
+ {
+ args.Player.TileThreshold++;
+ var coords = new Vector2(x, y);
+ if (!args.Player.TilesDestroyed.ContainsKey(coords))
+ args.Player.TilesDestroyed.Add(coords, Main.tile[x, y]);
+ }
+
+ return false;
+ }
+
+ private static bool HandleTogglePvp(GetDataHandlerArgs args)
+ {
+ int id = args.Data.ReadByte();
+ bool pvp = args.Data.ReadBoolean();
+
+ args.TPlayer.hostile = pvp;
+ if (id != args.Player.Index)
+ args.TPlayer.hostile = true;
+ if (ConfigurationManager.PermaPvp)
+ args.TPlayer.hostile = true;
+ NetMessage.SendData(30, -1, -1, "", args.Player.Index);
+ return true;
+ }
+
+ private static bool HandleSendSection(GetDataHandlerArgs args)
+ {
+ return Tools.HandleGriefer(args.Player, "SendSection abuse.");
+ }
+
+ private static bool HandleNpcUpdate(GetDataHandlerArgs args)
+ {
+ return Tools.HandleGriefer(args.Player, "Spawn NPC abuse");
+ }
+
+ private static bool HandlePlayerUpdate(GetDataHandlerArgs args)
+ {
+ byte plr = args.Data.ReadInt8();
+ byte control = args.Data.ReadInt8();
+ byte item = args.Data.ReadInt8();
+ float posx = args.Data.ReadSingle();
+ float posy = args.Data.ReadSingle();
+ float velx = args.Data.ReadSingle();
+ float vely = args.Data.ReadSingle();
+
+ if (Main.verboseNetplay)
+ Debug.WriteLine("Update: {{{0},{1}}} {{{2}, {3}}}", (int)posx, (int)posy, (int)velx, (int)vely);
+
+ if (plr != args.Player.Index)
+ {
+ return Tools.HandleGriefer(args.Player, "Update Player abuse");
+ }
+ return false;
+ }
+
+ private static bool HandleProjectileNew(GetDataHandlerArgs args)
+ {
+ short ident = args.Data.ReadInt16();
+ float posx = args.Data.ReadSingle();
+ float posy = args.Data.ReadSingle();
+ float velx = args.Data.ReadSingle();
+ float vely = args.Data.ReadSingle();
+ float knockback = args.Data.ReadSingle();
+ short dmg = args.Data.ReadInt16();
+ byte owner = args.Data.ReadInt8();
+ byte type = args.Data.ReadInt8();
+
+ if (type == 29 || type == 28 || type == 37)
+ {
+ Log.Debug(string.Format("Explosive(PlyXY:{0}_{1}, Type:{2})", args.Player.TileX, args.Player.TileY, type));
+ return Tools.HandleExplosivesUser(args.Player, "Throwing an explosive device.");
+ }
+ return false;
+ }
+
+ private static bool HandlePlayerKillMe(GetDataHandlerArgs args)
+ {
+ byte id = args.Data.ReadInt8();
+ byte hitdirection = args.Data.ReadInt8();
+ short dmg = args.Data.ReadInt16();
+ bool pvp = args.Data.ReadBoolean();
+
+ if (id != args.Player.Index)
+ {
+ return Tools.HandleGriefer(args.Player, "Trying to execute KillMe on someone else.");
+ }
+ return false;
+ }
+
+ private static bool HandlePlayerDamage(GetDataHandlerArgs args)
+ {
+ byte playerid = args.Data.ReadInt8();
+ byte direction = args.Data.ReadInt8();
+ Int16 damage = args.Data.ReadInt16();
+ byte pvp = args.Data.ReadInt8();
+
+ return !TShock.Players[playerid].TPlayer.hostile;
+ }
+
+ private static bool HandleLiquidSet(GetDataHandlerArgs args)
+ {
+ int x = args.Data.ReadInt32();
+ int y = args.Data.ReadInt32();
+ byte liquid = args.Data.ReadInt8();
+ bool lava = args.Data.ReadBoolean();
+
+ //The liquid was picked up.
+ if (liquid == 0)
+ return false;
+
+ int plyX = Math.Abs(args.Player.TileX);
+ int plyY = Math.Abs(args.Player.TileY);
+ int tileX = Math.Abs(x);
+ int tileY = Math.Abs(y);
+
+ bool bucket = false;
+ for (int i = 0; i < 44; i++)
+ {
+ if (args.TPlayer.inventory[i].type >= 205 && args.TPlayer.inventory[i].type <= 207)
+ {
+ bucket = true;
+ break;
+ }
+ }
+
+ if (lava && !args.Player.Group.HasPermission("canlava"))
+ {
+ args.Player.SendMessage("You do not have permission to use lava", Color.Red);
+ Tools.SendLogs(string.Format("{0} tried using lava", args.Player.Name), Color.Red);
+ // TODO need to revert player changes so they are insync with server
+ return true;
+ }
+ if (!lava && !args.Player.Group.HasPermission("canwater"))
+ {
+ args.Player.SendMessage("You do not have permission to use water", Color.Red);
+ Tools.SendLogs(string.Format("{0} tried using water", args.Player.Name), Color.Red);
+ // TODO need to revert player changes so they are insync with server
+ return true;
+ }
+
+ if (!bucket)
+ {
+ Log.Debug(string.Format("{0}(PlyXY:{1}_{2}, TileXY:{3}_{4}, Result:{5}_{6}, Amount:{7})",
+ lava ? "Lava" : "Water", plyX, plyY, tileX, tileY,
+ Math.Abs(plyX - tileX), Math.Abs(plyY - tileY), liquid));
+ return Tools.HandleGriefer(args.Player, "Manipulating liquid without bucket."); ;
+ }
+ if (ConfigurationManager.RangeChecks && ((Math.Abs(plyX - tileX) > 32) || (Math.Abs(plyY - tileY) > 32)))
+ {
+ Log.Debug(string.Format("Liquid(PlyXY:{0}_{1}, TileXY:{2}_{3}, Result:{4}_{5}, Amount:{6})",
+ plyX, plyY,
+ tileX, tileY,
+ Math.Abs(plyX - tileX), Math.Abs(plyY - tileY),
+ liquid
+ ));
+ return Tools.HandleGriefer(args.Player, "Placing impossible to place liquid."); ;
+ }
+
+ if (ConfigurationManager.SpawnProtect)
+ {
+ if (!args.Player.Group.HasPermission("editspawn"))
+ {
+ var flag = TShock.CheckSpawn(x, y);
+ if (flag)
+ {
+ args.Player.SendMessage("The spawn is protected!", Color.Red);
+ // TODO need to revert player changes so they are insync with server
+ return true;
+ }
+ }
+ }
+ return false;
+ }
+
+ private static bool HandleTileKill(GetDataHandlerArgs args)
+ {
+ int tilex = args.Data.ReadInt32();
+ int tiley = args.Data.ReadInt32();
+ if (tilex < 0 || tilex >= Main.maxTilesX || tiley < 0 || tiley >= Main.maxTilesY)
+ return false;
+
+ if (Main.tile[tilex, tiley].type != 0x15) //Chest
+ {
+ Log.Debug(string.Format("TileKill(TileXY:{0}_{1}, Type:{2})",
+ tilex, tiley, Main.tile[tilex, tiley].type));
+ Tools.ForceKick(args.Player, string.Format("Tile Kill abuse ({0})", Main.tile[tilex, tiley].type));
+ return true;
+ }
+ return false;
+ }
+ }
+}
diff --git a/TShockAPI/Group.cs b/TShockAPI/Group.cs
index 11cfcdf9..de53b247 100644
--- a/TShockAPI/Group.cs
+++ b/TShockAPI/Group.cs
@@ -1,19 +1,19 @@
-/*
-TShock, a server mod for Terraria
-Copyright (C) 2011 The TShock Team
-
-This program is free software: you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with this program. If not, see .
+/*
+TShock, a server mod for Terraria
+Copyright (C) 2011 The TShock Team
+
+This program is free software: you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation, either version 3 of the License, or
+(at your option) any later version.
+
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program. If not, see .
*/
using System;
using System.Collections.Generic;
diff --git a/TShockAPI/TSPlayer.cs b/TShockAPI/TSPlayer.cs
index 3bfc2066..92de581e 100644
--- a/TShockAPI/TSPlayer.cs
+++ b/TShockAPI/TSPlayer.cs
@@ -33,19 +33,28 @@ namespace TShockAPI
public Group Group { get; set; }
public bool ReceivedInfo { get; set; }
public int Index { get; protected set; }
-
+ public bool RealPlayer
+ {
+ get { return Index >= 0 && Index < Main.maxNetPlayers; }
+ }
+ public bool ConnectionAlive
+ {
+ get { return RealPlayer ? Netplay.serverSock[Index].active && !Netplay.serverSock[Index].kill : false; }
+ }
///
/// Terraria Player
///
public Player TPlayer { get; protected set; }
-
public string Name
{
get { return TPlayer.name; }
}
public string IP
{
- get { return Tools.GetRealIP(Netplay.serverSock[Index].tcpClient.Client.RemoteEndPoint.ToString()); }
+ get
+ {
+ return RealPlayer ? Tools.GetRealIP(Netplay.serverSock[Index].tcpClient.Client.RemoteEndPoint.ToString()) : "";
+ }
}
public bool Active
{
@@ -55,14 +64,20 @@ namespace TShockAPI
{
get { return TPlayer.team; }
}
-
public float X
{
- get { return TPlayer.position.X; }
+ get
+ {
+
+ return RealPlayer ? TPlayer.position.X : Main.spawnTileX * 16;
+ }
}
public float Y
{
- get { return TPlayer.position.Y; }
+ get
+ {
+ return RealPlayer ? TPlayer.position.Y : Main.spawnTileY * 16;
+ }
}
public int TileX
{
@@ -70,7 +85,7 @@ namespace TShockAPI
}
public int TileY
{
- get { return (int)(X / 16); }
+ get { return (int)(Y / 16); }
}
public TSPlayer(int index)
diff --git a/TShockAPI/TShock.cs b/TShockAPI/TShock.cs
index 078de510..fd18f449 100755
--- a/TShockAPI/TShock.cs
+++ b/TShockAPI/TShock.cs
@@ -20,10 +20,8 @@ using System.Collections.Generic;
using System.Diagnostics;
using System.IO;
using System.Net;
-using System.Text;
using Microsoft.Xna.Framework;
using Microsoft.Xna.Framework.Content;
-using StreamBinary;
using Terraria;
using TerrariaAPI;
using TerrariaAPI.Hooks;
@@ -41,13 +39,8 @@ namespace TShockAPI
public static readonly string VersionCodename = "Forgot to increase the version.";
- private static bool[] BlacklistTiles;
-
public static BanManager Bans = new BanManager(Path.Combine(SavePath, "bans.txt"));
- delegate bool HandleGetDataD(MemoryStream data, GetDataEventArgs e);
- Dictionary GetDataFuncs;
-
public override Version Version
{
get { return VersionNum; }
@@ -68,85 +61,15 @@ namespace TShockAPI
get { return "The administration modification of the future."; }
}
- static TShock()
- {
- //Tools.LoadGroups();
-
- #region Blacklisted tiles
-
- BlacklistTiles = new bool[0x80];
- BlacklistTiles[0] = true;
- BlacklistTiles[1] = true;
- BlacklistTiles[2] = true;
- BlacklistTiles[6] = true;
- BlacklistTiles[7] = true;
- BlacklistTiles[8] = true;
- BlacklistTiles[9] = true;
- BlacklistTiles[22] = true;
- BlacklistTiles[23] = true;
- BlacklistTiles[25] = true;
- BlacklistTiles[30] = true;
- BlacklistTiles[37] = true;
- BlacklistTiles[38] = true;
- BlacklistTiles[39] = true;
- BlacklistTiles[40] = true;
- BlacklistTiles[41] = true;
- BlacklistTiles[43] = true;
- BlacklistTiles[44] = true;
- BlacklistTiles[45] = true;
- BlacklistTiles[46] = true;
- BlacklistTiles[47] = true;
- BlacklistTiles[53] = true;
- BlacklistTiles[54] = true;
- BlacklistTiles[56] = true;
- BlacklistTiles[57] = true;
- BlacklistTiles[58] = true;
- BlacklistTiles[59] = true;
- BlacklistTiles[60] = true;
- BlacklistTiles[63] = true;
- BlacklistTiles[64] = true;
- BlacklistTiles[65] = true;
- BlacklistTiles[66] = true;
- BlacklistTiles[67] = true;
- BlacklistTiles[68] = true;
- BlacklistTiles[70] = true;
- BlacklistTiles[75] = true;
- BlacklistTiles[76] = true;
-
- #endregion Blacklisted tiles
- }
-
public TShock(Main game)
: base(game)
{
-
- GetDataFuncs = new Dictionary
- {
- {(byte)PacketTypes.PlayerInfo, HandlePlayerInfo},
- {(byte)PacketTypes.TileSendSection, HandleSendSection},
- {(byte)PacketTypes.PlayerUpdate, HandlePlayerUpdate},
- {(byte)PacketTypes.Tile, HandleTile},
- {(byte)PacketTypes.TileSendSquare, HandleSendTileSquare},
- {(byte)PacketTypes.NPCUpdate, HandleNpcUpdate},
- {(byte)PacketTypes.PlayerDamage, HandlePlayerDamage},
- {(byte)PacketTypes.ProjectileNew, HandleProjectileNew},
- {(byte)PacketTypes.TogglePVP, HandleTogglePvp},
- {(byte)PacketTypes.TileKill, HandleTileKill},
- {(byte)PacketTypes.PlayerKillMe, HandlePlayerKillMe},
- {(byte)PacketTypes.LiquidSet, HandleLiquidSet},
- };
}
public override void Initialize()
{
- try
- {
- FileTools.SetupConfig();
- }
- catch (Exception ex)
- {
- Console.WriteLine(ex.ToString());
- }
+ FileTools.SetupConfig();
+
string version = string.Format("TShock Version {0} ({1}) now running.", Version, VersionCodename);
Console.WriteLine(version);
@@ -156,13 +79,13 @@ namespace TShockAPI
GameHooks.PostInitialize += OnPostInit;
GameHooks.Update += OnUpdate;
- ServerHooks.Chat += OnChat;
ServerHooks.Join += OnJoin;
ServerHooks.Leave += OnLeave;
+ ServerHooks.Chat += OnChat;
+ ServerHooks.Command += ServerHooks_OnCommand;
NetHooks.GetData += GetData;
NetHooks.GreetPlayer += OnGreetPlayer;
NpcHooks.StrikeNpc += NpcHooks_OnStrikeNpc;
- ServerHooks.Command += ServerHooks_OnCommand;
AppDomain.CurrentDomain.UnhandledException += CurrentDomain_UnhandledException;
Log.Info("Hooks initialized");
@@ -170,6 +93,9 @@ namespace TShockAPI
Bans.LoadBans();
Log.Info("Bans initialized");
+ GetDataHandlers.InitGetDataHandler();
+ Log.Info("Get data handlers initialized");
+
Commands.InitCommands();
Log.Info("Commands initialized");
@@ -179,12 +105,11 @@ namespace TShockAPI
public override void DeInitialize()
{
Bans.SaveBans();
- ConfigurationManager.WriteJsonConfiguration();
GameHooks.PostInitialize -= OnPostInit;
GameHooks.Update -= OnUpdate;
- ServerHooks.Chat -= OnChat;
ServerHooks.Join -= OnJoin;
ServerHooks.Leave -= OnLeave;
+ ServerHooks.Chat -= OnChat;
ServerHooks.Command -= ServerHooks_OnCommand;
NetHooks.GetData -= GetData;
NetHooks.GreetPlayer -= OnGreetPlayer;
@@ -210,524 +135,78 @@ namespace TShockAPI
Log.Error(e.ExceptionObject.ToString());
}
+ private void HandleCommandLine(string[] parms)
+ {
+ for (int i = 0; i < parms.Length; i++)
+ {
+ if (parms[i].ToLower() == "-ip")
+ {
+ IPAddress ip;
+ if (IPAddress.TryParse(parms[++i], out ip))
+ {
+ Netplay.serverListenIP = ip;
+ Console.Write("Using IP: {0}", ip);
+ }
+ else
+ {
+ Console.WriteLine("Bad IP: {0}", parms[i]);
+ }
+ }
+ }
+ }
+
/*
* Hooks:
*
*/
- ///
- /// When a server command is run.
- ///
- ///
- ///
- private void ServerHooks_OnCommand(string text, HandledEventArgs e)
+ private void OnPostInit()
{
- if (text.StartsWith("/"))
+ if (!File.Exists(Path.Combine(SavePath, "auth.lck")))
{
- string cmdStr = text.Remove(0, 1);
- var args = Commands.ParseParameters(cmdStr);
- if (args.Count < 1)
- return;
+ var r = new Random((int)DateTime.Now.ToBinary());
+ ConfigurationManager.AuthToken = r.Next(100000, 10000000);
+ Console.WriteLine("TShock Notice: To become SuperAdmin, join the game and type /auth " +
+ ConfigurationManager.AuthToken);
+ Console.WriteLine("This token will only display ONCE. This only works ONCE. If you don't use it and the server goes down, delete auth.lck.");
+ FileTools.CreateFile(Path.Combine(SavePath, "auth.lck"));
+ }
+ }
- string scmd = args[0];
- args.RemoveAt(0);
-
- Command cmd = null;
- for (int i = 0; i < Commands.ChatCommands.Count; i++)
+ private void OnUpdate(GameTime time)
+ {
+ UpdateManager.UpdateProcedureCheck();
+ foreach (TSPlayer player in TShock.Players)
+ {
+ if (player != null && player.Active)
{
- if (Commands.ChatCommands[i].Name.Equals(scmd))
+ if (player.TileThreshold >= 20)
{
- cmd = Commands.ChatCommands[i];
+ if (Tools.HandleTntUser(player, "Kill tile abuse detected."))
+ {
+ RevertKillTile(player);
+ player.TileThreshold = 0;
+ player.TilesDestroyed.Clear();
+ }
+ else if (player.TileThreshold > 0)
+ {
+ player.TileThreshold = 0;
+ player.TilesDestroyed.Clear();
+ }
+
+ }
+ else if (player.TileThreshold > 0)
+ {
+ player.TileThreshold = 0;
}
}
-
- if (cmd == null)
- {
- TSPlayer.Server.SendMessage("That command does not exist, try /help", Color.Red);
- }
- else
- {
- Tools.SendLogs(string.Format("{0} executed: /{1}", TSPlayer.Server.Name, cmdStr), Color.Red);
- cmd.Run(cmdStr, TSPlayer.Server, args);
- }
- e.Handled = true;
- }
- else if (text.StartsWith("exit"))
- {
- Tools.ForceKickAll("Server shutting down!");
- }
- else if (text.StartsWith("playing"))
- {
- int count = 0;
- foreach (TSPlayer player in Players)
- {
- if (player != null && player.Active)
- {
- count++;
- Console.WriteLine(string.Format("{0} ({1}) [{2}]", player.Name, player.IP, player.Group.Name));
- }
- }
- Console.WriteLine(string.Format("{0} players connected.", count));
- e.Handled = true;
- }
- else if (text.StartsWith("say "))
- Log.Info(string.Format("Server said: {0}", text.Remove(0, 4)));
- }
-
- private void NpcHooks_OnStrikeNpc(NpcStrikeEventArgs e)
- {
- if (ConfigurationManager.InfiniteInvasion)
- {
- IncrementKills();
- if (Main.invasionSize < 10)
- {
- Main.invasionSize = 20000000;
- }
- }
- }
-
- private void GetData(GetDataEventArgs e)
- {
- if (!Netplay.serverSock[e.Msg.whoAmI].active || Netplay.serverSock[e.Msg.whoAmI].kill)
- return;
-
- if (Main.verboseNetplay)
- Debug.WriteLine("{0:X} ({2}): {3} ({1:XX})", e.Msg.whoAmI, e.MsgID, Main.player[e.Msg.whoAmI].dead ? "dead " : "alive", MsgNames[e.MsgID]);
-
- HandleGetDataD func;
- if (GetDataFuncs.TryGetValue(e.MsgID, out func))
- {
- using (var data = new MemoryStream(e.Msg.readBuffer, e.Index, e.Length))
- {
- try
- {
- e.Handled = func(data, e);
- }
- catch (Exception ex)
- {
- Log.Error(ex.ToString());
- }
- }
- }
- }
-
- bool HandlePlayerInfo(MemoryStream data, GetDataEventArgs e)
- {
- var player = Players[e.Msg.whoAmI];
- if (player == null)
- {
- Tools.ForceKick(new TSPlayer(e.Msg.whoAmI), "Player doesn't exist");
- return true;
- }
- var ban = Bans.GetBanByName(player.Name);
- if (ban != null)
- {
- Tools.ForceKick(player, string.Format("You are banned: {0}", ban.Reason));
- return true;
- }
- byte hair = e.Msg.readBuffer[e.Index + 1];
- if (hair > 0x10)
- {
- Tools.ForceKick(player, "Hair crash exploit.");
- return true;
- }
-
- string name = Encoding.ASCII.GetString(e.Msg.readBuffer, e.Index + 23, (e.Length - (e.Index + 23)) + e.Index - 1);
- if (name.Length > 32)
- {
- Tools.ForceKick(player, "Name exceeded 32 characters.");
- return true;
- }
- if (name.Trim().Length == 0)
- {
- Tools.ForceKick(player, "Empty Name.");
- return true;
- }
- if (player.ReceivedInfo)
- {
- return Tools.HandleGriefer(Players[e.Msg.whoAmI], "Sent client info more than once");
- }
-
- player.ReceivedInfo = true;
- return false;
- }
-
- bool HandleSendTileSquare(MemoryStream data, GetDataEventArgs e)
- {
- short size = data.ReadInt16();
- int x = data.ReadInt32();
- int y = data.ReadInt32();
- int plyX = Math.Abs((int)Main.player[e.Msg.whoAmI].position.X / 16);
- int plyY = Math.Abs((int)Main.player[e.Msg.whoAmI].position.Y / 16);
- int tileX = Math.Abs(x);
- int tileY = Math.Abs(y);
- if (size > 5 || (ConfigurationManager.RangeChecks && (Math.Abs(plyX - tileX) > 32 || Math.Abs(plyY - tileY) > 32)))
- {
- Log.Debug(string.Format("SendTileSquare(PlyXY:{0}_{1}, TileXY:{2}_{3}, Result:{4}_{5}, Size:{6})",
- plyX, plyY,
- tileX, tileY,
- Math.Abs(plyX - tileX), Math.Abs(plyY - tileY),
- size
- ));
- return Tools.HandleGriefer(Players[e.Msg.whoAmI], "Send Tile Square Abuse");
- }
- return false;
- }
-
- bool HandleTile(MemoryStream data, GetDataEventArgs e)
- {
- byte type = data.ReadInt8();
- int x = data.ReadInt32();
- int y = data.ReadInt32();
- byte tiletype = data.ReadInt8();
- if (type == 1 || type == 3)
- {
- int plyX = Math.Abs((int)Main.player[e.Msg.whoAmI].position.X / 16);
- int plyY = Math.Abs((int)Main.player[e.Msg.whoAmI].position.Y / 16);
- int tileX = Math.Abs(x);
- int tileY = Math.Abs(y);
-
- if (Players[e.Msg.whoAmI].TPlayer.selectedItem == 0x72) //Dirt Rod
- {
- return Tools.Kick(Players[e.Msg.whoAmI], "Using dirt rod");
- }
-
- if (ConfigurationManager.RangeChecks && ((Math.Abs(plyX - tileX) > 32) || (Math.Abs(plyY - tileY) > 32)))
- {
- Log.Debug(string.Format("TilePlaced(PlyXY:{0}_{1}, TileXY:{2}_{3}, Result:{4}_{5}, Type:{6})",
- plyX, plyY,
- tileX, tileY,
- Math.Abs(plyX - tileX), Math.Abs(plyY - tileY),
- tiletype
- ));
- return Tools.HandleGriefer(Players[e.Msg.whoAmI], "Placing impossible to place blocks.");
- }
- }
- if (ConfigurationManager.DisableBuild)
- {
- if (!Players[e.Msg.whoAmI].Group.HasPermission("editspawn"))
- {
- Players[e.Msg.whoAmI].SendMessage("World protected from changes.", Color.Red);
- RevertPlayerChanges(e.Msg.whoAmI, x, y);
- return true;
- }
- }
- if (ConfigurationManager.SpawnProtect)
- {
- if (!Players[e.Msg.whoAmI].Group.HasPermission("editspawn"))
- {
- var flag = CheckSpawn(x, y);
- if (flag)
- {
- Players[e.Msg.whoAmI].SendMessage("Spawn protected from changes.", Color.Red);
- RevertPlayerChanges(e.Msg.whoAmI, x, y);
- return true;
- }
- }
- }
-
- if (type == 0 && BlacklistTiles[Main.tile[x, y].type] && Main.player[e.Msg.whoAmI].active)
- {
- Players[e.Msg.whoAmI].TileThreshold++;
- var coords = new Vector2(x, y);
- if (!Players[e.Msg.whoAmI].TilesDestroyed.ContainsKey(coords))
- Players[e.Msg.whoAmI].TilesDestroyed.Add(coords, Main.tile[x, y]);
- }
-
- return false;
- }
-
- private static void RevertPlayerChanges(int player, int x, int y)
- {
- NetMessage.SendData(20, player, -1, "", 10, (float)(x - 5), (float)(y - 5), 0f);
- }
-
- bool HandleTogglePvp(MemoryStream data, GetDataEventArgs e)
- {
- int id = data.ReadByte();
- bool pvp = data.ReadBoolean();
-
- Main.player[e.Msg.whoAmI].hostile = pvp;
- if (id != e.Msg.whoAmI)
- Main.player[e.Msg.whoAmI].hostile = true;
- if (ConfigurationManager.PermaPvp)
- Main.player[e.Msg.whoAmI].hostile = true;
- NetMessage.SendData(30, -1, -1, "", e.Msg.whoAmI);
- return true;
- }
-
- bool HandleSendSection(MemoryStream data, GetDataEventArgs e)
- {
- return Tools.HandleGriefer(Players[e.Msg.whoAmI], "SendSection abuse.");
- }
-
- bool HandleNpcUpdate(MemoryStream data, GetDataEventArgs e)
- {
- return Tools.HandleGriefer(Players[e.Msg.whoAmI], "Spawn NPC abuse");
- }
-
- bool HandlePlayerUpdate(MemoryStream data, GetDataEventArgs e)
- {
- byte plr = data.ReadInt8();
- byte control = data.ReadInt8();
- byte item = data.ReadInt8();
- float posx = data.ReadSingle();
- float posy = data.ReadSingle();
- float velx = data.ReadSingle();
- float vely = data.ReadSingle();
-
- if (Main.verboseNetplay)
- Debug.WriteLine("Update: {{{0},{1}}} {{{2}, {3}}}", (int)posx, (int)posy, (int)velx, (int)vely);
-
- if (plr != e.Msg.whoAmI)
- {
- return Tools.HandleGriefer(Players[e.Msg.whoAmI], "Update Player abuse");
- }
- return false;
- }
-
- bool HandleProjectileNew(MemoryStream data, GetDataEventArgs e)
- {
- short ident = data.ReadInt16();
- float posx = data.ReadSingle();
- float posy = data.ReadSingle();
- float velx = data.ReadSingle();
- float vely = data.ReadSingle();
- float knockback = data.ReadSingle();
- short dmg = data.ReadInt16();
- byte owner = data.ReadInt8();
- byte type = data.ReadInt8();
-
- if (type == 29 || type == 28 || type == 37)
- {
- var plr = Main.player[e.Msg.whoAmI];
- Log.Debug(string.Format("Explosive(PlyXY:{0}_{1}, Type:{2})",
- (int)(plr.position.X / 16),
- (int)(plr.position.Y / 16),
- type
- ));
- return Tools.HandleExplosivesUser(Players[e.Msg.whoAmI], "Throwing an explosive device.");
- }
- return false;
- }
-
- bool HandlePlayerKillMe(MemoryStream data, GetDataEventArgs e)
- {
- byte id = data.ReadInt8();
- byte hitdirection = data.ReadInt8();
- short dmg = data.ReadInt16();
- bool pvp = data.ReadBoolean();
-
- if (id != e.Msg.whoAmI)
- {
- return Tools.HandleGriefer(Players[e.Msg.whoAmI], "Trying to execute KillMe on someone else.");
- }
- return false;
- }
-
- bool HandlePlayerDamage(MemoryStream data, GetDataEventArgs e)
- {
- byte playerid = data.ReadInt8();
- byte direction = data.ReadInt8();
- Int16 damage = data.ReadInt16();
- byte pvp = data.ReadInt8();
-
- return !Main.player[playerid].hostile;
- }
-
- bool HandleLiquidSet(MemoryStream data, GetDataEventArgs e)
- {
- int x = data.ReadInt32();
- int y = data.ReadInt32();
- byte liquid = data.ReadInt8();
- bool lava = data.ReadBoolean();
-
- //The liquid was picked up.
- if (liquid == 0)
- return false;
-
- int plyX = Math.Abs((int)Main.player[e.Msg.whoAmI].position.X / 16);
- int plyY = Math.Abs((int)Main.player[e.Msg.whoAmI].position.Y / 16);
- int tileX = Math.Abs(x);
- int tileY = Math.Abs(y);
-
- bool bucket = false;
- for (int i = 0; i < 44; i++)
- {
- if (Main.player[e.Msg.whoAmI].inventory[i].type >= 205 && Main.player[e.Msg.whoAmI].inventory[i].type <= 207)
- {
- bucket = true;
- break;
- }
- }
-
- if (lava && !Players[e.Msg.whoAmI].Group.HasPermission("canlava"))
- {
- Players[e.Msg.whoAmI].SendMessage("You do not have permission to use lava", Color.Red);
- Tools.SendLogs(string.Format("{0} tried using lava", Main.player[e.Msg.whoAmI].name), Color.Red);
-
- return true;
- }
- if (!lava && !Players[e.Msg.whoAmI].Group.HasPermission("canwater"))
- {
- Players[e.Msg.whoAmI].SendMessage("You do not have permission to use water", Color.Red);
- Tools.SendLogs(string.Format("{0} tried using water", Main.player[e.Msg.whoAmI].name), Color.Red);
- return true;
- }
-
- if (!bucket)
- {
- Log.Debug(string.Format("{0}(PlyXY:{1}_{2}, TileXY:{3}_{4}, Result:{5}_{6}, Amount:{7})",
- lava ? "Lava" : "Water",
- plyX, plyY,
- tileX, tileY,
- Math.Abs(plyX - tileX), Math.Abs(plyY - tileY),
- liquid
- ));
- return Tools.HandleGriefer(Players[e.Msg.whoAmI], "Manipulating liquid without bucket."); ;
- }
- if (ConfigurationManager.RangeChecks && ((Math.Abs(plyX - tileX) > 32) || (Math.Abs(plyY - tileY) > 32)))
- {
- Log.Debug(string.Format("Liquid(PlyXY:{0}_{1}, TileXY:{2}_{3}, Result:{4}_{5}, Amount:{6})",
- plyX, plyY,
- tileX, tileY,
- Math.Abs(plyX - tileX), Math.Abs(plyY - tileY),
- liquid
- ));
- return Tools.HandleGriefer(Players[e.Msg.whoAmI], "Placing impossible to place liquid."); ;
- }
-
- if (ConfigurationManager.SpawnProtect)
- {
- if (!Players[e.Msg.whoAmI].Group.HasPermission("editspawn"))
- {
- var flag = CheckSpawn(x, y);
- if (flag)
- {
- Players[e.Msg.whoAmI].SendMessage("The spawn is protected!", Color.Red);
- return true;
- }
- }
- }
- return false;
- }
-
- bool HandleTileKill(MemoryStream data, GetDataEventArgs e)
- {
- int tilex = data.ReadInt32();
- int tiley = data.ReadInt32();
- if (tilex < 0 || tilex >= Main.maxTilesX || tiley < 0 || tiley >= Main.maxTilesY)
- return false;
-
- if (Main.tile[tilex, tiley].type != 0x15) //Chest
- {
- Log.Debug(string.Format("TileKill(TileXY:{0}_{1}, Type:{2})",
- tilex, tiley,
- Main.tile[tilex, tiley].type
- ));
- Tools.ForceKick(Players[e.Msg.whoAmI], string.Format("Tile Kill abuse ({0})", Main.tile[tilex, tiley].type));
- return true;
- }
- return false;
- }
-
- private void OnGreetPlayer(int who, HandledEventArgs e)
- {
- if (Main.netMode != 2)
- return;
-
- TSPlayer player = Players[who];
- Log.Info(string.Format("{0} ({1}) from '{2}' group joined.", player.Name, player.IP, player.Group.Name));
-
- Tools.ShowFileToUser(player, "motd.txt");
- if (HackedHealth(who))
- {
- Tools.HandleCheater(player, "Hacked health.");
- }
- if (ConfigurationManager.PermaPvp)
- {
- Main.player[who].hostile = true;
- NetMessage.SendData(30, -1, -1, "", who);
- }
- if (Players[who].Group.HasPermission("causeevents") && ConfigurationManager.InfiniteInvasion)
- {
- StartInvasion();
- }
- e.Handled = true;
- }
-
- private void OnChat(messageBuffer msg, int ply, string text, HandledEventArgs e)
- {
- if (Main.netMode != 2)
- return;
-
- if (msg.whoAmI != ply)
- {
- e.Handled = Tools.HandleGriefer(Players[ply], "Faking Chat");
- return;
- }
-
- var tsplr = Players[msg.whoAmI];
-
- if (tsplr.Group.HasPermission("adminchat") && !text.StartsWith("/"))
- {
- Tools.Broadcast(ConfigurationManager.AdminChatPrefix + "<" + tsplr.Name + "> " + text,
- (byte)ConfigurationManager.AdminChatRGB[0], (byte)ConfigurationManager.AdminChatRGB[1], (byte)ConfigurationManager.AdminChatRGB[2]);
- e.Handled = true;
- return;
- }
-
- if (text.StartsWith("/"))
- {
- text = text.Remove(0, 1);
-
- var args = Commands.ParseParameters(text);
- if (args.Count < 1)
- return;
-
- string scmd = args[0];
- args.RemoveAt(0);
-
- Command cmd = null;
- for (int i = 0; i < Commands.ChatCommands.Count; i++)
- {
- if (Commands.ChatCommands[i].Name.Equals(scmd))
- {
- cmd = Commands.ChatCommands[i];
- }
- }
-
- if (cmd == null)
- {
- tsplr.SendMessage("That command does not exist, try /help", Color.Red);
- }
- else
- {
- if (!cmd.CanRun(tsplr))
- {
- Tools.SendLogs(string.Format("{0} tried to execute {1}", tsplr.Name, cmd.Name), Color.Red);
- tsplr.SendMessage("You do not have access to that command.", Color.Red);
- }
- else
- {
- Tools.SendLogs(string.Format("{0} executed: /{1}", tsplr.Name, text), Color.Red);
- cmd.Run(text, tsplr, args);
- }
- }
- e.Handled = true;
- }
- else
- {
- Log.Info(string.Format("{0} said: {1}", tsplr.Name, text));
}
}
private void OnJoin(int ply, HandledEventArgs handler)
{
- if (Main.netMode != 2)
- {
+ if (Main.netMode != 2 || handler.Handled)
return;
- }
var player = new TSPlayer(ply);
player.Group = Tools.GetGroupForIP(player.IP);
@@ -769,65 +248,143 @@ namespace TShockAPI
Players[ply] = null;
}
- private void OnPostInit()
+ private void OnChat(messageBuffer msg, int ply, string text, HandledEventArgs e)
{
- if (!File.Exists(Path.Combine(SavePath, "auth.lck")))
+ if (Main.netMode != 2)
+ return;
+
+ if (msg.whoAmI != ply)
{
- var r = new Random((int)DateTime.Now.ToBinary());
- ConfigurationManager.AuthToken = r.Next(100000, 10000000);
- Console.WriteLine("TShock Notice: To become SuperAdmin, join the game and type /auth " +
- ConfigurationManager.AuthToken);
- Console.WriteLine("This token will only display ONCE. This only works ONCE. If you don't use it and the server goes down, delete auth.lck.");
- FileTools.CreateFile(Path.Combine(SavePath, "auth.lck"));
+ e.Handled = Tools.HandleGriefer(Players[ply], "Faking Chat");
+ return;
+ }
+
+ var tsplr = Players[msg.whoAmI];
+
+ if (tsplr.Group.HasPermission("adminchat") && !text.StartsWith("/"))
+ {
+ Tools.Broadcast(ConfigurationManager.AdminChatPrefix + "<" + tsplr.Name + "> " + text,
+ (byte)ConfigurationManager.AdminChatRGB[0], (byte)ConfigurationManager.AdminChatRGB[1], (byte)ConfigurationManager.AdminChatRGB[2]);
+ e.Handled = true;
+ return;
+ }
+
+ if (text.StartsWith("/"))
+ {
+ if (Commands.HandleCommand(tsplr, text))
+ e.Handled = true;
+ }
+ else
+ {
+ Log.Info(string.Format("{0} said: {1}", tsplr.Name, text));
}
}
- void HandleCommandLine(string[] parms)
+ ///
+ /// When a server command is run.
+ ///
+ ///
+ ///
+ private void ServerHooks_OnCommand(string text, HandledEventArgs e)
{
- for (int i = 0; i < parms.Length; i++)
+ // Damn you ThreadStatic and Redigit
+ if (Main.rand == null)
{
- if (parms[i].ToLower() == "-ip")
+ Main.rand = new Random();
+ }
+ if (WorldGen.genRand == null)
+ {
+ WorldGen.genRand = new Random();
+ }
+
+ if (text.StartsWith("exit"))
+ {
+ Tools.ForceKickAll("Server shutting down!");
+ }
+ else if (text.StartsWith("playing") || text.StartsWith("/playing"))
+ {
+ int count = 0;
+ foreach (TSPlayer player in Players)
{
- IPAddress ip;
- if (IPAddress.TryParse(parms[++i], out ip))
+ if (player != null && player.Active)
{
- Netplay.serverListenIP = ip;
- Console.Write("Using IP: {0}", ip);
- }
- else
- {
- Console.WriteLine("Bad IP: {0}", parms[i]);
+ count++;
+ TSPlayer.Server.SendMessage(string.Format("{0} ({1}) [{2}]", player.Name, player.IP, player.Group.Name));
}
}
+ TSPlayer.Server.SendMessage(string.Format("{0} players connected.", count));
+ e.Handled = true;
+ }
+ else if (text.StartsWith("say "))
+ {
+ Log.Info(string.Format("Server said: {0}", text.Remove(0, 4)));
+ }
+ else if (text.StartsWith("/"))
+ {
+ if (Commands.HandleCommand(TSPlayer.Server, text))
+ e.Handled = true;
+ }
+
+ }
+
+ private void GetData(GetDataEventArgs e)
+ {
+ PacketTypes type = (PacketTypes) e.MsgID;
+ TSPlayer player = Players[e.Msg.whoAmI];
+
+ if (!player.ConnectionAlive)
+ return;
+
+ if (Main.verboseNetplay)
+ Debug.WriteLine("{0:X} ({2}): {3} ({1:XX})", player.Index, (byte) type, player.TPlayer.dead ? "dead " : "alive", type.ToString());
+
+ using (var data = new MemoryStream(e.Msg.readBuffer, e.Index, e.Length))
+ {
+ try
+ {
+ if (GetDataHandlers.HandlerGetData(type, player, data))
+ e.Handled = true;
+ }
+ catch (Exception ex)
+ {
+ Log.Error(ex.ToString());
+ }
}
}
- private void OnUpdate(GameTime time)
+ private void OnGreetPlayer(int who, HandledEventArgs e)
{
- UpdateManager.UpdateProcedureCheck();
- foreach (TSPlayer player in TShock.Players)
- {
- if (player != null && player.Active)
- {
- if (player.TileThreshold >= 20)
- {
- if (Tools.HandleTntUser(player, "Kill tile abuse detected."))
- {
- RevertKillTile(player);
- player.TileThreshold = 0;
- player.TilesDestroyed.Clear();
- }
- else if (player.TileThreshold > 0)
- {
- player.TileThreshold = 0;
- player.TilesDestroyed.Clear();
- }
+ if (Main.netMode != 2)
+ return;
- }
- else if (player.TileThreshold > 0)
- {
- player.TileThreshold = 0;
- }
+ TSPlayer player = Players[who];
+ Log.Info(string.Format("{0} ({1}) from '{2}' group joined.", player.Name, player.IP, player.Group.Name));
+
+ Tools.ShowFileToUser(player, "motd.txt");
+ if (HackedHealth(who))
+ {
+ Tools.HandleCheater(player, "Hacked health.");
+ }
+ if (ConfigurationManager.PermaPvp)
+ {
+ Main.player[who].hostile = true;
+ NetMessage.SendData(30, -1, -1, "", who);
+ }
+ if (Players[who].Group.HasPermission("causeevents") && ConfigurationManager.InfiniteInvasion)
+ {
+ StartInvasion();
+ }
+ e.Handled = true;
+ }
+
+ private void NpcHooks_OnStrikeNpc(NpcStrikeEventArgs e)
+ {
+ if (ConfigurationManager.InfiniteInvasion)
+ {
+ IncrementKills();
+ if (Main.invasionSize < 10)
+ {
+ Main.invasionSize = 20000000;
}
}
}
@@ -929,9 +486,14 @@ namespace TShockAPI
}
}
- public static void PlayerDamage(int plr, int damage)
+ public static void PlayerDamage(TSPlayer player, int damage)
{
- NetMessage.SendData(26, -1, -1, "", plr, ((new Random()).Next(-1, 1)), damage, (float)0);
+ NetMessage.SendData(26, -1, -1, "", player.Index, ((new Random()).Next(-1, 1)), damage, (float)0);
+ }
+
+ public static void SendTileSquare(TSPlayer player, int x, int y, int size = 10)
+ {
+ NetMessage.SendData(20, player.Index, -1, "", size, (float)(x - (size / 2)), (float)(y - (size / 2)), 0f);
}
//TODO : Notify the player if there is more than one match. (or do we want a First() kinda thing?)
diff --git a/TShockAPI/TShockAPI.csproj b/TShockAPI/TShockAPI.csproj
index 9ced447e..fcf805af 100644
--- a/TShockAPI/TShockAPI.csproj
+++ b/TShockAPI/TShockAPI.csproj
@@ -59,6 +59,7 @@
+
diff --git a/TShockAPI/Tools.cs b/TShockAPI/Tools.cs
index d6bba608..f5984c27 100755
--- a/TShockAPI/Tools.cs
+++ b/TShockAPI/Tools.cs
@@ -101,6 +101,7 @@ namespace TShockAPI
Log.Info(string.Format("Broadcast: {0}", msg));
}
+
public static void Broadcast(string msg, Color color)
{
Broadcast(msg, color.R, color.G, color.B);
@@ -117,7 +118,7 @@ namespace TShockAPI
TSPlayer.Server.SendMessage(log, color);
foreach (TSPlayer player in TShock.Players)
{
- if (player != null && player.Group.HasPermission("logs"))
+ if (player != null && player.Active && player.Group.HasPermission("logs"))
player.SendMessage(log, color);
}
}
@@ -198,7 +199,7 @@ namespace TShockAPI
{
foreach(TSPlayer player in TShock.Players)
{
- if (player != null && player.TPlayer.active)
+ if (player != null && player.Active)
{
Tools.ForceKick(player, reason);
}
@@ -212,7 +213,7 @@ namespace TShockAPI
/// string reason
public static void ForceKick(TSPlayer player, string reason)
{
- if (!Netplay.serverSock[player.Index].active || Netplay.serverSock[player.Index].kill)
+ if (!player.ConnectionAlive)
return;
NetMessage.SendData(0x2, player.Index, -1, reason, 0x0, 0f, 0f, 0f);
Log.Info(string.Format("{0} was force kicked for : {1}", player.IP, reason));
@@ -225,7 +226,7 @@ namespace TShockAPI
/// string reason
public static bool Kick(TSPlayer player, string reason, string adminUserName = "")
{
- if (!Netplay.serverSock[player.Index].active || Netplay.serverSock[player.Index].kill)
+ if (!player.ConnectionAlive)
return true;
if (!player.Group.HasPermission("immunetokick"))
{
@@ -248,7 +249,7 @@ namespace TShockAPI
/// string reason
public static bool Ban(TSPlayer player, string reason, string adminUserName = "")
{
- if (!Netplay.serverSock[player.Index].active || Netplay.serverSock[player.Index].kill)
+ if (!player.ConnectionAlive)
return true;
if (!player.Group.HasPermission("immunetoban"))
{
diff --git a/TShockAPI/UpdateManager.cs b/TShockAPI/UpdateManager.cs
index 64bc3d13..4150f6d3 100644
--- a/TShockAPI/UpdateManager.cs
+++ b/TShockAPI/UpdateManager.cs
@@ -37,11 +37,30 @@ namespace TShockAPI
/// Check once every X minutes.
///
static readonly int CheckXMinutes = 30;
+
+ public static void UpdateProcedureCheck()
+ {
+ if ((DateTime.Now - lastcheck).TotalMinutes >= CheckXMinutes)
+ {
+ ThreadPool.QueueUserWorkItem(CheckUpdate);
+ lastcheck = DateTime.Now;
+ }
+ }
+
+ public static void CheckUpdate(object o)
+ {
+ if (ServerIsOutOfDate())
+ {
+ EnableUpdateCommand();
+ NotifyAdministrators(globalChanges);
+ }
+ }
+
///
/// Checks to see if the server is out of date.
///
///
- public static bool ServerIsOutOfDate()
+ private static bool ServerIsOutOfDate()
{
WebClient client = new WebClient();
client.Headers.Add("user-agent",
@@ -65,42 +84,33 @@ namespace TShockAPI
return false;
}
- public static void EnableUpdateCommand()
+ private static void EnableUpdateCommand()
{
- Commands.ChatCommands.Add(new Command("updatenow", "maintenance", Commands.UpdateNow));
- updateCmd = true;
+ if (!updateCmd)
+ {
+ Commands.AddUpdateCommand();
+ updateCmd = true;
+ }
}
-
- public static void NotifyAdministrators(string[] changes)
+
+ private static void NotifyAdministrators(string[] changes)
{
+ NotifyAdministrator(TSPlayer.Server, changes);
foreach (TSPlayer player in TShock.Players)
{
if (player != null && player.Active && player.Group.HasPermission("maintenance"))
{
- player.SendMessage("The server is out of date. To update, type /updatenow.");
- for (int j = 4; j < changes.Length; j++)
- {
- player.SendMessage(changes[j], Color.Red);
- }
+ NotifyAdministrator(player, changes);
}
}
}
- public static void UpdateProcedureCheck()
+ private static void NotifyAdministrator(TSPlayer player, string[] changes)
{
- if ((DateTime.Now - lastcheck).TotalMinutes >= CheckXMinutes)
+ player.SendMessage("The server is out of date. To update, type /updatenow.");
+ for (int j = 4; j < changes.Length; j++)
{
- ThreadPool.QueueUserWorkItem(CheckUpdate);
- lastcheck = DateTime.Now;
- }
- }
-
- public static void CheckUpdate(object o)
- {
- if (ServerIsOutOfDate())
- {
- EnableUpdateCommand();
- NotifyAdministrators(globalChanges);
+ player.SendMessage(changes[j], Color.Red);
}
}
}