2010-10-15 09:10:44 +02:00
|
|
|
|
using System;
|
|
|
|
|
using System.IO;
|
2011-10-01 05:12:18 +02:00
|
|
|
|
using System.Linq;
|
2010-10-15 09:10:44 +02:00
|
|
|
|
using System.Reflection;
|
2011-10-01 05:12:18 +02:00
|
|
|
|
using System.Xml.Linq;
|
2011-10-07 08:36:04 +02:00
|
|
|
|
using System.Xml.XPath;
|
2010-10-15 09:10:44 +02:00
|
|
|
|
using NLog;
|
|
|
|
|
using NLog.Config;
|
|
|
|
|
|
2011-10-07 03:30:44 +02:00
|
|
|
|
namespace NzbDrone.Providers
|
2010-10-15 09:10:44 +02:00
|
|
|
|
{
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public class ConfigProvider
|
2010-10-15 09:10:44 +02:00
|
|
|
|
{
|
2011-10-07 08:43:35 +02:00
|
|
|
|
private static readonly Logger Logger = LogManager.GetLogger("Host.ConfigProvider");
|
2011-04-10 04:44:01 +02:00
|
|
|
|
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public virtual string ApplicationRoot
|
2010-10-15 09:10:44 +02:00
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
2011-10-07 03:30:44 +02:00
|
|
|
|
var appDir = new FileInfo(Assembly.GetExecutingAssembly().Location).Directory;
|
2010-10-15 09:10:44 +02:00
|
|
|
|
|
2011-10-07 03:30:44 +02:00
|
|
|
|
while (appDir.GetDirectories("iisexpress").Length == 0)
|
|
|
|
|
{
|
|
|
|
|
if (appDir.Parent == null) throw new ApplicationException("Can't fine IISExpress folder.");
|
|
|
|
|
appDir = appDir.Parent;
|
2010-10-15 09:10:44 +02:00
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 03:30:44 +02:00
|
|
|
|
return appDir.FullName;
|
2010-10-15 09:10:44 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public virtual int Port
|
2010-10-15 09:10:44 +02:00
|
|
|
|
{
|
2011-10-01 05:12:18 +02:00
|
|
|
|
get { return GetValueInt("Port"); }
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public virtual bool LaunchBrowser
|
2011-10-01 05:12:18 +02:00
|
|
|
|
{
|
|
|
|
|
get { return GetValueBoolean("LaunchBrowser"); }
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public virtual string AppDataDirectory
|
2011-10-01 05:12:18 +02:00
|
|
|
|
{
|
2011-10-07 03:30:44 +02:00
|
|
|
|
get { return Path.Combine(ApplicationRoot, "NzbDrone.Web", "App_Data"); }
|
2011-10-01 05:12:18 +02:00
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public virtual string ConfigFile
|
2011-10-01 05:12:18 +02:00
|
|
|
|
{
|
|
|
|
|
get { return Path.Combine(AppDataDirectory, "Config.xml"); }
|
2010-10-15 09:10:44 +02:00
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public virtual string IISFolder
|
2011-10-07 03:30:44 +02:00
|
|
|
|
{
|
|
|
|
|
get { return Path.Combine(ApplicationRoot, @"IISExpress\"); }
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public virtual string IISExePath
|
|
|
|
|
{
|
|
|
|
|
get { return IISFolder + @"iisexpress.exe"; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public virtual string IISConfigPath
|
|
|
|
|
{
|
|
|
|
|
get { return Path.Combine(IISFolder, "AppServer", "applicationhost.config"); }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public virtual void ConfigureNlog()
|
2011-04-10 04:44:01 +02:00
|
|
|
|
{
|
|
|
|
|
LogManager.Configuration = new XmlLoggingConfiguration(
|
2011-10-07 03:30:44 +02:00
|
|
|
|
Path.Combine(ApplicationRoot, "NzbDrone.Web\\log.config"), false);
|
2011-10-01 05:12:18 +02:00
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public virtual void UpdateIISConfig(string configPath)
|
|
|
|
|
{
|
|
|
|
|
Logger.Info(@"Server configuration file: {0}", configPath);
|
|
|
|
|
Logger.Info(@"Configuring server to: [http://localhost:{0}]", Port);
|
|
|
|
|
|
|
|
|
|
var configXml = XDocument.Load(configPath);
|
|
|
|
|
|
|
|
|
|
var bindings =
|
|
|
|
|
configXml.XPathSelectElement("configuration/system.applicationHost/sites").Elements("site").Where(
|
|
|
|
|
d => d.Attribute("name").Value.ToLowerInvariant() == "nzbdrone").First().Element("bindings");
|
|
|
|
|
bindings.Descendants().Remove();
|
|
|
|
|
bindings.Add(
|
|
|
|
|
new XElement("binding",
|
|
|
|
|
new XAttribute("protocol", "http"),
|
|
|
|
|
new XAttribute("bindingInformation", String.Format("*:{0}:localhost", Port))
|
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
bindings.Add(
|
2011-10-07 08:57:43 +02:00
|
|
|
|
new XElement("binding",
|
|
|
|
|
new XAttribute("protocol", "http"),
|
|
|
|
|
new XAttribute("bindingInformation", String.Format("*:{0}:", Port))
|
|
|
|
|
));
|
2011-10-07 08:36:04 +02:00
|
|
|
|
|
|
|
|
|
configXml.Save(configPath);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public virtual void CreateDefaultConfigFile()
|
2011-10-01 05:12:18 +02:00
|
|
|
|
{
|
|
|
|
|
//Create the config file here
|
|
|
|
|
Directory.CreateDirectory(AppDataDirectory);
|
|
|
|
|
|
|
|
|
|
if (!File.Exists(ConfigFile))
|
|
|
|
|
{
|
|
|
|
|
WriteDefaultConfig();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 08:36:04 +02:00
|
|
|
|
public virtual void WriteDefaultConfig()
|
2011-10-01 05:12:18 +02:00
|
|
|
|
{
|
|
|
|
|
var xDoc = new XDocument(new XDeclaration("1.0", "utf-8", "yes"));
|
|
|
|
|
|
|
|
|
|
xDoc.Add(new XElement("Config",
|
2011-10-07 08:57:43 +02:00
|
|
|
|
new XElement("Port", 8989),
|
|
|
|
|
new XElement("LaunchBrowser", true)
|
|
|
|
|
)
|
|
|
|
|
);
|
2011-10-01 05:12:18 +02:00
|
|
|
|
|
|
|
|
|
xDoc.Save(ConfigFile);
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 03:30:44 +02:00
|
|
|
|
private string GetValue(string key, string parent = null)
|
2011-10-01 05:12:18 +02:00
|
|
|
|
{
|
|
|
|
|
var xDoc = XDocument.Load(ConfigFile);
|
|
|
|
|
var config = xDoc.Descendants("Config").Single();
|
|
|
|
|
|
|
|
|
|
var parentContainer = config;
|
|
|
|
|
|
|
|
|
|
if (parent != null)
|
|
|
|
|
parentContainer = config.Descendants(parent).Single();
|
|
|
|
|
|
2011-10-07 08:57:43 +02:00
|
|
|
|
string value = parentContainer.Descendants(key).Single().Value;
|
2011-10-01 05:12:18 +02:00
|
|
|
|
|
|
|
|
|
return value;
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 03:30:44 +02:00
|
|
|
|
private int GetValueInt(string key, string parent = null)
|
2011-10-01 05:12:18 +02:00
|
|
|
|
{
|
|
|
|
|
return Convert.ToInt32(GetValue(key, parent));
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-07 03:30:44 +02:00
|
|
|
|
private bool GetValueBoolean(string key, string parent = null)
|
2011-10-01 05:12:18 +02:00
|
|
|
|
{
|
|
|
|
|
return Convert.ToBoolean(GetValue(key, parent));
|
2011-04-10 04:44:01 +02:00
|
|
|
|
}
|
2010-10-15 09:10:44 +02:00
|
|
|
|
}
|
2011-04-10 04:44:01 +02:00
|
|
|
|
}
|