Converted all files to LF line endings
This commit is contained in:
parent
3890a82b0e
commit
41dbd31aac
21 changed files with 14591 additions and 14591 deletions
|
|
@ -1,96 +1,96 @@
|
|||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Threading;
|
||||
using Terraria;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
public class BackupManager
|
||||
{
|
||||
public string BackupPath { get; set; }
|
||||
public int Interval { get; set; }
|
||||
public int KeepFor { get; set; }
|
||||
|
||||
private DateTime lastbackup = DateTime.UtcNow;
|
||||
|
||||
public BackupManager(string path)
|
||||
{
|
||||
BackupPath = path;
|
||||
}
|
||||
|
||||
public bool IsBackupTime
|
||||
{
|
||||
get { return (Interval > 0) && ((DateTime.UtcNow - lastbackup).TotalMinutes >= Interval); }
|
||||
}
|
||||
|
||||
public void Backup()
|
||||
{
|
||||
lastbackup = DateTime.UtcNow;
|
||||
ThreadPool.QueueUserWorkItem(DoBackup);
|
||||
ThreadPool.QueueUserWorkItem(DeleteOld);
|
||||
}
|
||||
|
||||
private void DoBackup(object o)
|
||||
{
|
||||
try
|
||||
{
|
||||
string worldname = Main.worldPathName;
|
||||
string name = Path.GetFileName(worldname);
|
||||
|
||||
Main.worldPathName = Path.Combine(BackupPath, string.Format("{0}.{1:dd.MM.yy-HH.mm.ss}.bak", name, DateTime.UtcNow));
|
||||
|
||||
string worldpath = Path.GetDirectoryName(Main.worldPathName);
|
||||
if (worldpath != null && !Directory.Exists(worldpath))
|
||||
Directory.CreateDirectory(worldpath);
|
||||
|
||||
TShock.Utils.Broadcast("Server map saving, potential lag spike");
|
||||
Console.WriteLine("Backing up world...");
|
||||
|
||||
SaveManager.Instance.SaveWorld();
|
||||
Console.WriteLine("World backed up");
|
||||
Console.ForegroundColor = ConsoleColor.Gray;
|
||||
Log.Info(string.Format("World backed up ({0})", Main.worldPathName));
|
||||
|
||||
Main.worldPathName = worldname;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Console.ForegroundColor = ConsoleColor.Red;
|
||||
Console.WriteLine("Backup failed");
|
||||
Console.ForegroundColor = ConsoleColor.Gray;
|
||||
Log.Error("Backup failed");
|
||||
Log.Error(ex.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
private void DeleteOld(object o)
|
||||
{
|
||||
if (KeepFor <= 0)
|
||||
return;
|
||||
foreach (var fi in new DirectoryInfo(BackupPath).GetFiles("*.bak"))
|
||||
{
|
||||
if ((DateTime.UtcNow - fi.LastWriteTimeUtc).TotalMinutes > KeepFor)
|
||||
{
|
||||
fi.Delete();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Threading;
|
||||
using Terraria;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
public class BackupManager
|
||||
{
|
||||
public string BackupPath { get; set; }
|
||||
public int Interval { get; set; }
|
||||
public int KeepFor { get; set; }
|
||||
|
||||
private DateTime lastbackup = DateTime.UtcNow;
|
||||
|
||||
public BackupManager(string path)
|
||||
{
|
||||
BackupPath = path;
|
||||
}
|
||||
|
||||
public bool IsBackupTime
|
||||
{
|
||||
get { return (Interval > 0) && ((DateTime.UtcNow - lastbackup).TotalMinutes >= Interval); }
|
||||
}
|
||||
|
||||
public void Backup()
|
||||
{
|
||||
lastbackup = DateTime.UtcNow;
|
||||
ThreadPool.QueueUserWorkItem(DoBackup);
|
||||
ThreadPool.QueueUserWorkItem(DeleteOld);
|
||||
}
|
||||
|
||||
private void DoBackup(object o)
|
||||
{
|
||||
try
|
||||
{
|
||||
string worldname = Main.worldPathName;
|
||||
string name = Path.GetFileName(worldname);
|
||||
|
||||
Main.worldPathName = Path.Combine(BackupPath, string.Format("{0}.{1:dd.MM.yy-HH.mm.ss}.bak", name, DateTime.UtcNow));
|
||||
|
||||
string worldpath = Path.GetDirectoryName(Main.worldPathName);
|
||||
if (worldpath != null && !Directory.Exists(worldpath))
|
||||
Directory.CreateDirectory(worldpath);
|
||||
|
||||
TShock.Utils.Broadcast("Server map saving, potential lag spike");
|
||||
Console.WriteLine("Backing up world...");
|
||||
|
||||
SaveManager.Instance.SaveWorld();
|
||||
Console.WriteLine("World backed up");
|
||||
Console.ForegroundColor = ConsoleColor.Gray;
|
||||
Log.Info(string.Format("World backed up ({0})", Main.worldPathName));
|
||||
|
||||
Main.worldPathName = worldname;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Console.ForegroundColor = ConsoleColor.Red;
|
||||
Console.WriteLine("Backup failed");
|
||||
Console.ForegroundColor = ConsoleColor.Gray;
|
||||
Log.Error("Backup failed");
|
||||
Log.Error(ex.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
private void DeleteOld(object o)
|
||||
{
|
||||
if (KeepFor <= 0)
|
||||
return;
|
||||
foreach (var fi in new DirectoryInfo(BackupPath).GetFiles("*.bak"))
|
||||
{
|
||||
if ((DateTime.UtcNow - fi.LastWriteTimeUtc).TotalMinutes > KeepFor)
|
||||
{
|
||||
fi.Delete();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
/*
|
||||
/*
|
||||
TShock, a server mod for Terraria
|
||||
Copyright (C) 2011 The TShock Team
|
||||
|
||||
|
|
@ -583,10 +583,10 @@ namespace TShockAPI
|
|||
// User deletion requires a username
|
||||
else if (subcmd == "del" && args.Parameters.Count == 2)
|
||||
{
|
||||
var user = new User();
|
||||
if (args.Parameters[1].Split('.').Count() ==4)
|
||||
|
||||
// changed to support dot character in usernames
|
||||
var user = new User();
|
||||
if (args.Parameters[1].Split('.').Count() ==4)
|
||||
|
||||
// changed to support dot character in usernames
|
||||
// if (args.Parameters[1].Contains("."))
|
||||
user.Address = args.Parameters[1];
|
||||
else
|
||||
|
|
@ -632,7 +632,7 @@ namespace TShockAPI
|
|||
// Group changing requires a username or IP address, and a new group to set
|
||||
else if (subcmd == "group")
|
||||
{
|
||||
var user = new User();
|
||||
var user = new User();
|
||||
if (args.Parameters[1].Split('.').Count()==4)
|
||||
|
||||
//changed to support dot character in usernames
|
||||
|
|
@ -1116,34 +1116,34 @@ namespace TShockAPI
|
|||
else if (args.Parameters[0] == "gold")
|
||||
{
|
||||
num = 5;
|
||||
}
|
||||
else if (args.Parameters[0] == "demonite")
|
||||
{
|
||||
num = 7;
|
||||
}
|
||||
else if (args.Parameters[0] == "sapphire")
|
||||
{
|
||||
num = 8;
|
||||
}
|
||||
else if (args.Parameters[0] == "ruby")
|
||||
{
|
||||
num = 9;
|
||||
}
|
||||
else if (args.Parameters[0] == "emerald")
|
||||
{
|
||||
num = 10;
|
||||
}
|
||||
else if (args.Parameters[0] == "topaz")
|
||||
{
|
||||
num = 11;
|
||||
}
|
||||
else if (args.Parameters[0] == "amethyst")
|
||||
{
|
||||
num = 12;
|
||||
}
|
||||
else if (args.Parameters[0] == "diamond")
|
||||
{
|
||||
num = 13;
|
||||
else if (args.Parameters[0] == "demonite")
|
||||
{
|
||||
num = 7;
|
||||
}
|
||||
else if (args.Parameters[0] == "sapphire")
|
||||
{
|
||||
num = 8;
|
||||
}
|
||||
else if (args.Parameters[0] == "ruby")
|
||||
{
|
||||
num = 9;
|
||||
}
|
||||
else if (args.Parameters[0] == "emerald")
|
||||
{
|
||||
num = 10;
|
||||
}
|
||||
else if (args.Parameters[0] == "topaz")
|
||||
{
|
||||
num = 11;
|
||||
}
|
||||
else if (args.Parameters[0] == "amethyst")
|
||||
{
|
||||
num = 12;
|
||||
}
|
||||
else if (args.Parameters[0] == "diamond")
|
||||
{
|
||||
num = 13;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -1179,40 +1179,40 @@ namespace TShockAPI
|
|||
num = 9;
|
||||
num3 *= 1.1f;
|
||||
}
|
||||
else if (num == 7)
|
||||
{
|
||||
num = 22;
|
||||
num3 *= 1;
|
||||
}
|
||||
else if (num == 8)
|
||||
{
|
||||
num = 63;
|
||||
num3 *= .80f;
|
||||
}
|
||||
else if (num == 9)
|
||||
{
|
||||
num = 64;
|
||||
num3 *=1;
|
||||
}
|
||||
else if (num == 10)
|
||||
{
|
||||
num = 65;
|
||||
num3 *= 1;
|
||||
}
|
||||
else if (num == 11)
|
||||
{
|
||||
num = 66;
|
||||
num3 *= 1;
|
||||
}
|
||||
else if (num == 12)
|
||||
{
|
||||
num = 67;
|
||||
num3 *= 1;
|
||||
}
|
||||
else if (num == 13)
|
||||
{
|
||||
num = 68;
|
||||
num3 *= 1;
|
||||
else if (num == 7)
|
||||
{
|
||||
num = 22;
|
||||
num3 *= 1;
|
||||
}
|
||||
else if (num == 8)
|
||||
{
|
||||
num = 63;
|
||||
num3 *= .80f;
|
||||
}
|
||||
else if (num == 9)
|
||||
{
|
||||
num = 64;
|
||||
num3 *=1;
|
||||
}
|
||||
else if (num == 10)
|
||||
{
|
||||
num = 65;
|
||||
num3 *= 1;
|
||||
}
|
||||
else if (num == 11)
|
||||
{
|
||||
num = 66;
|
||||
num3 *= 1;
|
||||
}
|
||||
else if (num == 12)
|
||||
{
|
||||
num = 67;
|
||||
num3 *= 1;
|
||||
}
|
||||
else if (num == 13)
|
||||
{
|
||||
num = 68;
|
||||
num3 *= 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -1598,38 +1598,38 @@ namespace TShockAPI
|
|||
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:
|
||||
case 113:
|
||||
case 110:
|
||||
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 = 53;
|
||||
break;
|
||||
case 118:
|
||||
Main.tile[x, y].type = 38;
|
||||
break;
|
||||
case 115:
|
||||
Main.tile[x, y].type = 52;
|
||||
break;
|
||||
default:
|
||||
continue;
|
||||
{
|
||||
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:
|
||||
case 113:
|
||||
case 110:
|
||||
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 = 53;
|
||||
break;
|
||||
case 118:
|
||||
Main.tile[x, y].type = 38;
|
||||
break;
|
||||
case 115:
|
||||
Main.tile[x, y].type = 52;
|
||||
break;
|
||||
default:
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -2262,7 +2262,7 @@ namespace TShockAPI
|
|||
|
||||
private static void Reload(CommandArgs args)
|
||||
{
|
||||
FileTools.SetupConfig();
|
||||
FileTools.SetupConfig();
|
||||
TShock.HandleCommandLinePostConfigLoad(Environment.GetCommandLineArgs());
|
||||
TShock.Groups.LoadPermisions();
|
||||
TShock.Regions.ReloadAllRegions();
|
||||
|
|
|
|||
|
|
@ -1,287 +1,287 @@
|
|||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.ComponentModel;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using Newtonsoft.Json;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
public class ConfigFile
|
||||
{
|
||||
[Description(
|
||||
"The equation for calculating invasion size is 100 + (multiplier * (number of active players with greater than 200 health))"
|
||||
)] public int InvasionMultiplier = 1;
|
||||
|
||||
[Description("The default maximum mobs that will spawn per wave. Higher means more mobs in that wave.")] public int
|
||||
DefaultMaximumSpawns = 5;
|
||||
|
||||
[Description("The delay between waves. Shorter values lead to less mobs.")] public int DefaultSpawnRate = 600;
|
||||
[Description("The port the server runs on.")] public int ServerPort = 7777;
|
||||
[Description("Enable or disable the whitelist based on IP addresses in whitelist.txt")] public bool EnableWhitelist;
|
||||
|
||||
[Description(
|
||||
"Enable the ability for invaison size to never decrease. Make sure to run /invade, and note that this adds 2 million+ goblins to the spawn que for the map."
|
||||
)] public bool InfiniteInvasion;
|
||||
|
||||
[Description("Set the server pvp mode. Vaild types are, \"normal\", \"always\", \"disabled\"")] public string PvPMode
|
||||
= "normal";
|
||||
|
||||
[Description("Prevents tiles from being placed within SpawnProtectionRadius of the default spawn.")] public bool
|
||||
SpawnProtection = true;
|
||||
|
||||
[Description("Radius from spawn tile for SpawnProtection.")] public int SpawnProtectionRadius = 10;
|
||||
|
||||
[Description(
|
||||
"Max slots for the server. If you want people to be kicked with \"Server is full\" set this to how many players you want max and then set Terraria max players to 2 higher."
|
||||
)] public int MaxSlots = 8;
|
||||
|
||||
[Description("Global protection agent for any block distance based anti-grief check.")] public bool RangeChecks = true;
|
||||
[Description("Disables any building; placing of blocks")] public bool DisableBuild;
|
||||
|
||||
[Description("#.#.#. = Red/Blue/Green - RGB Colors for the Admin Chat Color. Max value: 255")] public float[]
|
||||
SuperAdminChatRGB = {255, 0, 0};
|
||||
|
||||
[Description("Super admin group chat prefix")] public string SuperAdminChatPrefix = "(Admin) ";
|
||||
[Description("Super admin group chat suffix")] public string SuperAdminChatSuffix = "";
|
||||
|
||||
[Description(
|
||||
"Backup frequency in minutes. So, a value of 60 = 60 minutes. Backups are stored in the \\tshock\\backups folder.")] public int BackupInterval;
|
||||
|
||||
[Description("How long backups are kept in minutes. 2880 = 2 days.")] public int BackupKeepFor = 60;
|
||||
|
||||
[Description(
|
||||
"Remembers where a player left off. It works by remembering the IP, NOT the character. \neg. When you try to disconnect, and reconnect to be automatically placed at spawn, you'll be at your last location. Note: Won't save after server restarts."
|
||||
)] public bool RememberLeavePos;
|
||||
|
||||
[Description("Hardcore players ONLY. This means softcore players cannot join.")] public bool HardcoreOnly;
|
||||
[Description("Mediumcore players ONLY. This means softcore players cannot join.")] public bool MediumcoreOnly;
|
||||
[Description("Kicks a Hardcore player on death.")] public bool KickOnMediumcoreDeath;
|
||||
[Description("Bans a Hardcore player on death.")] public bool BanOnMediumcoreDeath;
|
||||
|
||||
[Description("Enable/Disable Terrarias built in auto save")] public bool AutoSave = true;
|
||||
|
||||
[Description("Number of failed login attempts before kicking the player.")] public int MaximumLoginAttempts = 3;
|
||||
|
||||
[Description("Not implemented")] public string RconPassword = "";
|
||||
[Description("Not implemented")] public int RconPort = 7777;
|
||||
|
||||
[Description("Used when replying to a rest /status request.")] public string ServerName = "";
|
||||
[Description("Not implemented")] public string MasterServer = "127.0.0.1";
|
||||
|
||||
[Description("Valid types are \"sqlite\" and \"mysql\"")] public string StorageType = "sqlite";
|
||||
|
||||
[Description("The MySQL Hostname and port to direct connections to")] public string MySqlHost = "localhost:3306";
|
||||
[Description("Database name to connect to")] public string MySqlDbName = "";
|
||||
[Description("Database username to connect with")] public string MySqlUsername = "";
|
||||
[Description("Database password to connect with")] public string MySqlPassword = "";
|
||||
|
||||
[Description("Bans a Mediumcore player on death.")] public string MediumcoreBanReason = "Death results in a ban";
|
||||
[Description("Kicks a Mediumcore player on death.")] public string MediumcoreKickReason = "Death results in a kick";
|
||||
|
||||
[Description("Enables DNS resolution of incoming connections with GetGroupForIPExpensive.")] public bool
|
||||
EnableDNSHostResolution;
|
||||
|
||||
[Description("Enables kicking of banned users by matching their IP Address")] public bool EnableIPBans = true;
|
||||
|
||||
[Description("Enables kicking of banned users by matching their Character Name")] public bool EnableBanOnUsernames;
|
||||
|
||||
[Description("Selects the default group name to place new registrants under")] public string
|
||||
DefaultRegistrationGroupName = "default";
|
||||
|
||||
[Description("Selects the default group name to place non registered users under")] public string
|
||||
DefaultGuestGroupName = "guest";
|
||||
|
||||
[Description("Force-Disable printing logs to players with the log permission")] public bool DisableSpewLogs = true;
|
||||
|
||||
[Description("Valid types are \"sha512\", \"sha256\", \"md5\", append with \"-xp\" for the xp supported algorithms")] public string HashAlgorithm = "sha512";
|
||||
|
||||
[Description("Buffers up the packets and sends them out at the end of each frame")] public bool BufferPackets = true;
|
||||
|
||||
[Description("String that is used when kicking people when the server is full.")] public string ServerFullReason =
|
||||
"Server is full";
|
||||
|
||||
[Description("String that is used when kicking people when the server is full with no reserved slots.")] public string
|
||||
ServerFullNoReservedReason = "Server is full. No reserved slots open.";
|
||||
|
||||
[Description("This will save the world if Terraria crashes from an unhandled exception.")] public bool
|
||||
SaveWorldOnCrash = true;
|
||||
|
||||
[Description("This will announce a player's location on join")] public bool EnableGeoIP;
|
||||
|
||||
[Description("This will turn on a token requirement for the /status API endpoint.")] public bool
|
||||
EnableTokenEndpointAuthentication;
|
||||
|
||||
[Description("This is used when the API endpoint /status is queried.")] public string ServerNickname = "TShock Server";
|
||||
|
||||
[Description("Enable/Disable the rest api.")] public bool RestApiEnabled;
|
||||
|
||||
[Description("This is the port which the rest api will listen on.")] public int RestApiPort = 7878;
|
||||
|
||||
[Description("Disable tombstones for all players.")] public bool DisableTombstones = true;
|
||||
|
||||
[Description("Displays a player's IP on join to everyone who has the log permission")] public bool DisplayIPToAdmins;
|
||||
|
||||
[Description(
|
||||
"Some tiles are 'fixed' by not letting TShock handle them. Disabling this may break certain asthetic tiles.")] public
|
||||
bool EnableInsecureTileFixes = true;
|
||||
|
||||
[Description("Kicks users using a proxy as identified with the GeoIP database")] public bool KickProxyUsers = true;
|
||||
|
||||
[Description("Disables hardmode, can't never be activated. Overrides /starthardmode")] public bool DisableHardmode;
|
||||
|
||||
[Description("Disables Dungeon Guardian from being spawned by player packets, this will instead force a respawn")] public bool DisableDungeonGuardian;
|
||||
|
||||
[Description("Enable Server Side Inventory checks, EXPERIMENTAL")] public bool ServerSideInventory;
|
||||
|
||||
[Description("How often SSI should save, in minutes")] public int ServerSideInventorySave = 15;
|
||||
|
||||
[Description("Time, in milliseconds, to disallow discarding items after logging in when ServerSideInventory is ON")] public int LogonDiscardThreshold=250;
|
||||
|
||||
[Description("Disables reporting of playercount to the stat system.")] public bool DisablePlayerCountReporting;
|
||||
|
||||
[Description("Disables clown bomb projectiles from spawning")] public bool DisableClownBombs;
|
||||
|
||||
[Description("Disables snow ball projectiles from spawning")] public bool DisableSnowBalls;
|
||||
|
||||
[Description(
|
||||
"Change ingame chat format, {0} = Group Name, {1} = Group Prefix, {2} = Player Name, {3} = Group Suffix, {4} = Chat Message"
|
||||
)] public string ChatFormat = "{1}{2}{3}: {4}";
|
||||
|
||||
[Description("Force the world time to be normal, day, or night")] public string ForceTime = "normal";
|
||||
|
||||
[Description("Disable/Revert a player if they exceed this number of tile kills within 1 second.")] public int
|
||||
TileKillThreshold = 60;
|
||||
|
||||
[Description("Disable/Revert a player if they exceed this number of tile places within 1 second.")] public int
|
||||
TilePlaceThreshold = 20;
|
||||
|
||||
[Description("Disable a player if they exceed this number of liquid sets within 1 second.")] public int
|
||||
TileLiquidThreshold = 15;
|
||||
|
||||
[Description("Disable a player if they exceed this number of projectile new within 1 second.")] public int
|
||||
ProjectileThreshold = 50;
|
||||
|
||||
[Description("Ignore shrapnel from crystal bullets for Projectile Threshold.")] public bool
|
||||
ProjIgnoreShrapnel = true;
|
||||
|
||||
[Description("Require all players to register or login before being allowed to play.")] public bool RequireLogin;
|
||||
|
||||
[Description(
|
||||
"Disables Invisibility potions from being used in PvP (Note, they can use them on the client, but the effect isn't sent to the rest of the server)"
|
||||
)] public bool DisableInvisPvP;
|
||||
|
||||
[Description("The maximum distance players disabled for various reasons can move from")] public int
|
||||
MaxRangeForDisabled = 10;
|
||||
|
||||
[Description("Server password required to join server")] public string ServerPassword = "";
|
||||
|
||||
[Description("Protect chests with region and build permissions")] public bool RegionProtectChests;
|
||||
|
||||
[Description("Disable users from being able to login with account password when joining")] public bool
|
||||
DisableLoginBeforeJoin;
|
||||
|
||||
[Description("Allows users to register any username with /register")] public bool AllowRegisterAnyUsername;
|
||||
|
||||
[Description("Allows users to login with any username with /login")] public bool AllowLoginAnyUsername = true;
|
||||
|
||||
[Description("The maximum damage a player/npc can inflict")] public int MaxDamage = 175;
|
||||
|
||||
[Description("The maximum damage a projectile can inflict")] public int MaxProjDamage = 175;
|
||||
|
||||
[Description("Ignores checking to see if player 'can' update a projectile")] public bool IgnoreProjUpdate = false;
|
||||
|
||||
[Description("Ignores checking to see if player 'can' kill a projectile")] public bool IgnoreProjKill = false;
|
||||
|
||||
[Description("Ignores all no clip checks for players")] public bool IgnoreNoClip = false;
|
||||
|
||||
[Description("Allow Ice placement even when user does not have canbuild")] public bool AllowIce = false;
|
||||
|
||||
public static ConfigFile Read(string path)
|
||||
{
|
||||
if (!File.Exists(path))
|
||||
return new ConfigFile();
|
||||
using (var fs = new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.Read))
|
||||
{
|
||||
return Read(fs);
|
||||
}
|
||||
}
|
||||
|
||||
public static ConfigFile Read(Stream stream)
|
||||
{
|
||||
using (var sr = new StreamReader(stream))
|
||||
{
|
||||
var cf = JsonConvert.DeserializeObject<ConfigFile>(sr.ReadToEnd());
|
||||
if (ConfigRead != null)
|
||||
ConfigRead(cf);
|
||||
return cf;
|
||||
}
|
||||
}
|
||||
|
||||
public void Write(string path)
|
||||
{
|
||||
using (var fs = new FileStream(path, FileMode.Create, FileAccess.Write, FileShare.Write))
|
||||
{
|
||||
Write(fs);
|
||||
}
|
||||
}
|
||||
|
||||
public void Write(Stream stream)
|
||||
{
|
||||
var str = JsonConvert.SerializeObject(this, Formatting.Indented);
|
||||
using (var sw = new StreamWriter(stream))
|
||||
{
|
||||
sw.Write(str);
|
||||
}
|
||||
}
|
||||
|
||||
public static Action<ConfigFile> ConfigRead;
|
||||
|
||||
|
||||
public static void DumpDescriptions()
|
||||
{
|
||||
var sb = new StringBuilder();
|
||||
var defaults = new ConfigFile();
|
||||
|
||||
foreach (var field in defaults.GetType().GetFields().OrderBy(f => f.Name))
|
||||
{
|
||||
if (field.IsStatic)
|
||||
continue;
|
||||
|
||||
var name = field.Name;
|
||||
var type = field.FieldType.Name;
|
||||
|
||||
var descattr =
|
||||
field.GetCustomAttributes(false).FirstOrDefault(o => o is DescriptionAttribute) as DescriptionAttribute;
|
||||
var desc = descattr != null && !string.IsNullOrWhiteSpace(descattr.Description) ? descattr.Description : "None";
|
||||
|
||||
var def = field.GetValue(defaults);
|
||||
|
||||
sb.AppendLine("## {0} ".SFormat(name));
|
||||
sb.AppendLine("**Type:** {0} ".SFormat(type));
|
||||
sb.AppendLine("**Description:** {0} ".SFormat(desc));
|
||||
sb.AppendLine("**Default:** \"{0}\" ".SFormat(def));
|
||||
sb.AppendLine();
|
||||
}
|
||||
|
||||
File.WriteAllText("ConfigDescriptions.txt", sb.ToString());
|
||||
}
|
||||
}
|
||||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.ComponentModel;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using Newtonsoft.Json;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
public class ConfigFile
|
||||
{
|
||||
[Description(
|
||||
"The equation for calculating invasion size is 100 + (multiplier * (number of active players with greater than 200 health))"
|
||||
)] public int InvasionMultiplier = 1;
|
||||
|
||||
[Description("The default maximum mobs that will spawn per wave. Higher means more mobs in that wave.")] public int
|
||||
DefaultMaximumSpawns = 5;
|
||||
|
||||
[Description("The delay between waves. Shorter values lead to less mobs.")] public int DefaultSpawnRate = 600;
|
||||
[Description("The port the server runs on.")] public int ServerPort = 7777;
|
||||
[Description("Enable or disable the whitelist based on IP addresses in whitelist.txt")] public bool EnableWhitelist;
|
||||
|
||||
[Description(
|
||||
"Enable the ability for invaison size to never decrease. Make sure to run /invade, and note that this adds 2 million+ goblins to the spawn que for the map."
|
||||
)] public bool InfiniteInvasion;
|
||||
|
||||
[Description("Set the server pvp mode. Vaild types are, \"normal\", \"always\", \"disabled\"")] public string PvPMode
|
||||
= "normal";
|
||||
|
||||
[Description("Prevents tiles from being placed within SpawnProtectionRadius of the default spawn.")] public bool
|
||||
SpawnProtection = true;
|
||||
|
||||
[Description("Radius from spawn tile for SpawnProtection.")] public int SpawnProtectionRadius = 10;
|
||||
|
||||
[Description(
|
||||
"Max slots for the server. If you want people to be kicked with \"Server is full\" set this to how many players you want max and then set Terraria max players to 2 higher."
|
||||
)] public int MaxSlots = 8;
|
||||
|
||||
[Description("Global protection agent for any block distance based anti-grief check.")] public bool RangeChecks = true;
|
||||
[Description("Disables any building; placing of blocks")] public bool DisableBuild;
|
||||
|
||||
[Description("#.#.#. = Red/Blue/Green - RGB Colors for the Admin Chat Color. Max value: 255")] public float[]
|
||||
SuperAdminChatRGB = {255, 0, 0};
|
||||
|
||||
[Description("Super admin group chat prefix")] public string SuperAdminChatPrefix = "(Admin) ";
|
||||
[Description("Super admin group chat suffix")] public string SuperAdminChatSuffix = "";
|
||||
|
||||
[Description(
|
||||
"Backup frequency in minutes. So, a value of 60 = 60 minutes. Backups are stored in the \\tshock\\backups folder.")] public int BackupInterval;
|
||||
|
||||
[Description("How long backups are kept in minutes. 2880 = 2 days.")] public int BackupKeepFor = 60;
|
||||
|
||||
[Description(
|
||||
"Remembers where a player left off. It works by remembering the IP, NOT the character. \neg. When you try to disconnect, and reconnect to be automatically placed at spawn, you'll be at your last location. Note: Won't save after server restarts."
|
||||
)] public bool RememberLeavePos;
|
||||
|
||||
[Description("Hardcore players ONLY. This means softcore players cannot join.")] public bool HardcoreOnly;
|
||||
[Description("Mediumcore players ONLY. This means softcore players cannot join.")] public bool MediumcoreOnly;
|
||||
[Description("Kicks a Hardcore player on death.")] public bool KickOnMediumcoreDeath;
|
||||
[Description("Bans a Hardcore player on death.")] public bool BanOnMediumcoreDeath;
|
||||
|
||||
[Description("Enable/Disable Terrarias built in auto save")] public bool AutoSave = true;
|
||||
|
||||
[Description("Number of failed login attempts before kicking the player.")] public int MaximumLoginAttempts = 3;
|
||||
|
||||
[Description("Not implemented")] public string RconPassword = "";
|
||||
[Description("Not implemented")] public int RconPort = 7777;
|
||||
|
||||
[Description("Used when replying to a rest /status request.")] public string ServerName = "";
|
||||
[Description("Not implemented")] public string MasterServer = "127.0.0.1";
|
||||
|
||||
[Description("Valid types are \"sqlite\" and \"mysql\"")] public string StorageType = "sqlite";
|
||||
|
||||
[Description("The MySQL Hostname and port to direct connections to")] public string MySqlHost = "localhost:3306";
|
||||
[Description("Database name to connect to")] public string MySqlDbName = "";
|
||||
[Description("Database username to connect with")] public string MySqlUsername = "";
|
||||
[Description("Database password to connect with")] public string MySqlPassword = "";
|
||||
|
||||
[Description("Bans a Mediumcore player on death.")] public string MediumcoreBanReason = "Death results in a ban";
|
||||
[Description("Kicks a Mediumcore player on death.")] public string MediumcoreKickReason = "Death results in a kick";
|
||||
|
||||
[Description("Enables DNS resolution of incoming connections with GetGroupForIPExpensive.")] public bool
|
||||
EnableDNSHostResolution;
|
||||
|
||||
[Description("Enables kicking of banned users by matching their IP Address")] public bool EnableIPBans = true;
|
||||
|
||||
[Description("Enables kicking of banned users by matching their Character Name")] public bool EnableBanOnUsernames;
|
||||
|
||||
[Description("Selects the default group name to place new registrants under")] public string
|
||||
DefaultRegistrationGroupName = "default";
|
||||
|
||||
[Description("Selects the default group name to place non registered users under")] public string
|
||||
DefaultGuestGroupName = "guest";
|
||||
|
||||
[Description("Force-Disable printing logs to players with the log permission")] public bool DisableSpewLogs = true;
|
||||
|
||||
[Description("Valid types are \"sha512\", \"sha256\", \"md5\", append with \"-xp\" for the xp supported algorithms")] public string HashAlgorithm = "sha512";
|
||||
|
||||
[Description("Buffers up the packets and sends them out at the end of each frame")] public bool BufferPackets = true;
|
||||
|
||||
[Description("String that is used when kicking people when the server is full.")] public string ServerFullReason =
|
||||
"Server is full";
|
||||
|
||||
[Description("String that is used when kicking people when the server is full with no reserved slots.")] public string
|
||||
ServerFullNoReservedReason = "Server is full. No reserved slots open.";
|
||||
|
||||
[Description("This will save the world if Terraria crashes from an unhandled exception.")] public bool
|
||||
SaveWorldOnCrash = true;
|
||||
|
||||
[Description("This will announce a player's location on join")] public bool EnableGeoIP;
|
||||
|
||||
[Description("This will turn on a token requirement for the /status API endpoint.")] public bool
|
||||
EnableTokenEndpointAuthentication;
|
||||
|
||||
[Description("This is used when the API endpoint /status is queried.")] public string ServerNickname = "TShock Server";
|
||||
|
||||
[Description("Enable/Disable the rest api.")] public bool RestApiEnabled;
|
||||
|
||||
[Description("This is the port which the rest api will listen on.")] public int RestApiPort = 7878;
|
||||
|
||||
[Description("Disable tombstones for all players.")] public bool DisableTombstones = true;
|
||||
|
||||
[Description("Displays a player's IP on join to everyone who has the log permission")] public bool DisplayIPToAdmins;
|
||||
|
||||
[Description(
|
||||
"Some tiles are 'fixed' by not letting TShock handle them. Disabling this may break certain asthetic tiles.")] public
|
||||
bool EnableInsecureTileFixes = true;
|
||||
|
||||
[Description("Kicks users using a proxy as identified with the GeoIP database")] public bool KickProxyUsers = true;
|
||||
|
||||
[Description("Disables hardmode, can't never be activated. Overrides /starthardmode")] public bool DisableHardmode;
|
||||
|
||||
[Description("Disables Dungeon Guardian from being spawned by player packets, this will instead force a respawn")] public bool DisableDungeonGuardian;
|
||||
|
||||
[Description("Enable Server Side Inventory checks, EXPERIMENTAL")] public bool ServerSideInventory;
|
||||
|
||||
[Description("How often SSI should save, in minutes")] public int ServerSideInventorySave = 15;
|
||||
|
||||
[Description("Time, in milliseconds, to disallow discarding items after logging in when ServerSideInventory is ON")] public int LogonDiscardThreshold=250;
|
||||
|
||||
[Description("Disables reporting of playercount to the stat system.")] public bool DisablePlayerCountReporting;
|
||||
|
||||
[Description("Disables clown bomb projectiles from spawning")] public bool DisableClownBombs;
|
||||
|
||||
[Description("Disables snow ball projectiles from spawning")] public bool DisableSnowBalls;
|
||||
|
||||
[Description(
|
||||
"Change ingame chat format, {0} = Group Name, {1} = Group Prefix, {2} = Player Name, {3} = Group Suffix, {4} = Chat Message"
|
||||
)] public string ChatFormat = "{1}{2}{3}: {4}";
|
||||
|
||||
[Description("Force the world time to be normal, day, or night")] public string ForceTime = "normal";
|
||||
|
||||
[Description("Disable/Revert a player if they exceed this number of tile kills within 1 second.")] public int
|
||||
TileKillThreshold = 60;
|
||||
|
||||
[Description("Disable/Revert a player if they exceed this number of tile places within 1 second.")] public int
|
||||
TilePlaceThreshold = 20;
|
||||
|
||||
[Description("Disable a player if they exceed this number of liquid sets within 1 second.")] public int
|
||||
TileLiquidThreshold = 15;
|
||||
|
||||
[Description("Disable a player if they exceed this number of projectile new within 1 second.")] public int
|
||||
ProjectileThreshold = 50;
|
||||
|
||||
[Description("Ignore shrapnel from crystal bullets for Projectile Threshold.")] public bool
|
||||
ProjIgnoreShrapnel = true;
|
||||
|
||||
[Description("Require all players to register or login before being allowed to play.")] public bool RequireLogin;
|
||||
|
||||
[Description(
|
||||
"Disables Invisibility potions from being used in PvP (Note, they can use them on the client, but the effect isn't sent to the rest of the server)"
|
||||
)] public bool DisableInvisPvP;
|
||||
|
||||
[Description("The maximum distance players disabled for various reasons can move from")] public int
|
||||
MaxRangeForDisabled = 10;
|
||||
|
||||
[Description("Server password required to join server")] public string ServerPassword = "";
|
||||
|
||||
[Description("Protect chests with region and build permissions")] public bool RegionProtectChests;
|
||||
|
||||
[Description("Disable users from being able to login with account password when joining")] public bool
|
||||
DisableLoginBeforeJoin;
|
||||
|
||||
[Description("Allows users to register any username with /register")] public bool AllowRegisterAnyUsername;
|
||||
|
||||
[Description("Allows users to login with any username with /login")] public bool AllowLoginAnyUsername = true;
|
||||
|
||||
[Description("The maximum damage a player/npc can inflict")] public int MaxDamage = 175;
|
||||
|
||||
[Description("The maximum damage a projectile can inflict")] public int MaxProjDamage = 175;
|
||||
|
||||
[Description("Ignores checking to see if player 'can' update a projectile")] public bool IgnoreProjUpdate = false;
|
||||
|
||||
[Description("Ignores checking to see if player 'can' kill a projectile")] public bool IgnoreProjKill = false;
|
||||
|
||||
[Description("Ignores all no clip checks for players")] public bool IgnoreNoClip = false;
|
||||
|
||||
[Description("Allow Ice placement even when user does not have canbuild")] public bool AllowIce = false;
|
||||
|
||||
public static ConfigFile Read(string path)
|
||||
{
|
||||
if (!File.Exists(path))
|
||||
return new ConfigFile();
|
||||
using (var fs = new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.Read))
|
||||
{
|
||||
return Read(fs);
|
||||
}
|
||||
}
|
||||
|
||||
public static ConfigFile Read(Stream stream)
|
||||
{
|
||||
using (var sr = new StreamReader(stream))
|
||||
{
|
||||
var cf = JsonConvert.DeserializeObject<ConfigFile>(sr.ReadToEnd());
|
||||
if (ConfigRead != null)
|
||||
ConfigRead(cf);
|
||||
return cf;
|
||||
}
|
||||
}
|
||||
|
||||
public void Write(string path)
|
||||
{
|
||||
using (var fs = new FileStream(path, FileMode.Create, FileAccess.Write, FileShare.Write))
|
||||
{
|
||||
Write(fs);
|
||||
}
|
||||
}
|
||||
|
||||
public void Write(Stream stream)
|
||||
{
|
||||
var str = JsonConvert.SerializeObject(this, Formatting.Indented);
|
||||
using (var sw = new StreamWriter(stream))
|
||||
{
|
||||
sw.Write(str);
|
||||
}
|
||||
}
|
||||
|
||||
public static Action<ConfigFile> ConfigRead;
|
||||
|
||||
|
||||
public static void DumpDescriptions()
|
||||
{
|
||||
var sb = new StringBuilder();
|
||||
var defaults = new ConfigFile();
|
||||
|
||||
foreach (var field in defaults.GetType().GetFields().OrderBy(f => f.Name))
|
||||
{
|
||||
if (field.IsStatic)
|
||||
continue;
|
||||
|
||||
var name = field.Name;
|
||||
var type = field.FieldType.Name;
|
||||
|
||||
var descattr =
|
||||
field.GetCustomAttributes(false).FirstOrDefault(o => o is DescriptionAttribute) as DescriptionAttribute;
|
||||
var desc = descattr != null && !string.IsNullOrWhiteSpace(descattr.Description) ? descattr.Description : "None";
|
||||
|
||||
var def = field.GetValue(defaults);
|
||||
|
||||
sb.AppendLine("## {0} ".SFormat(name));
|
||||
sb.AppendLine("**Type:** {0} ".SFormat(type));
|
||||
sb.AppendLine("**Description:** {0} ".SFormat(desc));
|
||||
sb.AppendLine("**Default:** \"{0}\" ".SFormat(def));
|
||||
sb.AppendLine();
|
||||
}
|
||||
|
||||
File.WriteAllText("ConfigDescriptions.txt", sb.ToString());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
/*
|
||||
/*
|
||||
TShock, a server mod for Terraria
|
||||
Copyright (C) 2011 The TShock Team
|
||||
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
/*
|
||||
/*
|
||||
TShock, a server mod for Terraria
|
||||
Copyright (C) 2011 The TShock Team
|
||||
|
||||
|
|
|
|||
|
|
@ -1,119 +1,119 @@
|
|||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.IO;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
public class FileTools
|
||||
{
|
||||
internal static string RulesPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "rules.txt"); }
|
||||
}
|
||||
|
||||
internal static string MotdPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "motd.txt"); }
|
||||
}
|
||||
|
||||
internal static string WhitelistPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "whitelist.txt"); }
|
||||
}
|
||||
|
||||
internal static string RememberedPosPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "oldpos.xml"); }
|
||||
}
|
||||
|
||||
internal static string ConfigPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "config.json"); }
|
||||
}
|
||||
|
||||
public static void CreateFile(string file)
|
||||
{
|
||||
File.Create(file).Close();
|
||||
}
|
||||
|
||||
public static void CreateIfNot(string file, string data = "")
|
||||
{
|
||||
if (!File.Exists(file))
|
||||
{
|
||||
File.WriteAllText(file, data);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Sets up the configuration file for all variables, and creates any missing files.
|
||||
/// </summary>
|
||||
public static void SetupConfig()
|
||||
{
|
||||
if (!Directory.Exists(TShock.SavePath))
|
||||
{
|
||||
Directory.CreateDirectory(TShock.SavePath);
|
||||
}
|
||||
|
||||
CreateIfNot(RulesPath, "Respect the admins!\nDon't use TNT!");
|
||||
CreateIfNot(MotdPath,
|
||||
"This server is running TShock for Terraria.\n Type /help for a list of commands.\n%255,000,000%Current map: %map%\nCurrent players: %players%");
|
||||
CreateIfNot(WhitelistPath);
|
||||
if (File.Exists(ConfigPath))
|
||||
{
|
||||
TShock.Config = ConfigFile.Read(ConfigPath);
|
||||
// Add all the missing config properties in the json file
|
||||
}
|
||||
TShock.Config.Write(ConfigPath);
|
||||
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Tells if a user is on the whitelist
|
||||
/// </summary>
|
||||
/// <param name="ip">string ip of the user</param>
|
||||
/// <returns>true/false</returns>
|
||||
public static bool OnWhitelist(string ip)
|
||||
{
|
||||
if (!TShock.Config.EnableWhitelist)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
CreateIfNot(WhitelistPath, "127.0.0.1");
|
||||
using (var tr = new StreamReader(WhitelistPath))
|
||||
{
|
||||
string whitelist = tr.ReadToEnd();
|
||||
ip = TShock.Utils.GetRealIP(ip);
|
||||
bool contains = whitelist.Contains(ip);
|
||||
if (!contains)
|
||||
{
|
||||
foreach (var line in whitelist.Split(Environment.NewLine.ToCharArray()))
|
||||
{
|
||||
if (string.IsNullOrWhiteSpace(line))
|
||||
continue;
|
||||
contains = TShock.Utils.GetIPv4Address(line).Equals(ip);
|
||||
if (contains)
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.IO;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
public class FileTools
|
||||
{
|
||||
internal static string RulesPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "rules.txt"); }
|
||||
}
|
||||
|
||||
internal static string MotdPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "motd.txt"); }
|
||||
}
|
||||
|
||||
internal static string WhitelistPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "whitelist.txt"); }
|
||||
}
|
||||
|
||||
internal static string RememberedPosPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "oldpos.xml"); }
|
||||
}
|
||||
|
||||
internal static string ConfigPath
|
||||
{
|
||||
get { return Path.Combine(TShock.SavePath, "config.json"); }
|
||||
}
|
||||
|
||||
public static void CreateFile(string file)
|
||||
{
|
||||
File.Create(file).Close();
|
||||
}
|
||||
|
||||
public static void CreateIfNot(string file, string data = "")
|
||||
{
|
||||
if (!File.Exists(file))
|
||||
{
|
||||
File.WriteAllText(file, data);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Sets up the configuration file for all variables, and creates any missing files.
|
||||
/// </summary>
|
||||
public static void SetupConfig()
|
||||
{
|
||||
if (!Directory.Exists(TShock.SavePath))
|
||||
{
|
||||
Directory.CreateDirectory(TShock.SavePath);
|
||||
}
|
||||
|
||||
CreateIfNot(RulesPath, "Respect the admins!\nDon't use TNT!");
|
||||
CreateIfNot(MotdPath,
|
||||
"This server is running TShock for Terraria.\n Type /help for a list of commands.\n%255,000,000%Current map: %map%\nCurrent players: %players%");
|
||||
CreateIfNot(WhitelistPath);
|
||||
if (File.Exists(ConfigPath))
|
||||
{
|
||||
TShock.Config = ConfigFile.Read(ConfigPath);
|
||||
// Add all the missing config properties in the json file
|
||||
}
|
||||
TShock.Config.Write(ConfigPath);
|
||||
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Tells if a user is on the whitelist
|
||||
/// </summary>
|
||||
/// <param name="ip">string ip of the user</param>
|
||||
/// <returns>true/false</returns>
|
||||
public static bool OnWhitelist(string ip)
|
||||
{
|
||||
if (!TShock.Config.EnableWhitelist)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
CreateIfNot(WhitelistPath, "127.0.0.1");
|
||||
using (var tr = new StreamReader(WhitelistPath))
|
||||
{
|
||||
string whitelist = tr.ReadToEnd();
|
||||
ip = TShock.Utils.GetRealIP(ip);
|
||||
bool contains = whitelist.Contains(ip);
|
||||
if (!contains)
|
||||
{
|
||||
foreach (var line in whitelist.Split(Environment.NewLine.ToCharArray()))
|
||||
{
|
||||
if (string.IsNullOrWhiteSpace(line))
|
||||
continue;
|
||||
contains = TShock.Utils.GetIPv4Address(line).Equals(ip);
|
||||
if (contains)
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
File diff suppressed because it is too large
Load diff
|
|
@ -1,200 +1,200 @@
|
|||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.Linq;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
public class Group
|
||||
{
|
||||
public readonly List<string> permissions = new List<string>();
|
||||
public readonly List<string> negatedpermissions = new List<string>();
|
||||
|
||||
public string Name { get; set; }
|
||||
public Group Parent { get; set; }
|
||||
public int Order { get; set; }
|
||||
public string Prefix { get; set; }
|
||||
public string Suffix { get; set; }
|
||||
public string ParentName { get { return (null == Parent) ? "" : Parent.Name; } }
|
||||
public string ChatColor
|
||||
{
|
||||
get { return string.Format("{0}{1}{2}", R.ToString("X2"), G.ToString("X2"), B.ToString("X2")); }
|
||||
set
|
||||
{
|
||||
if (null != value)
|
||||
{
|
||||
string[] parts = value.Split(',');
|
||||
if (3 == parts.Length)
|
||||
{
|
||||
byte r, g, b;
|
||||
if (byte.TryParse(parts[0], out r) && byte.TryParse(parts[1], out g) && byte.TryParse(parts[2], out b))
|
||||
{
|
||||
R = r;
|
||||
G = g;
|
||||
B = b;
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public string Permissions
|
||||
{
|
||||
get
|
||||
{
|
||||
List<string> all = new List<string>(permissions);
|
||||
negatedpermissions.ForEach(p => all.Add("!" + p));
|
||||
return string.Join(",", all);
|
||||
}
|
||||
set
|
||||
{
|
||||
permissions.Clear();
|
||||
negatedpermissions.Clear();
|
||||
if (null != value)
|
||||
value.Split(',').ForEach(p => AddPermission(p.Trim()));
|
||||
}
|
||||
}
|
||||
|
||||
public List<string> TotalPermissions
|
||||
{
|
||||
get
|
||||
{
|
||||
var cur = this;
|
||||
var traversed = new List<Group>();
|
||||
HashSet<string> all = new HashSet<string>();
|
||||
while (cur != null)
|
||||
{
|
||||
foreach (var perm in cur.permissions)
|
||||
{
|
||||
all.Add(perm);
|
||||
}
|
||||
|
||||
foreach (var perm in cur.negatedpermissions)
|
||||
{
|
||||
all.Remove(perm);
|
||||
}
|
||||
|
||||
if (traversed.Contains(cur))
|
||||
{
|
||||
throw new Exception("Infinite group parenting ({0})".SFormat(cur.Name));
|
||||
}
|
||||
traversed.Add(cur);
|
||||
cur = cur.Parent;
|
||||
}
|
||||
return all.ToList();
|
||||
}
|
||||
}
|
||||
|
||||
public byte R = 255;
|
||||
public byte G = 255;
|
||||
public byte B = 255;
|
||||
|
||||
public Group(string groupname, Group parentgroup = null, string chatcolor = "255,255,255", string permissions = null)
|
||||
{
|
||||
Name = groupname;
|
||||
Parent = parentgroup;
|
||||
ChatColor = chatcolor;
|
||||
Permissions = permissions;
|
||||
}
|
||||
|
||||
public virtual bool HasPermission(string permission)
|
||||
{
|
||||
if (string.IsNullOrEmpty(permission))
|
||||
return true;
|
||||
|
||||
var cur = this;
|
||||
var traversed = new List<Group>();
|
||||
while (cur != null)
|
||||
{
|
||||
if (cur.negatedpermissions.Contains(permission))
|
||||
return false;
|
||||
if (cur.permissions.Contains(permission))
|
||||
return true;
|
||||
if (traversed.Contains(cur))
|
||||
{
|
||||
throw new Exception("Infinite group parenting ({0})".SFormat(cur.Name));
|
||||
}
|
||||
traversed.Add(cur);
|
||||
cur = cur.Parent;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public void NegatePermission(string permission)
|
||||
{
|
||||
// Avoid duplicates
|
||||
if (!negatedpermissions.Contains(permission))
|
||||
{
|
||||
negatedpermissions.Add(permission);
|
||||
permissions.Remove(permission); // Ensure we don't have conflicting definitions for a permissions
|
||||
}
|
||||
}
|
||||
|
||||
public void AddPermission(string permission)
|
||||
{
|
||||
if (permission.StartsWith("!"))
|
||||
{
|
||||
NegatePermission(permission.Substring(1));
|
||||
return;
|
||||
}
|
||||
// Avoid duplicates
|
||||
if (!permissions.Contains(permission))
|
||||
{
|
||||
permissions.Add(permission);
|
||||
negatedpermissions.Remove(permission); // Ensure we don't have conflicting definitions for a permissions
|
||||
}
|
||||
}
|
||||
|
||||
public void SetPermission(List<string> permission)
|
||||
{
|
||||
permissions.Clear();
|
||||
negatedpermissions.Clear();
|
||||
permission.ForEach(p => AddPermission(p));
|
||||
}
|
||||
|
||||
public void RemovePermission(string permission)
|
||||
{
|
||||
if (permission.StartsWith("!"))
|
||||
{
|
||||
negatedpermissions.Remove(permission.Substring(1));
|
||||
return;
|
||||
}
|
||||
permissions.Remove(permission);
|
||||
}
|
||||
}
|
||||
|
||||
public class SuperAdminGroup : Group
|
||||
{
|
||||
public SuperAdminGroup()
|
||||
: base("superadmin")
|
||||
{
|
||||
R = (byte) TShock.Config.SuperAdminChatRGB[0];
|
||||
G = (byte) TShock.Config.SuperAdminChatRGB[1];
|
||||
B = (byte) TShock.Config.SuperAdminChatRGB[2];
|
||||
Prefix = TShock.Config.SuperAdminChatPrefix;
|
||||
Suffix = TShock.Config.SuperAdminChatSuffix;
|
||||
}
|
||||
|
||||
public override bool HasPermission(string permission)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.Linq;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
public class Group
|
||||
{
|
||||
public readonly List<string> permissions = new List<string>();
|
||||
public readonly List<string> negatedpermissions = new List<string>();
|
||||
|
||||
public string Name { get; set; }
|
||||
public Group Parent { get; set; }
|
||||
public int Order { get; set; }
|
||||
public string Prefix { get; set; }
|
||||
public string Suffix { get; set; }
|
||||
public string ParentName { get { return (null == Parent) ? "" : Parent.Name; } }
|
||||
public string ChatColor
|
||||
{
|
||||
get { return string.Format("{0}{1}{2}", R.ToString("X2"), G.ToString("X2"), B.ToString("X2")); }
|
||||
set
|
||||
{
|
||||
if (null != value)
|
||||
{
|
||||
string[] parts = value.Split(',');
|
||||
if (3 == parts.Length)
|
||||
{
|
||||
byte r, g, b;
|
||||
if (byte.TryParse(parts[0], out r) && byte.TryParse(parts[1], out g) && byte.TryParse(parts[2], out b))
|
||||
{
|
||||
R = r;
|
||||
G = g;
|
||||
B = b;
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public string Permissions
|
||||
{
|
||||
get
|
||||
{
|
||||
List<string> all = new List<string>(permissions);
|
||||
negatedpermissions.ForEach(p => all.Add("!" + p));
|
||||
return string.Join(",", all);
|
||||
}
|
||||
set
|
||||
{
|
||||
permissions.Clear();
|
||||
negatedpermissions.Clear();
|
||||
if (null != value)
|
||||
value.Split(',').ForEach(p => AddPermission(p.Trim()));
|
||||
}
|
||||
}
|
||||
|
||||
public List<string> TotalPermissions
|
||||
{
|
||||
get
|
||||
{
|
||||
var cur = this;
|
||||
var traversed = new List<Group>();
|
||||
HashSet<string> all = new HashSet<string>();
|
||||
while (cur != null)
|
||||
{
|
||||
foreach (var perm in cur.permissions)
|
||||
{
|
||||
all.Add(perm);
|
||||
}
|
||||
|
||||
foreach (var perm in cur.negatedpermissions)
|
||||
{
|
||||
all.Remove(perm);
|
||||
}
|
||||
|
||||
if (traversed.Contains(cur))
|
||||
{
|
||||
throw new Exception("Infinite group parenting ({0})".SFormat(cur.Name));
|
||||
}
|
||||
traversed.Add(cur);
|
||||
cur = cur.Parent;
|
||||
}
|
||||
return all.ToList();
|
||||
}
|
||||
}
|
||||
|
||||
public byte R = 255;
|
||||
public byte G = 255;
|
||||
public byte B = 255;
|
||||
|
||||
public Group(string groupname, Group parentgroup = null, string chatcolor = "255,255,255", string permissions = null)
|
||||
{
|
||||
Name = groupname;
|
||||
Parent = parentgroup;
|
||||
ChatColor = chatcolor;
|
||||
Permissions = permissions;
|
||||
}
|
||||
|
||||
public virtual bool HasPermission(string permission)
|
||||
{
|
||||
if (string.IsNullOrEmpty(permission))
|
||||
return true;
|
||||
|
||||
var cur = this;
|
||||
var traversed = new List<Group>();
|
||||
while (cur != null)
|
||||
{
|
||||
if (cur.negatedpermissions.Contains(permission))
|
||||
return false;
|
||||
if (cur.permissions.Contains(permission))
|
||||
return true;
|
||||
if (traversed.Contains(cur))
|
||||
{
|
||||
throw new Exception("Infinite group parenting ({0})".SFormat(cur.Name));
|
||||
}
|
||||
traversed.Add(cur);
|
||||
cur = cur.Parent;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public void NegatePermission(string permission)
|
||||
{
|
||||
// Avoid duplicates
|
||||
if (!negatedpermissions.Contains(permission))
|
||||
{
|
||||
negatedpermissions.Add(permission);
|
||||
permissions.Remove(permission); // Ensure we don't have conflicting definitions for a permissions
|
||||
}
|
||||
}
|
||||
|
||||
public void AddPermission(string permission)
|
||||
{
|
||||
if (permission.StartsWith("!"))
|
||||
{
|
||||
NegatePermission(permission.Substring(1));
|
||||
return;
|
||||
}
|
||||
// Avoid duplicates
|
||||
if (!permissions.Contains(permission))
|
||||
{
|
||||
permissions.Add(permission);
|
||||
negatedpermissions.Remove(permission); // Ensure we don't have conflicting definitions for a permissions
|
||||
}
|
||||
}
|
||||
|
||||
public void SetPermission(List<string> permission)
|
||||
{
|
||||
permissions.Clear();
|
||||
negatedpermissions.Clear();
|
||||
permission.ForEach(p => AddPermission(p));
|
||||
}
|
||||
|
||||
public void RemovePermission(string permission)
|
||||
{
|
||||
if (permission.StartsWith("!"))
|
||||
{
|
||||
negatedpermissions.Remove(permission.Substring(1));
|
||||
return;
|
||||
}
|
||||
permissions.Remove(permission);
|
||||
}
|
||||
}
|
||||
|
||||
public class SuperAdminGroup : Group
|
||||
{
|
||||
public SuperAdminGroup()
|
||||
: base("superadmin")
|
||||
{
|
||||
R = (byte) TShock.Config.SuperAdminChatRGB[0];
|
||||
G = (byte) TShock.Config.SuperAdminChatRGB[1];
|
||||
B = (byte) TShock.Config.SuperAdminChatRGB[2];
|
||||
Prefix = TShock.Config.SuperAdminChatPrefix;
|
||||
Suffix = TShock.Config.SuperAdminChatSuffix;
|
||||
}
|
||||
|
||||
public override bool HasPermission(string permission)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
/*
|
||||
/*
|
||||
TShock, a server mod for Terraria
|
||||
Copyright (C) 2011 The TShock Team
|
||||
|
||||
|
|
|
|||
|
|
@ -298,7 +298,7 @@ namespace TShockAPI
|
|||
if (ret is RestObject)
|
||||
return ret;
|
||||
|
||||
User user = (User)ret;
|
||||
User user = (User)ret;
|
||||
return new RestObject() { { "group", user.Group }, { "id", user.ID.ToString() }, { "name", user.Name } };
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
/*
|
||||
/*
|
||||
TShock, a server mod for Terraria
|
||||
Copyright (C) 2011 The TShock Team
|
||||
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
/*
|
||||
/*
|
||||
TShock, a server mod for Terraria
|
||||
Copyright (C) 2011 The TShock Team
|
||||
|
||||
|
|
|
|||
File diff suppressed because it is too large
Load diff
2934
TShockAPI/TShock.cs
2934
TShockAPI/TShock.cs
File diff suppressed because it is too large
Load diff
|
|
@ -1,102 +1,102 @@
|
|||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Net;
|
||||
using System.Threading;
|
||||
using Newtonsoft.Json;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
internal class UpdateManager
|
||||
{
|
||||
private static string updateUrl = "http://shankshock.com/tshock-update.json";
|
||||
public static DateTime lastcheck = DateTime.MinValue;
|
||||
|
||||
/// <summary>
|
||||
/// Check once every X minutes.
|
||||
/// </summary>
|
||||
private 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)
|
||||
{
|
||||
var updates = ServerIsOutOfDate();
|
||||
if (updates != null)
|
||||
{
|
||||
NotifyAdministrators(updates);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Checks to see if the server is out of date.
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
private static Dictionary<string, string> ServerIsOutOfDate()
|
||||
{
|
||||
using (var client = new WebClient())
|
||||
{
|
||||
client.Headers.Add("user-agent",
|
||||
"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; .NET CLR 1.0.3705;)");
|
||||
try
|
||||
{
|
||||
string updatejson = client.DownloadString(updateUrl);
|
||||
var update = JsonConvert.DeserializeObject<Dictionary<string, string>>(updatejson);
|
||||
var version = new Version(update["version"]);
|
||||
if (TShock.VersionNum.CompareTo(version) < 0)
|
||||
return update;
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Log.Error(e.ToString());
|
||||
}
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
private static void NotifyAdministrators(Dictionary<string, string> update)
|
||||
{
|
||||
var changes = update["changes"].Split(new[] {'\n'}, StringSplitOptions.RemoveEmptyEntries);
|
||||
NotifyAdministrator(TSPlayer.Server, changes);
|
||||
foreach (TSPlayer player in TShock.Players)
|
||||
{
|
||||
if (player != null && player.Active && player.Group.HasPermission(Permissions.maintenance))
|
||||
{
|
||||
NotifyAdministrator(player, changes);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private static void NotifyAdministrator(TSPlayer player, string[] changes)
|
||||
{
|
||||
player.SendMessage("The server is out of date.", Color.Red);
|
||||
for (int j = 0; j < changes.Length; j++)
|
||||
{
|
||||
player.SendMessage(changes[j], Color.Red);
|
||||
}
|
||||
}
|
||||
}
|
||||
/*
|
||||
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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Net;
|
||||
using System.Threading;
|
||||
using Newtonsoft.Json;
|
||||
|
||||
namespace TShockAPI
|
||||
{
|
||||
internal class UpdateManager
|
||||
{
|
||||
private static string updateUrl = "http://shankshock.com/tshock-update.json";
|
||||
public static DateTime lastcheck = DateTime.MinValue;
|
||||
|
||||
/// <summary>
|
||||
/// Check once every X minutes.
|
||||
/// </summary>
|
||||
private 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)
|
||||
{
|
||||
var updates = ServerIsOutOfDate();
|
||||
if (updates != null)
|
||||
{
|
||||
NotifyAdministrators(updates);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Checks to see if the server is out of date.
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
private static Dictionary<string, string> ServerIsOutOfDate()
|
||||
{
|
||||
using (var client = new WebClient())
|
||||
{
|
||||
client.Headers.Add("user-agent",
|
||||
"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; .NET CLR 1.0.3705;)");
|
||||
try
|
||||
{
|
||||
string updatejson = client.DownloadString(updateUrl);
|
||||
var update = JsonConvert.DeserializeObject<Dictionary<string, string>>(updatejson);
|
||||
var version = new Version(update["version"]);
|
||||
if (TShock.VersionNum.CompareTo(version) < 0)
|
||||
return update;
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Log.Error(e.ToString());
|
||||
}
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
private static void NotifyAdministrators(Dictionary<string, string> update)
|
||||
{
|
||||
var changes = update["changes"].Split(new[] {'\n'}, StringSplitOptions.RemoveEmptyEntries);
|
||||
NotifyAdministrator(TSPlayer.Server, changes);
|
||||
foreach (TSPlayer player in TShock.Players)
|
||||
{
|
||||
if (player != null && player.Active && player.Group.HasPermission(Permissions.maintenance))
|
||||
{
|
||||
NotifyAdministrator(player, changes);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private static void NotifyAdministrator(TSPlayer player, string[] changes)
|
||||
{
|
||||
player.SendMessage("The server is out of date.", Color.Red);
|
||||
for (int j = 0; j < changes.Length; j++)
|
||||
{
|
||||
player.SendMessage(changes[j], Color.Red);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
1564
TShockAPI/Utils.cs
1564
TShockAPI/Utils.cs
File diff suppressed because it is too large
Load diff
Loading…
Add table
Add a link
Reference in a new issue