2010-10-14 09:29:01 +03:00
|
|
|
using System;
|
|
|
|
using System.Diagnostics;
|
2011-07-28 01:59:48 +03:00
|
|
|
using System.Net;
|
2010-10-17 20:22:48 +03:00
|
|
|
using System.Threading;
|
2011-07-11 08:05:52 +03:00
|
|
|
using System.Timers;
|
2010-10-15 10:10:44 +03:00
|
|
|
using Exceptioneer.WindowsFormsClient;
|
2010-10-14 09:29:01 +03:00
|
|
|
using NLog;
|
2010-10-10 22:00:07 +03:00
|
|
|
namespace NzbDrone
|
2010-09-23 06:19:47 +03:00
|
|
|
{
|
2011-04-10 05:44:01 +03:00
|
|
|
internal static class Program
|
2010-09-23 06:19:47 +03:00
|
|
|
{
|
2010-10-14 09:29:01 +03:00
|
|
|
private static readonly Logger Logger = LogManager.GetLogger("Application");
|
|
|
|
|
2011-04-10 05:44:01 +03:00
|
|
|
private static void Main()
|
2010-10-14 09:29:01 +03:00
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
2011-07-04 08:03:05 +03:00
|
|
|
Config.ConfigureNlog();
|
2011-10-01 06:12:18 +03:00
|
|
|
Config.CreateDefaultConfigFile();
|
2011-07-04 08:03:05 +03:00
|
|
|
Logger.Info("Starting NZBDrone. Start-up Path:'{0}'", Config.ProjectRoot);
|
2010-10-17 20:22:48 +03:00
|
|
|
Thread.CurrentThread.Name = "Host";
|
|
|
|
|
2011-07-04 08:03:05 +03:00
|
|
|
Process currentProcess = Process.GetCurrentProcess();
|
2011-07-11 03:03:01 +03:00
|
|
|
|
2011-07-11 08:05:52 +03:00
|
|
|
var prioCheckTimer = new System.Timers.Timer(5000);
|
|
|
|
prioCheckTimer.Elapsed += prioCheckTimer_Elapsed;
|
|
|
|
prioCheckTimer.Enabled = true;
|
2011-07-04 08:03:05 +03:00
|
|
|
|
|
|
|
currentProcess.EnableRaisingEvents = true;
|
|
|
|
currentProcess.Exited += ProgramExited;
|
|
|
|
|
2010-10-14 09:29:01 +03:00
|
|
|
AppDomain.CurrentDomain.UnhandledException += ((s, e) => AppDomainException(e));
|
2010-10-15 10:10:44 +03:00
|
|
|
AppDomain.CurrentDomain.ProcessExit += ProgramExited;
|
|
|
|
AppDomain.CurrentDomain.DomainUnload += ProgramExited;
|
2010-10-14 09:29:01 +03:00
|
|
|
|
2011-04-22 09:46:26 +03:00
|
|
|
IISController.StopServer();
|
|
|
|
IISController.StartServer();
|
2010-10-14 09:29:01 +03:00
|
|
|
|
2010-10-15 10:10:44 +03:00
|
|
|
#if DEBUG
|
2011-04-22 20:09:06 +03:00
|
|
|
Attach();
|
|
|
|
#endif
|
2011-07-11 03:03:01 +03:00
|
|
|
|
2011-10-01 06:12:18 +03:00
|
|
|
if (!Environment.UserInteractive || !Config.LaunchBrowser)
|
2011-07-28 01:59:48 +03:00
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
new WebClient().DownloadString(IISController.AppUrl);
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
Logger.ErrorException("Failed to load home page.", e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
2011-05-16 10:32:01 +03:00
|
|
|
{
|
2011-06-22 06:38:46 +03:00
|
|
|
try
|
|
|
|
{
|
|
|
|
Logger.Info("Starting default browser. {0}", IISController.AppUrl);
|
|
|
|
Process.Start(IISController.AppUrl);
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
Logger.ErrorException("Failed to open URL in default browser.", e);
|
|
|
|
}
|
|
|
|
while (true)
|
|
|
|
{
|
|
|
|
Console.ReadLine();
|
|
|
|
}
|
2011-04-24 06:02:20 +03:00
|
|
|
}
|
2011-04-22 20:09:06 +03:00
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
AppDomainException(e);
|
|
|
|
}
|
2011-04-25 21:41:20 +03:00
|
|
|
|
|
|
|
Console.WriteLine("Press enter to exit.");
|
|
|
|
Console.ReadLine();
|
2011-04-22 20:09:06 +03:00
|
|
|
}
|
|
|
|
|
2011-07-17 23:01:37 +03:00
|
|
|
private static void prioCheckTimer_Elapsed(object sender, ElapsedEventArgs e)
|
2011-07-11 03:03:01 +03:00
|
|
|
{
|
|
|
|
Process currentProcess = Process.GetCurrentProcess();
|
2011-07-17 23:01:37 +03:00
|
|
|
if (currentProcess.PriorityClass != ProcessPriorityClass.Normal)
|
2011-07-11 03:03:01 +03:00
|
|
|
{
|
2011-07-17 23:01:37 +03:00
|
|
|
SetPriority(currentProcess);
|
2011-07-11 03:03:01 +03:00
|
|
|
}
|
|
|
|
|
2011-07-11 08:05:52 +03:00
|
|
|
|
2011-07-17 23:01:37 +03:00
|
|
|
if (IISController.IISProcess != null)
|
2011-07-11 03:03:01 +03:00
|
|
|
{
|
2011-07-17 23:01:37 +03:00
|
|
|
IISController.IISProcess.Refresh();
|
|
|
|
|
|
|
|
if (IISController.IISProcess.PriorityClass != ProcessPriorityClass.Normal && IISController.IISProcess.PriorityClass != ProcessPriorityClass.AboveNormal)
|
|
|
|
{
|
|
|
|
SetPriority(IISController.IISProcess);
|
|
|
|
}
|
2011-07-11 03:03:01 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-07-17 23:01:37 +03:00
|
|
|
private static void SetPriority(Process process)
|
|
|
|
{
|
|
|
|
Logger.Info("Updating [{0}] process priority from {1} to {2}",
|
|
|
|
process.ProcessName,
|
|
|
|
IISController.IISProcess.PriorityClass,
|
|
|
|
ProcessPriorityClass.Normal);
|
|
|
|
process.PriorityClass = ProcessPriorityClass.Normal;
|
|
|
|
}
|
|
|
|
|
2011-07-11 08:05:52 +03:00
|
|
|
|
|
|
|
|
2011-05-27 09:01:07 +03:00
|
|
|
#if DEBUG
|
2011-04-22 20:09:06 +03:00
|
|
|
private static void Attach()
|
|
|
|
{
|
|
|
|
if (Debugger.IsAttached)
|
|
|
|
{
|
|
|
|
Logger.Info("Trying to attach to debugger");
|
|
|
|
|
|
|
|
var count = 0;
|
|
|
|
|
|
|
|
while (true)
|
2010-10-17 20:22:48 +03:00
|
|
|
{
|
2010-10-24 10:46:58 +03:00
|
|
|
try
|
|
|
|
{
|
|
|
|
ProcessAttacher.Attach();
|
2011-04-22 20:09:06 +03:00
|
|
|
Logger.Info("Debugger Attached");
|
|
|
|
return;
|
2010-10-24 10:46:58 +03:00
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
2011-04-22 20:09:06 +03:00
|
|
|
count++;
|
|
|
|
if (count > 20)
|
|
|
|
{
|
|
|
|
Logger.WarnException("Unable to attach to debugger", e);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
Thread.Sleep(100);
|
|
|
|
|
2010-10-24 10:46:58 +03:00
|
|
|
}
|
2010-10-15 10:10:44 +03:00
|
|
|
}
|
2010-10-14 09:29:01 +03:00
|
|
|
}
|
|
|
|
}
|
2011-05-27 09:01:07 +03:00
|
|
|
#endif
|
2010-10-14 09:29:01 +03:00
|
|
|
|
|
|
|
private static void AppDomainException(object excepion)
|
|
|
|
{
|
|
|
|
Console.WriteLine("EPIC FAIL: {0}", excepion);
|
|
|
|
Logger.Fatal("EPIC FAIL: {0}", excepion);
|
|
|
|
|
2011-07-05 09:46:03 +03:00
|
|
|
#if RELEASE
|
2010-10-15 10:10:44 +03:00
|
|
|
new Client
|
2011-04-25 21:41:20 +03:00
|
|
|
{
|
|
|
|
ApiKey = "43BBF60A-EB2A-4C1C-B09E-422ADF637265",
|
|
|
|
ApplicationName = "NZBDrone",
|
|
|
|
CurrentException = excepion as Exception
|
|
|
|
}.Submit();
|
|
|
|
#endif
|
2010-09-23 06:19:47 +03:00
|
|
|
|
2011-04-22 09:46:26 +03:00
|
|
|
IISController.StopServer();
|
2010-10-14 09:29:01 +03:00
|
|
|
}
|
2010-09-23 06:19:47 +03:00
|
|
|
|
2011-04-10 05:44:01 +03:00
|
|
|
private static void ProgramExited(object sender, EventArgs e)
|
2010-10-14 09:29:01 +03:00
|
|
|
{
|
2011-04-22 09:46:26 +03:00
|
|
|
IISController.StopServer();
|
2010-10-14 09:29:01 +03:00
|
|
|
}
|
2010-09-23 06:19:47 +03:00
|
|
|
}
|
2011-04-10 05:44:01 +03:00
|
|
|
}
|