IW4M-Admin/Admin/Main.cs

147 lines
4.8 KiB
C#
Raw Normal View History

2015-05-09 12:46:25 -04:00
#define USINGMEMORY
using System;
2015-03-08 17:20:10 -04:00
using System.Collections.Generic;
using System.Text;
using System.Threading;
2015-08-17 16:38:42 -04:00
using System.Runtime.InteropServices;
using SharedLibrary;
2015-03-08 17:20:10 -04:00
namespace IW4MAdmin
{
class Program
{
2015-08-17 16:38:42 -04:00
static public double Version = 0.92;
static public double latestVersion;
2015-05-09 12:46:25 -04:00
static public bool usingMemory = true;
static private Manager serverManager;
static private IW4MAdmin_Web.WebFront frontEnd;
2015-03-08 17:20:10 -04:00
static void Main(string[] args)
{
2015-08-17 16:38:42 -04:00
handler = new ConsoleEventDelegate(OnProcessExit);
SetConsoleCtrlHandler(handler, true);
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("=====================================================");
serverManager = new IW4MAdmin.Manager();
Thread serverMGRThread = new Thread(serverManager.Init);
serverMGRThread.Name = "Server Manager thread";
serverMGRThread.Start();
while(!serverManager.isReady())
{
Utilities.Wait(1);
}
if (serverManager.getServers() != null)
2015-08-17 16:38:42 -04:00
Program.getManager().mainLog.Write("IW4M Now Initialized! Visit http://127.0.0.1:1624 for server overview.");
2015-07-17 18:53:51 -04:00
if (serverManager.getServers().Count > 0)
{
frontEnd = new IW4MAdmin_Web.WebFront();
2015-07-17 18:53:51 -04:00
frontEnd.Init();
}
serverMGRThread.Join();
serverManager.mainLog.Write("Shutting down IW4MAdmin...", Log.Level.Debug);
}
2015-08-17 16:38:42 -04:00
static ConsoleEventDelegate handler;
static private bool OnProcessExit(int e)
{
try
{
foreach (Server S in IW4MAdmin.Program.getServers())
{
if (S == null)
continue;
S.isRunning = false;
if (Utilities.shutdownInterface(S.pID()))
2015-08-17 16:38:42 -04:00
Program.getManager().mainLog.Write("Successfully removed IW4MAdmin from server with PID " + S.pID(), Log.Level.Debug);
else
Program.getManager().mainLog.Write("Could not remove IW4MAdmin from server with PID " + S.pID(), Log.Level.Debug);
}
Program.getManager().shutDown();
frontEnd.webSchedule.Stop();
frontEnd.webSchedule.Dispose();
2015-08-17 16:38:42 -04:00
}
catch
{
return true;
}
return false;
}
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();
}
static public Server[] getServers()
{
return serverManager.getServers().ToArray();
}
2015-08-17 16:38:42 -04:00
static public Manager getManager()
{
return serverManager;
}
2015-07-24 15:46:32 -04:00
#if DEBUG2
static List<Server> checkConfig()
{
file Config = new file("config\\servers.cfg");
String[] SV_CONF = Config.readAll();
List<Server> Servers = new List<Server>();
Config.Close();
if (SV_CONF == null || SV_CONF.Length < 1 || SV_CONF[0] == String.Empty)
{
setupConfig(); // get our first time server
Config = new file("config\\servers.cfg", true);
Config.Write(IP + ':' + Port + ':' + RCON);
Config.Close();
2015-05-09 12:46:25 -04:00
Servers.Add(new Server(IP, Port, RCON, 0));
}
else
{
foreach (String L in SV_CONF)
{
String[] server_line = L.Split(':');
int newPort;
if (server_line.Length < 3 || !int.TryParse(server_line[1], out newPort))
{
Console.WriteLine("You have an error in your server.cfg");
continue;
}
2015-05-09 12:46:25 -04:00
Servers.Add(new Server(server_line[0], newPort, server_line[2],0));
}
}
return Servers;
}
#endif
2015-03-08 17:20:10 -04:00
}
}