Merge branch 'general-devel' of github.com:TShock/TShock into general-devel
This commit is contained in:
commit
cf88214be4
7 changed files with 223 additions and 298 deletions
|
|
@ -26,6 +26,7 @@ using System.Text;
|
|||
using System.Threading;
|
||||
using Terraria;
|
||||
using TShockAPI.DB;
|
||||
using System.Reflection;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
|
|
@ -129,6 +130,7 @@ namespace TShockAPI
|
|||
add(Permissions.maintenance, ClearBans, "clearbans");
|
||||
add(Permissions.whitelist, Whitelist, "whitelist");
|
||||
add(Permissions.maintenance, Off, "off", "exit");
|
||||
add(Permissions.maintenance, Restart, "restart"); //Added restart command
|
||||
add(Permissions.maintenance, OffNoSave, "off-nosave", "exit-nosave");
|
||||
add(Permissions.maintenance, CheckUpdates, "checkupdates");
|
||||
add(Permissions.causeevents, DropMeteor, "dropmeteor");
|
||||
|
|
@ -213,6 +215,7 @@ namespace TShockAPI
|
|||
add(Permissions.cfg, WorldInfo, "world");
|
||||
add(Permissions.converthardmode, ConvertCorruption, "convertcorruption");
|
||||
add(Permissions.converthardmode, ConvertHallow, "converthallow");
|
||||
add(Permissions.converthardmode, RemoveSpecial, "removespecial");
|
||||
}
|
||||
|
||||
public static bool HandleCommand(TSPlayer player, string text)
|
||||
|
|
@ -986,10 +989,45 @@ namespace TShockAPI
|
|||
|
||||
private static void Off(CommandArgs args)
|
||||
{
|
||||
|
||||
if (TShock.Config.ServerSideInventory)
|
||||
{
|
||||
foreach (TSPlayer player in TShock.Players)
|
||||
{
|
||||
if (player != null && player.IsLoggedIn && !player.IgnoreActionsForClearingTrashCan)
|
||||
{
|
||||
TShock.InventoryDB.InsertPlayerData(player);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
TShock.Utils.ForceKickAll("Server shutting down!");
|
||||
WorldGen.saveWorld();
|
||||
Netplay.disconnect = true;
|
||||
}
|
||||
//Added restart command
|
||||
private static void Restart(CommandArgs args)
|
||||
{
|
||||
if (Main.runningMono){
|
||||
Log.ConsoleInfo("Sorry, this command has not yet been implemented in Mono");
|
||||
}else{
|
||||
if (TShock.Config.ServerSideInventory)
|
||||
{
|
||||
foreach (TSPlayer player in TShock.Players)
|
||||
{
|
||||
if (player != null && player.IsLoggedIn && !player.IgnoreActionsForClearingTrashCan)
|
||||
{
|
||||
TShock.InventoryDB.InsertPlayerData(player);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
TShock.Utils.ForceKickAll("Server restarting!");
|
||||
WorldGen.saveWorld();
|
||||
Netplay.disconnect = true;
|
||||
System.Diagnostics.Process.Start(System.Reflection.Assembly.GetExecutingAssembly().GetName().CodeBase);
|
||||
Environment.Exit(0);
|
||||
}}
|
||||
|
||||
private static void OffNoSave(CommandArgs args)
|
||||
{
|
||||
|
|
@ -1394,7 +1432,6 @@ namespace TShockAPI
|
|||
{
|
||||
switch (Main.tile[x, y].type)
|
||||
{
|
||||
case 22:
|
||||
case 25:
|
||||
Main.tile[x, y].type = 117;
|
||||
break;
|
||||
|
|
@ -1451,6 +1488,47 @@ namespace TShockAPI
|
|||
TShock.Utils.Broadcast("Hallow conversion done.");
|
||||
}
|
||||
|
||||
private static void RemoveSpecial(CommandArgs args)
|
||||
{
|
||||
TShock.Utils.Broadcast("Server may lag for a moment.", Color.Red);
|
||||
for (int x = 0; x < Main.maxTilesX; x++)
|
||||
{
|
||||
for (int y = 0; y < Main.maxTilesY; y++)
|
||||
{
|
||||
switch (Main.tile[x, y].type)
|
||||
{
|
||||
case 117:
|
||||
case 25:
|
||||
Main.tile[x, y].type = 1;
|
||||
break;
|
||||
case 109:
|
||||
case 23:
|
||||
Main.tile[x, y].type = 2;
|
||||
break;
|
||||
case 32:
|
||||
Main.tile[x, y].type = 0;
|
||||
Main.tile[x, y].active = false;
|
||||
break;
|
||||
case 24:
|
||||
Main.tile[x, y].type = 3;
|
||||
break;
|
||||
case 112:
|
||||
case 116:
|
||||
Main.tile[x, y].type = 169;
|
||||
break;
|
||||
case 113:
|
||||
Main.tile[x, y].type = 38;
|
||||
break;
|
||||
default:
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
WorldGen.CountTiles(0);
|
||||
TSPlayer.All.SendData(PacketTypes.UpdateGoodEvil);
|
||||
Netplay.ResetSections();
|
||||
TShock.Utils.Broadcast("Special tile conversion done.");
|
||||
}
|
||||
#endregion Cause Events and Spawn Monsters Commands
|
||||
|
||||
#region Teleport Commands
|
||||
|
|
@ -2120,9 +2198,24 @@ namespace TShockAPI
|
|||
if (args.Parameters.Count != 1)
|
||||
{
|
||||
args.Player.SendMessage("Invalid syntax! Proper syntax: /maxspawns <maxspawns>", Color.Red);
|
||||
args.Player.SendMessage("Proper syntax: /maxspawns show", Color.Red);
|
||||
args.Player.SendMessage("Proper syntax: /maxspawns default", Color.Red);
|
||||
return;
|
||||
}
|
||||
|
||||
if (args.Parameters[0] == "show")
|
||||
{
|
||||
args.Player.SendMessage("Current maximum spawns is: " + TShock.Config.DefaultMaximumSpawns);
|
||||
return;
|
||||
}
|
||||
|
||||
if(args.Parameters[0]=="default"){
|
||||
TShock.Config.DefaultMaximumSpawns = 5;
|
||||
NPC.defaultMaxSpawns = 5;
|
||||
TShock.Utils.Broadcast(string.Format("{0} changed the maximum spawns to: 5", args.Player.Name));
|
||||
return;
|
||||
}
|
||||
|
||||
int amount = Convert.ToInt32(args.Parameters[0]);
|
||||
int.TryParse(args.Parameters[0], out amount);
|
||||
NPC.defaultMaxSpawns = amount;
|
||||
|
|
@ -2135,9 +2228,25 @@ namespace TShockAPI
|
|||
if (args.Parameters.Count != 1)
|
||||
{
|
||||
args.Player.SendMessage("Invalid syntax! Proper syntax: /spawnrate <spawnrate>", Color.Red);
|
||||
args.Player.SendMessage("/spawnrate show", Color.Red);
|
||||
args.Player.SendMessage("/spawnrate default", Color.Red);
|
||||
return;
|
||||
}
|
||||
|
||||
if (args.Parameters[0] == "show")
|
||||
{
|
||||
args.Player.SendMessage("Current spawn rate is: " + TShock.Config.DefaultSpawnRate);
|
||||
return;
|
||||
}
|
||||
|
||||
if (args.Parameters[0] == "default")
|
||||
{
|
||||
TShock.Config.DefaultSpawnRate = 600;
|
||||
NPC.defaultSpawnRate = 600;
|
||||
TShock.Utils.Broadcast(string.Format("{0} changed the spawn rate to: 600", args.Player.Name));
|
||||
return;
|
||||
}
|
||||
|
||||
int amount = Convert.ToInt32(args.Parameters[0]);
|
||||
int.TryParse(args.Parameters[0], out amount);
|
||||
NPC.defaultSpawnRate = amount;
|
||||
|
|
@ -3386,4 +3495,4 @@ namespace TShockAPI
|
|||
|
||||
#endregion Cheat Comamnds
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -44,6 +44,28 @@ namespace TShockAPI.DB
|
|||
creator.EnsureExists(table);
|
||||
}
|
||||
|
||||
public Vector2 CheckLeavePos(string name)
|
||||
{
|
||||
try
|
||||
{
|
||||
using (var reader = database.QueryReader("SELECT * FROM RememberedPos WHERE Name=@0", name))
|
||||
{
|
||||
if (reader.Read())
|
||||
{
|
||||
return new Vector2(reader.Get<int>("X"), reader.Get<int>("Y"));
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Error(ex.ToString());
|
||||
}
|
||||
|
||||
return new Vector2();
|
||||
}
|
||||
|
||||
|
||||
|
||||
public Vector2 GetLeavePos(string name, string IP)
|
||||
{
|
||||
try
|
||||
|
|
@ -66,12 +88,11 @@ namespace TShockAPI.DB
|
|||
|
||||
public void InsertLeavePos(string name, string IP, int X, int Y)
|
||||
{
|
||||
if (GetLeavePos(name, IP) == Vector2.Zero)
|
||||
if (CheckLeavePos(name) == Vector2.Zero)
|
||||
{
|
||||
try
|
||||
{
|
||||
database.Query("INSERT INTO RememberedPos (Name, IP, X, Y, WorldID) VALUES (@0, @1, @2, @3, @4);", name, IP, X,
|
||||
Y + 3, Main.worldID.ToString());
|
||||
database.Query("INSERT INTO RememberedPos (Name, IP, X, Y, WorldID) VALUES (@0, @1, @2, @3, @4);", name, IP, X, Y , Main.worldID.ToString());
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
|
|
@ -82,8 +103,7 @@ namespace TShockAPI.DB
|
|||
{
|
||||
try
|
||||
{
|
||||
database.Query("UPDATE RememberedPos SET X = @0, Y = @1 WHERE Name = @2 AND IP = @3 AND WorldID = @4;", X, Y + 3,
|
||||
name, IP, Main.worldID.ToString());
|
||||
database.Query("UPDATE RememberedPos SET X = @0, Y = @1, IP = @2 WHERE Name = @3 AND WorldID = @4;", X, Y, IP, name, Main.worldID.ToString());
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
|
|
@ -92,4 +112,4 @@ namespace TShockAPI.DB
|
|||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -412,7 +412,47 @@ namespace TShockAPI
|
|||
PlayerUpdate.Invoke(null, args);
|
||||
return args.Handled;
|
||||
}
|
||||
|
||||
public static bool TSCheckNoclip(Vector2 Position, int Width, int Height)
|
||||
{
|
||||
int num = (int)(Position.X / 16f) - 1;
|
||||
int num2 = (int)((Position.X + (float)Width) / 16f) + 2;
|
||||
int num3 = (int)(Position.Y / 16f) - 1;
|
||||
int num4 = (int)((Position.Y + (float)Height) / 16f) + 2;
|
||||
if (num < 0)
|
||||
{
|
||||
num = 0;
|
||||
}
|
||||
if (num2 > Main.maxTilesX)
|
||||
{
|
||||
num2 = Main.maxTilesX;
|
||||
}
|
||||
if (num3 < 0)
|
||||
{
|
||||
num3 = 0;
|
||||
}
|
||||
if (num4 > Main.maxTilesY)
|
||||
{
|
||||
num4 = Main.maxTilesY;
|
||||
}
|
||||
for (int i = num; i < num2; i++)
|
||||
{
|
||||
for (int j = num3; j < num4; j++)
|
||||
{
|
||||
if (Main.tile[i, j] != null && Main.tile[i, j].active && Main.tileSolid[(int)Main.tile[i, j].type] && !Main.tileSolidTop[(int)Main.tile[i, j].type] &&(((int)Main.tile[i,j].type !=53) && ((int)Main.tile[i,j].type !=112) && ((int)Main.tile[i,j].type !=116) && ((int)Main.tile[i,j].type !=123)))
|
||||
{
|
||||
Vector2 vector;
|
||||
vector.X = (float)(i * 16);
|
||||
vector.Y = (float)(j * 16);
|
||||
if (Position.X + (float)Width > vector.X && Position.X < vector.X + 16f && Position.Y + (float)Height > vector.Y && Position.Y < vector.Y + 16f)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// For use in a SendTileSquare event
|
||||
/// </summary>
|
||||
|
|
@ -1801,7 +1841,7 @@ namespace TShockAPI
|
|||
}
|
||||
|
||||
if (!args.Player.Group.HasPermission(Permissions.ignorenoclipdetection) &&
|
||||
Collision.SolidCollision(pos, args.TPlayer.width, args.TPlayer.height) && !TShock.Config.IgnoreNoClip)
|
||||
TSCheckNoclip(pos, args.TPlayer.width, args.TPlayer.height) && !TShock.Config.IgnoreNoClip)
|
||||
{
|
||||
int lastTileX = (int) (args.Player.LastNetPosition.X/16f);
|
||||
int lastTileY = (int) (args.Player.LastNetPosition.Y/16f);
|
||||
|
|
|
|||
|
|
@ -48,5 +48,5 @@ using System.Runtime.InteropServices;
|
|||
// Build Number
|
||||
// MMdd of the build
|
||||
|
||||
[assembly: AssemblyVersion("3.5.2.0127")]
|
||||
[assembly: AssemblyFileVersion("3.5.2.0127")]
|
||||
[assembly: AssemblyVersion("3.6.0.0126")]
|
||||
[assembly: AssemblyFileVersion("3.6.0.0126")]
|
||||
|
|
|
|||
|
|
@ -39,7 +39,6 @@ namespace TShockAPI
|
|||
Rest.Register(new RestCommand("/status", Status) {RequiresToken = false});
|
||||
Rest.Register(new RestCommand("/tokentest", TokenTest) {RequiresToken = true});
|
||||
|
||||
Rest.Register(new RestCommand("/users/activelist", UserList) {RequiresToken = true});
|
||||
Rest.Register(new RestCommand("/v2/users/activelist", UserListV2) { RequiresToken = true });
|
||||
Rest.Register(new RestCommand("/v2/users/read", UserInfoV2) { RequiresToken = true });
|
||||
Rest.Register(new RestCommand("/v2/users/destroy", UserDestroyV2) { RequiresToken = true });
|
||||
|
|
@ -68,20 +67,6 @@ namespace TShockAPI
|
|||
Rest.Register(new RestCommand("/v2/server/broadcast", Broadcast) { RequiresToken = true});
|
||||
Rest.Register(new RestCommand("/v2/server/off", Off) {RequiresToken = true});
|
||||
Rest.Register(new RestCommand("/v2/server/rawcmd", ServerCommand) {RequiresToken = true});
|
||||
|
||||
#region Deprecated Endpoints
|
||||
Rest.Register(new RestCommand("/bans/read/{user}/info", BanInfo) { RequiresToken = true });
|
||||
Rest.Register(new RestCommand("/bans/destroy/{user}", BanDestroy) { RequiresToken = true });
|
||||
|
||||
Rest.Register(new RestCommand("/users/read/{user}/info", UserInfo) { RequiresToken = true });
|
||||
Rest.Register(new RestCommand("/users/destroy/{user}", UserDestroy) { RequiresToken = true });
|
||||
Rest.Register(new RestCommand("/users/update/{user}", UserUpdate) { RequiresToken = true });
|
||||
|
||||
Rest.Register(new RestCommand("/players/read/{player}", PlayerRead) { RequiresToken = true });
|
||||
Rest.Register(new RestCommand("/players/{player}/kick", PlayerKick) { RequiresToken = true });
|
||||
Rest.Register(new RestCommand("/players/{player}/ban", PlayerBan) { RequiresToken = true });
|
||||
#endregion
|
||||
|
||||
}
|
||||
|
||||
#region RestServerMethods
|
||||
|
|
@ -172,14 +157,15 @@ namespace TShockAPI
|
|||
|
||||
private object UserListV2(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var ret = new RestObject("200");
|
||||
string playerlist = "";
|
||||
foreach (var TSPlayer in TShock.Players)
|
||||
{
|
||||
playerlist += playerlist == "" ? TSPlayer.UserAccountName : "\t" + TSPlayer.UserAccountName;
|
||||
}
|
||||
ret["activeusers"] = playerlist;
|
||||
return ret;
|
||||
var returnBlock = new Dictionary<string, string>();
|
||||
returnBlock.Add("status", "200");
|
||||
returnBlock.Add("activeusers", playerlist);
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
private object UserUpdateV2(RestVerbs verbs, IParameterCollection parameters)
|
||||
|
|
@ -664,266 +650,5 @@ namespace TShockAPI
|
|||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Deperecated endpoints
|
||||
|
||||
private object UserUpdate(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var returnBlock = new Dictionary<string, string>();
|
||||
var password = parameters["password"];
|
||||
var group = parameters["group"];
|
||||
|
||||
if (group == null && password == null)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "No parameters were passed.");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
var user = TShock.Users.GetUserByName(verbs["user"]);
|
||||
if (user == null)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "The specefied user doesn't exist.");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
if (password != null)
|
||||
{
|
||||
TShock.Users.SetUserPassword(user, password);
|
||||
returnBlock.Add("password-response", "Password updated successfully.");
|
||||
}
|
||||
|
||||
if (group != null)
|
||||
{
|
||||
TShock.Users.SetUserGroup(user, group);
|
||||
returnBlock.Add("group-response", "Group updated successfully.");
|
||||
}
|
||||
|
||||
returnBlock.Add("status", "200");
|
||||
returnBlock.Add("deprecated", "This endpoint is deprecated. It will be fully removed from code in TShock 3.6.");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
private object UserDestroy(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var user = TShock.Users.GetUserByName(verbs["user"]);
|
||||
if (user == null)
|
||||
{
|
||||
return new Dictionary<string, string> { { "status", "400" }, { "error", "The specified user account does not exist." } };
|
||||
}
|
||||
var returnBlock = new Dictionary<string, string>();
|
||||
try
|
||||
{
|
||||
TShock.Users.RemoveUser(user);
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "The specified user was unable to be removed.");
|
||||
return returnBlock;
|
||||
}
|
||||
returnBlock.Add("status", "200");
|
||||
returnBlock.Add("response", "User deleted successfully.");
|
||||
returnBlock.Add("deprecated", "This endpoint is deprecated. It will be fully removed from code in TShock 3.6.");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
private object UserInfo(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var user = TShock.Users.GetUserByName(verbs["user"]);
|
||||
if (user == null)
|
||||
{
|
||||
return new Dictionary<string, string> { { "status", "400" }, { "error", "The specified user account does not exist." } };
|
||||
}
|
||||
|
||||
var returnBlock = new Dictionary<string, string>();
|
||||
returnBlock.Add("status", "200");
|
||||
returnBlock.Add("group", user.Group);
|
||||
returnBlock.Add("id", user.ID.ToString());
|
||||
returnBlock.Add("deprecated", "This endpoint is deprecated. It will be fully removed from code in TShock 3.6.");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
private object UserList(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var ret = new RestObject("200");
|
||||
string playerlist = "";
|
||||
foreach (var TSPlayer in TShock.Players)
|
||||
{
|
||||
if (playerlist == "")
|
||||
{
|
||||
playerlist += TSPlayer.UserAccountName;
|
||||
}
|
||||
else
|
||||
{
|
||||
playerlist += ", " + TSPlayer.UserAccountName;
|
||||
}
|
||||
}
|
||||
ret["activeuesrs"] = playerlist;
|
||||
return ret;
|
||||
}
|
||||
|
||||
private object BanDestroy(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var returnBlock = new Dictionary<string, string>();
|
||||
|
||||
var type = parameters["type"];
|
||||
if (type == null)
|
||||
{
|
||||
returnBlock.Add("Error", "Invalid Type");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
var ban = new Ban();
|
||||
if (type == "ip") ban = TShock.Bans.GetBanByIp(verbs["user"]);
|
||||
else if (type == "name") ban = TShock.Bans.GetBanByName(verbs["user"]);
|
||||
else
|
||||
{
|
||||
returnBlock.Add("Error", "Invalid Type");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
if (ban == null)
|
||||
{
|
||||
return new Dictionary<string, string> { { "status", "400" }, { "error", "The specified ban does not exist." } };
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
TShock.Bans.RemoveBan(ban.IP);
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "The specified ban was unable to be removed.");
|
||||
return returnBlock;
|
||||
}
|
||||
returnBlock.Add("status", "200");
|
||||
returnBlock.Add("response", "Ban deleted successfully.");
|
||||
returnBlock.Add("deprecated", "This endpoint is deprecated. It will be fully removed from code in TShock 3.6.");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
private object PlayerRead(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var returnBlock = new Dictionary<string, object>();
|
||||
var playerParam = verbs["player"];
|
||||
var found = TShock.Utils.FindPlayer(playerParam);
|
||||
if (found.Count == 0)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "Name " + playerParam + " was not found");
|
||||
}
|
||||
else if (found.Count > 1)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "Name " + playerParam + " matches " + playerParam.Count() + " players");
|
||||
}
|
||||
else if (found.Count == 1)
|
||||
{
|
||||
var player = found[0];
|
||||
returnBlock.Add("status", "200");
|
||||
returnBlock.Add("nickname", player.Name);
|
||||
returnBlock.Add("username", player.UserAccountName == null ? "" : player.UserAccountName);
|
||||
returnBlock.Add("ip", player.IP);
|
||||
returnBlock.Add("group", player.Group.Name);
|
||||
returnBlock.Add("position", player.TileX + "," + player.TileY);
|
||||
var activeItems = player.TPlayer.inventory.Where(p => p.active).ToList();
|
||||
returnBlock.Add("inventory", string.Join(", ", activeItems.Select(p => p.name)));
|
||||
returnBlock.Add("buffs", string.Join(", ", player.TPlayer.buffType));
|
||||
}
|
||||
returnBlock.Add("deprecated", "This endpoint is deprecated. It will be fully removed from code in TShock 3.6.");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
private object PlayerKick(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var returnBlock = new Dictionary<string, object>();
|
||||
var playerParam = verbs["player"];
|
||||
var found = TShock.Utils.FindPlayer(playerParam);
|
||||
var reason = verbs["reason"];
|
||||
if (found.Count == 0)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "Name " + playerParam + " was not found");
|
||||
}
|
||||
else if (found.Count > 1)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "Name " + playerParam + " matches " + playerParam.Count() + " players");
|
||||
}
|
||||
else if (found.Count == 1)
|
||||
{
|
||||
var player = found[0];
|
||||
TShock.Utils.ForceKick(player, reason == null ? "Kicked via web" : reason);
|
||||
returnBlock.Add("status", "200");
|
||||
returnBlock.Add("response", "Player " + player.Name + " was kicked");
|
||||
}
|
||||
returnBlock.Add("deprecated", "This endpoint is deprecated. It will be fully removed from code in TShock 3.6.");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
private object PlayerBan(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var returnBlock = new Dictionary<string, object>();
|
||||
var playerParam = verbs["player"];
|
||||
var found = TShock.Utils.FindPlayer(playerParam);
|
||||
var reason = verbs["reason"];
|
||||
if (found.Count == 0)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "Name " + playerParam + " was not found");
|
||||
}
|
||||
else if (found.Count > 1)
|
||||
{
|
||||
returnBlock.Add("status", "400");
|
||||
returnBlock.Add("error", "Name " + playerParam + " matches " + playerParam.Count() + " players");
|
||||
}
|
||||
else if (found.Count == 1)
|
||||
{
|
||||
var player = found[0];
|
||||
TShock.Bans.AddBan(player.IP, player.Name, reason == null ? "Banned via web" : reason);
|
||||
TShock.Utils.ForceKick(player, reason == null ? "Banned via web" : reason);
|
||||
returnBlock.Add("status", "200");
|
||||
returnBlock.Add("response", "Player " + player.Name + " was banned");
|
||||
}
|
||||
returnBlock.Add("deprecated", "This endpoint is deprecated. It will be fully removed from code in TShock 3.6.");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
private object BanInfo(RestVerbs verbs, IParameterCollection parameters)
|
||||
{
|
||||
var returnBlock = new Dictionary<string, string>();
|
||||
|
||||
var type = parameters["type"];
|
||||
if (type == null)
|
||||
{
|
||||
returnBlock.Add("Error", "Invalid Type");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
var ban = new Ban();
|
||||
if (type == "ip") ban = TShock.Bans.GetBanByIp(verbs["user"]);
|
||||
else if (type == "name") ban = TShock.Bans.GetBanByName(verbs["user"]);
|
||||
else
|
||||
{
|
||||
returnBlock.Add("Error", "Invalid Type");
|
||||
return returnBlock;
|
||||
}
|
||||
|
||||
if (ban == null)
|
||||
{
|
||||
return new Dictionary<string, string> { { "status", "400" }, { "error", "The specified ban does not exist." } };
|
||||
}
|
||||
|
||||
returnBlock.Add("status", "200");
|
||||
returnBlock.Add("name", ban.Name);
|
||||
returnBlock.Add("ip", ban.IP);
|
||||
returnBlock.Add("reason", ban.Reason);
|
||||
returnBlock.Add("deprecated", "This endpoint is deprecated. It will be fully removed from code in TShock 3.6.");
|
||||
return returnBlock;
|
||||
}
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
|
|
@ -270,6 +270,9 @@ namespace TShockAPI
|
|||
|
||||
TPlayer.position.X = (float)(tilex * 16 + 8 - TPlayer.width /2);
|
||||
TPlayer.position.Y = (float)(tiley * 16 - TPlayer.height);
|
||||
//We need to send the tile data again to prevent clients from thinking they *really* destroyed blocks just now.
|
||||
|
||||
SendTileSquare(tilex, tiley, 150);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
|
@ -313,11 +316,35 @@ namespace TShockAPI
|
|||
try
|
||||
{
|
||||
int num = (size - 1)/2;
|
||||
SendData(PacketTypes.TileSendSquare, "", size, (x - num), (y - num));
|
||||
int m_x=0;
|
||||
int m_y=0;
|
||||
|
||||
if (x - num <0){
|
||||
m_x=0;
|
||||
}else{
|
||||
m_x = x - num;
|
||||
}
|
||||
|
||||
if (y - num <0){
|
||||
m_y=0;
|
||||
}else{
|
||||
m_y = y - num;
|
||||
}
|
||||
|
||||
if (m_x + size > Main.maxTilesX){
|
||||
m_x=Main.maxTilesX - size;
|
||||
}
|
||||
|
||||
if (m_y + size > Main.maxTilesY){
|
||||
m_y=Main.maxTilesY - size;
|
||||
}
|
||||
|
||||
SendData(PacketTypes.TileSendSquare, "", size, m_x, m_y);
|
||||
return true;
|
||||
}
|
||||
catch (IndexOutOfRangeException)
|
||||
{
|
||||
|
||||
// This is expected if square exceeds array.
|
||||
}
|
||||
catch (Exception ex)
|
||||
|
|
|
|||
|
|
@ -41,7 +41,7 @@ namespace TShockAPI
|
|||
public class TShock : TerrariaPlugin
|
||||
{
|
||||
public static readonly Version VersionNum = Assembly.GetExecutingAssembly().GetName().Version;
|
||||
public static readonly string VersionCodename = "1.1.2 was sudden";
|
||||
public static readonly string VersionCodename = "Squashing bugs, and adding suggestions";
|
||||
|
||||
public static string SavePath = "tshock";
|
||||
|
||||
|
|
@ -107,12 +107,13 @@ namespace TShockAPI
|
|||
if (!Directory.Exists(SavePath))
|
||||
Directory.CreateDirectory(SavePath);
|
||||
|
||||
DateTime now = DateTime.Now;
|
||||
#if DEBUG
|
||||
Log.Initialize(Path.Combine(SavePath, "log.txt"), LogLevel.All, false);
|
||||
Log.Initialize(Path.Combine(SavePath, now.ToString("yyyyMMddHHmmss")+".log"), LogLevel.All, false);
|
||||
#else
|
||||
Log.Initialize(Path.Combine(SavePath, "log.txt"), LogLevel.All & ~LogLevel.Debug, false);
|
||||
Log.Initialize(Path.Combine(SavePath, now.ToString("yyyyMMddHHmmss")+".log"), LogLevel.All & ~LogLevel.Debug, false);
|
||||
#endif
|
||||
AppDomain.CurrentDomain.UnhandledException += CurrentDomain_UnhandledException;
|
||||
AppDomain.CurrentDomain.UnhandledException += CurrentDomain_UnhandledException;
|
||||
|
||||
try
|
||||
{
|
||||
|
|
@ -492,6 +493,8 @@ namespace TShockAPI
|
|||
if (player.TileKillThreshold > 0)
|
||||
{
|
||||
player.TileKillThreshold = 0;
|
||||
//We don't want to revert the entire map in case of a disable.
|
||||
player.TilesDestroyed.Clear();
|
||||
}
|
||||
if (player.TilesCreated != null)
|
||||
{
|
||||
|
|
@ -851,10 +854,11 @@ namespace TShockAPI
|
|||
|
||||
if (Config.RememberLeavePos)
|
||||
{
|
||||
if (RememberedPos.GetLeavePos(player.Name, player.IP) != Vector2.Zero){
|
||||
var pos = RememberedPos.GetLeavePos(player.Name, player.IP);
|
||||
player.LastNetPosition = pos;
|
||||
player.Teleport((int) pos.X, (int) pos.Y + 3);
|
||||
}
|
||||
}}
|
||||
|
||||
e.Handled = true;
|
||||
}
|
||||
|
|
@ -1429,4 +1433,4 @@ namespace TShockAPI
|
|||
Utils.HashAlgo = file.HashAlgorithm;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue