Added private/public warps. Todo before release - make warps with spaces hide. (Too tired. Cannot finish)
This commit is contained in:
parent
f95fdf5085
commit
dd33927e76
3 changed files with 81 additions and 7 deletions
|
|
@ -137,6 +137,7 @@ namespace TShockAPI
|
||||||
ChatCommands.Add(new Command("warp", UseWarp, "warp"));
|
ChatCommands.Add(new Command("warp", UseWarp, "warp"));
|
||||||
ChatCommands.Add(new Command("managewarp", SetWarp, "setwarp"));
|
ChatCommands.Add(new Command("managewarp", SetWarp, "setwarp"));
|
||||||
ChatCommands.Add(new Command("managewarp", DeleteWarp, "delwarp"));
|
ChatCommands.Add(new Command("managewarp", DeleteWarp, "delwarp"));
|
||||||
|
ChatCommands.Add(new Command("managewarp", HideWarp, "hidewarp"));
|
||||||
ChatCommands.Add(new Command("managegroup", AddGroup, "addGroup"));
|
ChatCommands.Add(new Command("managegroup", AddGroup, "addGroup"));
|
||||||
ChatCommands.Add(new Command("managegroup", DeleteGroup, "delGroup"));
|
ChatCommands.Add(new Command("managegroup", DeleteGroup, "delGroup"));
|
||||||
ChatCommands.Add(new Command("managegroup", ModifyGroup, "modGroup"));
|
ChatCommands.Add(new Command("managegroup", ModifyGroup, "modGroup"));
|
||||||
|
|
@ -1217,6 +1218,31 @@ namespace TShockAPI
|
||||||
args.Player.SendMessage("Invalid syntax! Proper syntax: /delwarp [name]", Color.Red);
|
args.Player.SendMessage("Invalid syntax! Proper syntax: /delwarp [name]", Color.Red);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void HideWarp(CommandArgs args)
|
||||||
|
{
|
||||||
|
if (args.Parameters.Count > 1)
|
||||||
|
{
|
||||||
|
string warpName = String.Join(" ", args.Parameters);
|
||||||
|
bool state = false;
|
||||||
|
if (Boolean.TryParse(args.Parameters[1], out state))
|
||||||
|
{
|
||||||
|
if (TShock.Warps.HideWarp(args.Parameters[0], state))
|
||||||
|
{
|
||||||
|
if (state)
|
||||||
|
args.Player.SendMessage("Made warp " + warpName + " private", Color.Yellow);
|
||||||
|
else
|
||||||
|
args.Player.SendMessage("Made warp " + warpName + " public", Color.Yellow);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
args.Player.SendMessage("Could not find specified warp", Color.Red);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
args.Player.SendMessage("Invalid syntax! Proper syntax: /hidewarp [name] <true/false>", Color.Red);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
args.Player.SendMessage("Invalid syntax! Proper syntax: /hidewarp [name] <true/false>", Color.Red);
|
||||||
|
}
|
||||||
|
|
||||||
private static void UseWarp(CommandArgs args)
|
private static void UseWarp(CommandArgs args)
|
||||||
{
|
{
|
||||||
if (args.Parameters.Count < 1)
|
if (args.Parameters.Count < 1)
|
||||||
|
|
@ -1245,7 +1271,7 @@ namespace TShockAPI
|
||||||
page--; //Substract 1 as pages are parsed starting at 1 and not 0
|
page--; //Substract 1 as pages are parsed starting at 1 and not 0
|
||||||
}
|
}
|
||||||
|
|
||||||
var warps = TShock.Warps.ListAllWarps(Main.worldID.ToString());
|
var warps = TShock.Warps.ListAllPublicWarps(Main.worldID.ToString());
|
||||||
|
|
||||||
//Check if they are trying to access a page that doesn't exist.
|
//Check if they are trying to access a page that doesn't exist.
|
||||||
int pagecount = warps.Count / pagelimit;
|
int pagecount = warps.Count / pagelimit;
|
||||||
|
|
|
||||||
|
|
@ -38,6 +38,11 @@ namespace TShockAPI.DB
|
||||||
"CREATE TABLE IF NOT EXISTS 'Warps' ('X' NUMERIC, 'Y' NUMERIC, 'WarpName' TEXT PRIMARY KEY, 'WorldID' TEXT);" :
|
"CREATE TABLE IF NOT EXISTS 'Warps' ('X' NUMERIC, 'Y' NUMERIC, 'WarpName' TEXT PRIMARY KEY, 'WorldID' TEXT);" :
|
||||||
"CREATE TABLE IF NOT EXISTS Warps (X INT(11), Y INT(11), WarpName VARCHAR(255) PRIMARY, WorldID VARCHAR(255));";
|
"CREATE TABLE IF NOT EXISTS Warps (X INT(11), Y INT(11), WarpName VARCHAR(255) PRIMARY, WorldID VARCHAR(255));";
|
||||||
|
|
||||||
|
if (TShock.Config.StorageType.ToLower() == "sqlite")
|
||||||
|
db.Query("ALTER TABLE 'Warps' ADD COLUMN 'Private' TEXT");
|
||||||
|
else
|
||||||
|
db.Query("ALTER TABLE Warps ADD COLUMN Private VARCHAR(255)");
|
||||||
|
|
||||||
database.Query(query);
|
database.Query(query);
|
||||||
|
|
||||||
String file = Path.Combine(TShock.SavePath, "warps.xml");
|
String file = Path.Combine(TShock.SavePath, "warps.xml");
|
||||||
|
|
@ -167,7 +172,14 @@ namespace TShockAPI.DB
|
||||||
{
|
{
|
||||||
if (reader.Read())
|
if (reader.Read())
|
||||||
{
|
{
|
||||||
return new Warp(new Vector2(reader.Get<int>("X"), reader.Get<int>("Y")), reader.Get<string>("WarpName"), reader.Get<string>("WorldID"));
|
try
|
||||||
|
{
|
||||||
|
return new Warp(new Vector2(reader.Get<int>("X"), reader.Get<int>("Y")), reader.Get<string>("WarpName"), reader.Get<string>("WorldID"), reader.Get<string>("Private"));
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
return new Warp(new Vector2(reader.Get<int>("X"), reader.Get<int>("Y")), reader.Get<string>("WarpName"), reader.Get<string>("WorldID"), "0");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -183,15 +195,25 @@ namespace TShockAPI.DB
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="worldid">World name to get warps from</param>
|
/// <param name="worldid">World name to get warps from</param>
|
||||||
/// <returns>List of warps with only their names</returns>
|
/// <returns>List of warps with only their names</returns>
|
||||||
public List<Warp> ListAllWarps(string worldid)
|
public List<Warp> ListAllPublicWarps(string worldid)
|
||||||
{
|
{
|
||||||
var warps = new List<Warp>();
|
var warps = new List<Warp>();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
using (var reader = database.QueryReader("SELECT WarpName FROM Warps WHERE WorldID=@0", worldid))
|
using (var reader = database.QueryReader("SELECT * FROM Warps WHERE WorldID=@0", worldid))
|
||||||
{
|
{
|
||||||
while (reader.Read())
|
while (reader.Read())
|
||||||
warps.Add(new Warp { WarpName = reader.Get<string>("WarpName") });
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (reader.Get<String>("Private") == "0" || reader.Get<String>("Private") == null)
|
||||||
|
warps.Add(new Warp { WarpName = reader.Get<string>("WarpName") });
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
warps.Add(new Warp { WarpName = reader.Get<string>("WarpName") });
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
|
|
@ -200,6 +222,28 @@ namespace TShockAPI.DB
|
||||||
}
|
}
|
||||||
return warps;
|
return warps;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets all the warps names from world
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="worldid">World name to get warps from</param>
|
||||||
|
/// <returns>List of warps with only their names</returns>
|
||||||
|
public bool HideWarp(string warp, bool state)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
string query = "UPDATE Warps SET Private=@0 WHERE WarpName=@1 AND WorldID=@2";
|
||||||
|
|
||||||
|
database.Query(query, state ? "1" : "0", warp, Main.worldID.ToString());
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Log.Error(ex.ToString());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public class Warp
|
public class Warp
|
||||||
|
|
@ -207,12 +251,14 @@ namespace TShockAPI.DB
|
||||||
public Vector2 WarpPos { get; set; }
|
public Vector2 WarpPos { get; set; }
|
||||||
public string WarpName { get; set; }
|
public string WarpName { get; set; }
|
||||||
public string WorldWarpID { get; set; }
|
public string WorldWarpID { get; set; }
|
||||||
|
public string Private { get; set; }
|
||||||
|
|
||||||
public Warp(Vector2 warppos, string name, string worldname)
|
public Warp(Vector2 warppos, string name, string worldid, string hidden)
|
||||||
{
|
{
|
||||||
WarpPos = warppos;
|
WarpPos = warppos;
|
||||||
WarpName = name;
|
WarpName = name;
|
||||||
WorldWarpID = worldname;
|
WorldWarpID = worldid;
|
||||||
|
Private = hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Warp()
|
public Warp()
|
||||||
|
|
@ -220,6 +266,7 @@ namespace TShockAPI.DB
|
||||||
WarpPos = Vector2.Zero;
|
WarpPos = Vector2.Zero;
|
||||||
WarpName = null;
|
WarpName = null;
|
||||||
WorldWarpID = string.Empty;
|
WorldWarpID = string.Empty;
|
||||||
|
Private = "0";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -25,6 +25,7 @@ using System.Security.Cryptography;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using Microsoft.Xna.Framework;
|
using Microsoft.Xna.Framework;
|
||||||
using Terraria;
|
using Terraria;
|
||||||
|
using TerrariaAPI;
|
||||||
|
|
||||||
namespace TShockAPI
|
namespace TShockAPI
|
||||||
{
|
{
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue