Sonarr/NzbDrone.Common/EnvironmentInfo/AppFolderInfo.cs

64 lines
1.9 KiB
C#
Raw Normal View History

using System;
using System.IO;
using System.Reflection;
using System.Security.AccessControl;
using NLog;
namespace NzbDrone.Common.EnvironmentInfo
{
public interface IAppFolderInfo
{
string AppDataFolder { get; }
string TempFolder { get; }
string StartUpFolder { get; }
}
public class AppFolderInfo : IAppFolderInfo
{
private readonly IDiskProvider _diskProvider;
2013-07-09 00:47:28 +00:00
private readonly Logger _logger;
2013-06-19 21:08:56 +00:00
private readonly Environment.SpecialFolder DATA_SPECIAL_FOLDER = Environment.SpecialFolder.CommonApplicationData;
2013-07-27 04:53:05 +00:00
public AppFolderInfo(IDiskProvider diskProvider)
{
_diskProvider = diskProvider;
2013-06-19 21:08:56 +00:00
2013-07-27 04:53:05 +00:00
if (OsInfo.IsLinux)
{
DATA_SPECIAL_FOLDER = Environment.SpecialFolder.ApplicationData;
}
2013-06-19 21:08:56 +00:00
2013-07-27 04:53:05 +00:00
_logger = LogManager.GetCurrentClassLogger();
2013-07-27 04:53:05 +00:00
AppDataFolder = Path.Combine(Environment.GetFolderPath(DATA_SPECIAL_FOLDER, Environment.SpecialFolderOption.Create), "NzbDrone");
StartUpFolder = new FileInfo(Assembly.GetExecutingAssembly().Location).Directory.FullName;
TempFolder = Path.GetTempPath();
2013-07-27 04:53:05 +00:00
diskProvider.EnsureFolder(AppDataFolder);
2013-07-26 06:55:15 +00:00
if (!OsInfo.IsLinux)
{
SetPermissions();
}
}
private void SetPermissions()
{
try
{
_diskProvider.SetPermissions(AppDataFolder, "Everyone", FileSystemRights.FullControl, AccessControlType.Allow);
}
catch (Exception ex)
{
2013-07-09 00:47:28 +00:00
_logger.WarnException("Coudn't set app folder permission", ex);
}
}
public string AppDataFolder { get; private set; }
public string StartUpFolder { get; private set; }
public String TempFolder { get; private set; }
}
}