mirror of
https://github.com/RaidMax/IW4M-Admin.git
synced 2025-06-10 15:20:48 -05:00
Branch for IW4X practically everything refactored
This commit is contained in:
119
Admin/Main.cs
119
Admin/Main.cs
@ -1,65 +1,75 @@
|
||||
#define USINGMEMORY
|
||||
|
||||
#define USINGMEMORY
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Text;
|
||||
using System.Threading;
|
||||
using System.Runtime.InteropServices;
|
||||
using SharedLibrary;
|
||||
using System.Threading.Tasks;
|
||||
using System.IO;
|
||||
|
||||
namespace IW4MAdmin
|
||||
{
|
||||
class Program
|
||||
{
|
||||
static public double Version { get; private set; }
|
||||
static private Manager serverManager;
|
||||
static private Manager ServerManager;
|
||||
|
||||
static void Main(string[] args)
|
||||
{
|
||||
Version = 1.1;
|
||||
Version = 1.3;
|
||||
double latestVersion = 0;
|
||||
handler = new ConsoleEventDelegate(OnProcessExit);
|
||||
SetConsoleCtrlHandler(handler, true);
|
||||
|
||||
double.TryParse(checkUpdate(), out latestVersion);
|
||||
double.TryParse(CheckUpdate(), out 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(" Version " + Version + " (unable to retrieve latest)");
|
||||
Console.WriteLine("=====================================================");
|
||||
|
||||
serverManager = new Manager();
|
||||
|
||||
Thread serverMGRThread = new Thread(serverManager.Init);
|
||||
serverMGRThread.Name = "Server Manager thread";
|
||||
serverMGRThread.Start();
|
||||
|
||||
while(!serverManager.isReady())
|
||||
try
|
||||
{
|
||||
SharedLibrary.Utilities.Wait(1);
|
||||
CheckDirectories();
|
||||
|
||||
ServerManager = Manager.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 (userInput != null && ServerManager.Running);
|
||||
});*/
|
||||
|
||||
}
|
||||
|
||||
if (serverManager.getServers() != null)
|
||||
getManager().mainLog.Write("IW4M Now Initialized!", Log.Level.Production);
|
||||
|
||||
String userInput;
|
||||
Server serverToExecuteOn = serverManager.getServers()[0];
|
||||
Player Origin = new Player("IW4MAdmin", "", -1, Player.Permission.Console, -1, "", 0, "");
|
||||
|
||||
do
|
||||
catch(Exception e)
|
||||
{
|
||||
userInput = Console.ReadLine();
|
||||
Event E = new Event(Event.GType.Say, userInput, Origin, null, serverToExecuteOn);
|
||||
Origin.lastEvent = E;
|
||||
serverToExecuteOn.processEvent(E);
|
||||
Console.Write('>');
|
||||
Console.WriteLine($"Fatal Error during initialization: {e.Message}");
|
||||
Console.WriteLine("Press any key to exit...");
|
||||
Console.ReadKey();
|
||||
return;
|
||||
}
|
||||
|
||||
} while (userInput != null && serverManager.isRunning());
|
||||
|
||||
serverMGRThread.Join();
|
||||
serverManager.mainLog.Write("Shutting down IW4MAdmin...", Log.Level.Debug);
|
||||
ServerManager.Start();
|
||||
}
|
||||
|
||||
static ConsoleEventDelegate handler;
|
||||
@ -68,22 +78,8 @@ namespace IW4MAdmin
|
||||
{
|
||||
try
|
||||
{
|
||||
foreach (Server S in getServers())
|
||||
{
|
||||
if (S == null)
|
||||
continue;
|
||||
|
||||
S.Broadcast("^5IW4MAdmin ^7is going ^1offline^7");
|
||||
S.isRunning = false;
|
||||
|
||||
if (Utilities.shutdownInterface(S.pID()))
|
||||
getManager().mainLog.Write("Successfully removed IW4MAdmin from server with PID " + S.pID(), Log.Level.Debug);
|
||||
else
|
||||
getManager().mainLog.Write("Could not remove IW4MAdmin from server with PID " + S.pID(), Log.Level.Debug);
|
||||
}
|
||||
|
||||
getManager().shutDown();
|
||||
return false;
|
||||
ServerManager.Stop();
|
||||
return true;
|
||||
}
|
||||
|
||||
catch
|
||||
@ -96,20 +92,31 @@ namespace IW4MAdmin
|
||||
[DllImport("kernel32.dll", SetLastError = true)]
|
||||
private static extern bool SetConsoleCtrlHandler(ConsoleEventDelegate callback, bool add);
|
||||
|
||||
static private String checkUpdate()
|
||||
static private String CheckUpdate()
|
||||
{
|
||||
Connection Ver = new Connection("http://raidmax.org/IW4M/Admin/version.php");
|
||||
return Ver.Read();
|
||||
}
|
||||
|
||||
static public Server[] getServers()
|
||||
static void CheckDirectories()
|
||||
{
|
||||
return serverManager.getServers().ToArray();
|
||||
}
|
||||
if (!Directory.Exists("Lib"))
|
||||
throw new Exception("Lib folder does not exist");
|
||||
|
||||
static public Manager getManager()
|
||||
{
|
||||
return serverManager;
|
||||
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");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user