|
|
@ -5,29 +5,39 @@ using System.Linq;
|
|
|
|
using System.Reflection;
|
|
|
|
using System.Reflection;
|
|
|
|
using System.Text;
|
|
|
|
using System.Text;
|
|
|
|
using System.Xml.Linq;
|
|
|
|
using System.Xml.Linq;
|
|
|
|
|
|
|
|
using NzbDrone.Core.Model;
|
|
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Providers.Core
|
|
|
|
namespace NzbDrone.Core.Providers.Core
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public class ConfigFileProvider
|
|
|
|
public class ConfigFileProvider
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
private string _configFile = Path.Combine(CentralDispatch.AppPath, "App_Data", "Config.xml");
|
|
|
|
|
|
|
|
|
|
|
|
public string ConfigFile
|
|
|
|
public string ConfigFile
|
|
|
|
{
|
|
|
|
{
|
|
|
|
get { return Path.Combine(CentralDispatch.AppPath, "App_Data", "Config.xml"); }
|
|
|
|
get { return _configFile; }
|
|
|
|
|
|
|
|
set { _configFile = value; }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public virtual int Port
|
|
|
|
public virtual int Port
|
|
|
|
{
|
|
|
|
{
|
|
|
|
get { return GetValueInt("Port"); }
|
|
|
|
get { return GetValueInt("Port", 8989); }
|
|
|
|
set { SetValue("Port", value); }
|
|
|
|
set { SetValue("Port", value); }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public virtual bool LaunchBrowser
|
|
|
|
public virtual bool LaunchBrowser
|
|
|
|
{
|
|
|
|
{
|
|
|
|
get { return GetValueBoolean("LaunchBrowser"); }
|
|
|
|
get { return GetValueBoolean("LaunchBrowser", true); }
|
|
|
|
set { SetValue("LaunchBrowser", value); }
|
|
|
|
set { SetValue("LaunchBrowser", value); }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public virtual string GetValue(string key, string parent = null)
|
|
|
|
public virtual AuthenticationType AuthenticationType
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
get { return (AuthenticationType)GetValueInt("AuthenticationType", 0); }
|
|
|
|
|
|
|
|
set { SetValue("AuthenticationType", (int)value); }
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public virtual string GetValue(string key, object defaultValue, string parent = null)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var xDoc = XDocument.Load(ConfigFile);
|
|
|
|
var xDoc = XDocument.Load(ConfigFile);
|
|
|
|
var config = xDoc.Descendants("Config").Single();
|
|
|
|
var config = xDoc.Descendants("Config").Single();
|
|
|
@ -35,21 +45,40 @@ namespace NzbDrone.Core.Providers.Core
|
|
|
|
var parentContainer = config;
|
|
|
|
var parentContainer = config;
|
|
|
|
|
|
|
|
|
|
|
|
if (!String.IsNullOrEmpty(parent))
|
|
|
|
if (!String.IsNullOrEmpty(parent))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//Add the parent
|
|
|
|
|
|
|
|
if (config.Descendants(parent).Count() != 1)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
SetValue(key, defaultValue, parent);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//Reload the configFile
|
|
|
|
|
|
|
|
xDoc = XDocument.Load(ConfigFile);
|
|
|
|
|
|
|
|
config = xDoc.Descendants("Config").Single();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
parentContainer = config.Descendants(parent).Single();
|
|
|
|
parentContainer = config.Descendants(parent).Single();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var value = parentContainer.Descendants(key).Single().Value;
|
|
|
|
var valueHolder = parentContainer.Descendants(key).ToList();
|
|
|
|
|
|
|
|
|
|
|
|
return value;
|
|
|
|
if (valueHolder.Count() == 1)
|
|
|
|
|
|
|
|
return valueHolder.First().Value;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//Save the value
|
|
|
|
|
|
|
|
SetValue(key, defaultValue, parent);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//return the default value
|
|
|
|
|
|
|
|
return defaultValue.ToString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public virtual int GetValueInt(string key, string parent = null)
|
|
|
|
public virtual int GetValueInt(string key, int defaultValue, string parent = null)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return Convert.ToInt32(GetValue(key, parent));
|
|
|
|
return Convert.ToInt32(GetValue(key, defaultValue, parent));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public virtual bool GetValueBoolean(string key, string parent = null)
|
|
|
|
public virtual bool GetValueBoolean(string key, bool defaultValue, string parent = null)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return Convert.ToBoolean(GetValue(key, parent));
|
|
|
|
return Convert.ToBoolean(GetValue(key, defaultValue, parent));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public virtual void SetValue(string key, object value, string parent = null)
|
|
|
|
public virtual void SetValue(string key, object value, string parent = null)
|
|
|
@ -60,8 +89,22 @@ namespace NzbDrone.Core.Providers.Core
|
|
|
|
var parentContainer = config;
|
|
|
|
var parentContainer = config;
|
|
|
|
|
|
|
|
|
|
|
|
if (!String.IsNullOrEmpty(parent))
|
|
|
|
if (!String.IsNullOrEmpty(parent))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//Add the parent container if it doesn't already exist
|
|
|
|
|
|
|
|
if (config.Descendants(parent).Count() != 1)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
config.Add(new XElement(parent));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
parentContainer = config.Descendants(parent).Single();
|
|
|
|
parentContainer = config.Descendants(parent).Single();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var keyHolder = parentContainer.Descendants(key);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (keyHolder.Count() != 1)
|
|
|
|
|
|
|
|
parentContainer.Add(new XElement(key, value));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
parentContainer.Descendants(key).Single().Value = value.ToString();
|
|
|
|
parentContainer.Descendants(key).Single().Value = value.ToString();
|
|
|
|
|
|
|
|
|
|
|
|
xDoc.Save(ConfigFile);
|
|
|
|
xDoc.Save(ConfigFile);
|
|
|
@ -82,11 +125,7 @@ namespace NzbDrone.Core.Providers.Core
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var xDoc = new XDocument(new XDeclaration("1.0", "utf-8", "yes"));
|
|
|
|
var xDoc = new XDocument(new XDeclaration("1.0", "utf-8", "yes"));
|
|
|
|
|
|
|
|
|
|
|
|
xDoc.Add(new XElement("Config",
|
|
|
|
xDoc.Add(new XElement("Config"));
|
|
|
|
new XElement("Port", 8989),
|
|
|
|
|
|
|
|
new XElement("LaunchBrowser", true)
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
xDoc.Save(ConfigFile);
|
|
|
|
xDoc.Save(ConfigFile);
|
|
|
|
}
|
|
|
|
}
|
|
|
|