BaseApplicationPaths.cs 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. using System;
  2. using System.IO;
  3. using MediaBrowser.Common.Configuration;
  4. namespace Emby.Server.Implementations.AppBase
  5. {
  6. /// <summary>
  7. /// Provides a base class to hold common application paths used by both the UI and Server.
  8. /// This can be subclassed to add application-specific paths.
  9. /// </summary>
  10. public abstract class BaseApplicationPaths : IApplicationPaths
  11. {
  12. private string _dataPath;
  13. /// <summary>
  14. /// Initializes a new instance of the <see cref="BaseApplicationPaths"/> class.
  15. /// </summary>
  16. /// <param name="programDataPath">The program data path.</param>
  17. /// <param name="logDirectoryPath">The log directory path.</param>
  18. /// <param name="configurationDirectoryPath">The configuration directory path.</param>
  19. /// <param name="cacheDirectoryPath">The cache directory path.</param>
  20. /// <param name="webDirectoryPath">The web directory path.</param>
  21. protected BaseApplicationPaths(
  22. string programDataPath,
  23. string logDirectoryPath,
  24. string configurationDirectoryPath,
  25. string cacheDirectoryPath,
  26. string webDirectoryPath)
  27. {
  28. ProgramDataPath = programDataPath;
  29. LogDirectoryPath = logDirectoryPath;
  30. ConfigurationDirectoryPath = configurationDirectoryPath;
  31. CachePath = cacheDirectoryPath;
  32. WebPath = webDirectoryPath;
  33. DataPath = Path.Combine(ProgramDataPath, "data");
  34. }
  35. /// <summary>
  36. /// Gets the path to the program data folder.
  37. /// </summary>
  38. /// <value>The program data path.</value>
  39. public string ProgramDataPath { get; }
  40. /// <inheritdoc/>
  41. public string WebPath { get; }
  42. /// <summary>
  43. /// Gets the path to the system folder.
  44. /// </summary>
  45. /// <value>The path to the system folder.</value>
  46. public string ProgramSystemPath { get; } = AppContext.BaseDirectory;
  47. /// <summary>
  48. /// Gets the folder path to the data directory.
  49. /// </summary>
  50. /// <value>The data directory.</value>
  51. public string DataPath
  52. {
  53. get => _dataPath;
  54. private set => _dataPath = Directory.CreateDirectory(value).FullName;
  55. }
  56. /// <inheritdoc />
  57. public string VirtualDataPath { get; } = "%AppDataPath%";
  58. /// <summary>
  59. /// Gets the image cache path.
  60. /// </summary>
  61. /// <value>The image cache path.</value>
  62. public string ImageCachePath => Path.Combine(CachePath, "images");
  63. /// <summary>
  64. /// Gets the path to the plugin directory.
  65. /// </summary>
  66. /// <value>The plugins path.</value>
  67. public string PluginsPath => Path.Combine(ProgramDataPath, "plugins");
  68. /// <summary>
  69. /// Gets the path to the plugin configurations directory.
  70. /// </summary>
  71. /// <value>The plugin configurations path.</value>
  72. public string PluginConfigurationsPath => Path.Combine(PluginsPath, "configurations");
  73. /// <summary>
  74. /// Gets the path to the log directory.
  75. /// </summary>
  76. /// <value>The log directory path.</value>
  77. public string LogDirectoryPath { get; }
  78. /// <summary>
  79. /// Gets the path to the application configuration root directory.
  80. /// </summary>
  81. /// <value>The configuration directory path.</value>
  82. public string ConfigurationDirectoryPath { get; }
  83. /// <summary>
  84. /// Gets the path to the system configuration file.
  85. /// </summary>
  86. /// <value>The system configuration file path.</value>
  87. public string SystemConfigurationFilePath => Path.Combine(ConfigurationDirectoryPath, "system.xml");
  88. /// <summary>
  89. /// Gets or sets the folder path to the cache directory.
  90. /// </summary>
  91. /// <value>The cache directory.</value>
  92. public string CachePath { get; set; }
  93. /// <summary>
  94. /// Gets the folder path to the temp directory within the cache folder.
  95. /// </summary>
  96. /// <value>The temp directory.</value>
  97. public string TempDirectory => Path.Combine(CachePath, "temp");
  98. }
  99. }