IW4M-Admin/Admin/Main.cs

127 lines
3.9 KiB
C#
Raw Normal View History


#define USINGMEMORY
2015-05-09 12:46:25 -04:00
using System;
2015-08-17 16:38:42 -04:00
using System.Runtime.InteropServices;
using SharedLibrary;
using System.Threading.Tasks;
using System.IO;
2015-03-08 17:20:10 -04:00
namespace IW4MAdmin
{
class Program
{
2015-08-20 17:54:38 -04:00
static public double Version { get; private set; }
static private ApplicationManager ServerManager;
2015-03-08 17:20:10 -04:00
static void Main(string[] args)
{
Version = 1.3;
2015-08-17 16:38:42 -04:00
handler = new ConsoleEventDelegate(OnProcessExit);
SetConsoleCtrlHandler(handler, true);
double.TryParse(CheckUpdate(), out double latestVersion);
Console.WriteLine("=====================================================");
Console.WriteLine(" IW4M ADMIN");
Console.WriteLine(" by RaidMax ");
if (latestVersion != 0)
Console.WriteLine(" Version " + Version + " (latest " + latestVersion + ")");
else
Console.WriteLine(" Version " + Version + " (unable to retrieve latest)");
Console.WriteLine("=====================================================");
try
{
CheckDirectories();
ServerManager = ApplicationManager.GetInstance();
ServerManager.Init();
Task.Run(() =>
{
String userInput;
Player Origin = new Player("IW4MAdmin", "", -1, Player.Permission.Console, -1, "", 0, "");
do
{
userInput = Console.ReadLine();
if (userInput.ToLower() == "quit")
ServerManager.Stop();
if (ServerManager.Servers.Count == 0)
return;
Event E = new Event(Event.GType.Say, userInput, Origin, null, ServerManager.Servers[0]);
Origin.lastEvent = E;
ServerManager.Servers[0].ExecuteEvent(E);
Console.Write('>');
} while (ServerManager.Running);
});
}
catch(Exception e)
{
Console.WriteLine($"Fatal Error during initialization: {e.Message}");
Console.WriteLine("Press any key to exit...");
Console.ReadKey();
return;
}
ServerManager.Start();
}
2015-08-17 16:38:42 -04:00
static ConsoleEventDelegate handler;
static private bool OnProcessExit(int e)
{
try
{
ServerManager.Stop();
return true;
2015-08-17 16:38:42 -04:00
}
catch
{
return true;
}
}
private delegate bool ConsoleEventDelegate(int eventType);
[DllImport("kernel32.dll", SetLastError = true)]
private static extern bool SetConsoleCtrlHandler(ConsoleEventDelegate callback, bool add);
static private String CheckUpdate()
{
//Connection Ver = new Connection("http://raidmax.org/IW4M/Admin/version.php");
//return Ver.Read();
return "0";
}
static void CheckDirectories()
{
if (!Directory.Exists("Lib"))
throw new Exception("Lib folder does not exist");
if (!Directory.Exists("Config"))
{
Console.WriteLine("Warning: Config folder does not exist");
Directory.CreateDirectory("Config");
}
if (!Directory.Exists("Config/Servers"))
Directory.CreateDirectory("Config/Servers");
if (!Directory.Exists("Logs"))
Directory.CreateDirectory("Logs");
if (!Directory.Exists("Database"))
Directory.CreateDirectory("Database");
2017-05-27 19:29:20 -04:00
if (!Directory.Exists("Plugins"))
Directory.CreateDirectory("Plugins");
2015-08-17 16:38:42 -04:00
}
2015-03-08 17:20:10 -04:00
}
}