2011-10-06 23:36:04 -07:00
|
|
|
using System.Collections.Generic;
|
2011-10-06 20:37:41 -07:00
|
|
|
using System.Diagnostics;
|
|
|
|
using System.Linq;
|
|
|
|
using NLog;
|
2011-10-22 22:26:43 -07:00
|
|
|
using NzbDrone.Common.Model;
|
2011-10-06 20:37:41 -07:00
|
|
|
|
2011-10-22 22:26:43 -07:00
|
|
|
namespace NzbDrone.Common
|
2011-10-06 20:37:41 -07:00
|
|
|
{
|
|
|
|
public class ProcessProvider
|
|
|
|
{
|
2011-10-06 23:43:35 -07:00
|
|
|
private static readonly Logger Logger = LogManager.GetLogger("Host.ProcessProvider");
|
2011-10-06 20:37:41 -07:00
|
|
|
|
2011-10-23 11:31:17 -07:00
|
|
|
public static readonly string NzbDroneProccessName = "NzbDrone";
|
2011-10-06 20:37:41 -07:00
|
|
|
|
2011-10-06 23:36:04 -07:00
|
|
|
public virtual ProcessInfo GetCurrentProcess()
|
2011-10-06 20:37:41 -07:00
|
|
|
{
|
2011-10-06 23:36:04 -07:00
|
|
|
return ConvertToProcessInfo(Process.GetCurrentProcess());
|
|
|
|
}
|
2011-10-06 20:37:41 -07:00
|
|
|
|
2011-10-06 23:36:04 -07:00
|
|
|
public virtual ProcessInfo GetProcessById(int id)
|
|
|
|
{
|
|
|
|
return ConvertToProcessInfo(Process.GetProcesses().Where(p => p.Id == id).FirstOrDefault());
|
|
|
|
}
|
2011-10-06 20:37:41 -07:00
|
|
|
|
2011-10-06 23:36:04 -07:00
|
|
|
public virtual IEnumerable<ProcessInfo> GetProcessByName(string name)
|
|
|
|
{
|
|
|
|
return Process.GetProcessesByName(name).Select(ConvertToProcessInfo);
|
2011-10-06 20:37:41 -07:00
|
|
|
}
|
|
|
|
|
2011-10-06 23:36:04 -07:00
|
|
|
public virtual void Start(string path)
|
2011-10-06 20:37:41 -07:00
|
|
|
{
|
2011-10-06 23:36:04 -07:00
|
|
|
Process.Start(path);
|
2011-10-06 20:37:41 -07:00
|
|
|
}
|
|
|
|
|
2011-10-06 23:36:04 -07:00
|
|
|
public virtual Process Start(ProcessStartInfo startInfo)
|
2011-10-06 20:37:41 -07:00
|
|
|
{
|
2011-10-06 23:36:04 -07:00
|
|
|
Logger.Info("Starting process. [{0}]", startInfo.FileName);
|
|
|
|
|
|
|
|
var process = new Process
|
|
|
|
{
|
|
|
|
StartInfo = startInfo
|
|
|
|
};
|
|
|
|
process.Start();
|
|
|
|
return process;
|
2011-10-06 20:37:41 -07:00
|
|
|
}
|
|
|
|
|
2011-10-06 23:36:04 -07:00
|
|
|
public virtual void Kill(int processId)
|
2011-10-06 20:37:41 -07:00
|
|
|
{
|
2011-11-20 17:13:58 -08:00
|
|
|
if (processId == 0 || !Process.GetProcesses().Any(p => p.Id == processId))
|
|
|
|
{
|
|
|
|
Logger.Warn("Cannot find process with id: {0}", processId);
|
|
|
|
return;
|
|
|
|
}
|
2011-10-06 23:36:04 -07:00
|
|
|
|
|
|
|
var process = Process.GetProcessById(processId);
|
|
|
|
|
|
|
|
if (!process.HasExited)
|
|
|
|
{
|
2011-11-20 17:13:58 -08:00
|
|
|
Logger.Info("[{0}]: Killing process", process.Id);
|
2011-10-06 23:36:04 -07:00
|
|
|
process.Kill();
|
2011-11-20 17:13:58 -08:00
|
|
|
Logger.Info("[{0}]: Waiting for exit", process.Id);
|
2011-10-06 23:36:04 -07:00
|
|
|
process.WaitForExit();
|
2011-11-20 17:13:58 -08:00
|
|
|
Logger.Info("[{0}]: Process terminated successfully", process.Id);
|
2011-10-06 23:36:04 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public virtual void SetPriority(int processId, ProcessPriorityClass priority)
|
|
|
|
{
|
|
|
|
var process = Process.GetProcessById(processId);
|
|
|
|
|
|
|
|
Logger.Info("Updating [{0}] process priority from {1} to {2}",
|
|
|
|
process.ProcessName,
|
|
|
|
process.PriorityClass,
|
|
|
|
priority);
|
|
|
|
|
|
|
|
process.PriorityClass = priority;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static ProcessInfo ConvertToProcessInfo(Process process)
|
|
|
|
{
|
2011-10-07 22:06:16 -07:00
|
|
|
if (process == null || process.Id <= 0) return null;
|
2011-10-06 23:36:04 -07:00
|
|
|
|
|
|
|
return new ProcessInfo
|
2011-10-06 23:57:43 -07:00
|
|
|
{
|
|
|
|
Id = process.Id,
|
|
|
|
Priority = process.PriorityClass,
|
|
|
|
StartPath = process.MainModule.FileName
|
|
|
|
};
|
2011-10-06 20:37:41 -07:00
|
|
|
}
|
2011-11-20 17:13:58 -08:00
|
|
|
|
2011-10-06 20:37:41 -07:00
|
|
|
}
|
2011-10-06 23:57:43 -07:00
|
|
|
}
|