ResolverHelper.cs 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. using MediaBrowser.Common.IO;
  2. using MediaBrowser.Controller.Entities;
  3. using MediaBrowser.Controller.Library;
  4. using MediaBrowser.Controller.Providers;
  5. using System;
  6. using System.IO;
  7. using System.Linq;
  8. using System.Text.RegularExpressions;
  9. using CommonIO;
  10. namespace MediaBrowser.Server.Implementations.Library
  11. {
  12. /// <summary>
  13. /// Class ResolverHelper
  14. /// </summary>
  15. public static class ResolverHelper
  16. {
  17. /// <summary>
  18. /// Sets the initial item values.
  19. /// </summary>
  20. /// <param name="item">The item.</param>
  21. /// <param name="parent">The parent.</param>
  22. /// <param name="fileSystem">The file system.</param>
  23. /// <param name="libraryManager">The library manager.</param>
  24. /// <param name="directoryService">The directory service.</param>
  25. /// <exception cref="System.ArgumentException">Item must have a path</exception>
  26. public static void SetInitialItemValues(BaseItem item, Folder parent, IFileSystem fileSystem, ILibraryManager libraryManager, IDirectoryService directoryService)
  27. {
  28. // This version of the below method has no ItemResolveArgs, so we have to require the path already being set
  29. if (string.IsNullOrWhiteSpace(item.Path))
  30. {
  31. throw new ArgumentException("Item must have a Path");
  32. }
  33. // If the resolver didn't specify this
  34. if (parent != null)
  35. {
  36. item.SetParent(parent);
  37. }
  38. item.Id = libraryManager.GetNewItemId(item.Path, item.GetType());
  39. item.IsLocked = item.Path.IndexOf("[dontfetchmeta]", StringComparison.OrdinalIgnoreCase) != -1 ||
  40. item.Parents.Any(i => i.IsLocked);
  41. // Make sure DateCreated and DateModified have values
  42. var fileInfo = directoryService.GetFile(item.Path);
  43. item.DateModified = fileSystem.GetLastWriteTimeUtc(fileInfo);
  44. SetDateCreated(item, fileSystem, fileInfo);
  45. EnsureName(item, fileInfo);
  46. }
  47. /// <summary>
  48. /// Sets the initial item values.
  49. /// </summary>
  50. /// <param name="item">The item.</param>
  51. /// <param name="args">The args.</param>
  52. /// <param name="fileSystem">The file system.</param>
  53. /// <param name="libraryManager">The library manager.</param>
  54. public static void SetInitialItemValues(BaseItem item, ItemResolveArgs args, IFileSystem fileSystem, ILibraryManager libraryManager)
  55. {
  56. // If the resolver didn't specify this
  57. if (string.IsNullOrEmpty(item.Path))
  58. {
  59. item.Path = args.Path;
  60. }
  61. // If the resolver didn't specify this
  62. if (args.Parent != null)
  63. {
  64. item.SetParent(args.Parent);
  65. }
  66. item.Id = libraryManager.GetNewItemId(item.Path, item.GetType());
  67. // Make sure the item has a name
  68. EnsureName(item, args.FileInfo);
  69. item.IsLocked = item.Path.IndexOf("[dontfetchmeta]", StringComparison.OrdinalIgnoreCase) != -1 ||
  70. item.Parents.Any(i => i.IsLocked);
  71. // Make sure DateCreated and DateModified have values
  72. EnsureDates(fileSystem, item, args, true);
  73. }
  74. /// <summary>
  75. /// Ensures the name.
  76. /// </summary>
  77. /// <param name="item">The item.</param>
  78. /// <param name="fileInfo">The file information.</param>
  79. private static void EnsureName(BaseItem item, FileSystemMetadata fileInfo)
  80. {
  81. // If the subclass didn't supply a name, add it here
  82. if (string.IsNullOrEmpty(item.Name) && !string.IsNullOrEmpty(item.Path))
  83. {
  84. item.Name = GetDisplayName(fileInfo.Name, fileInfo.IsDirectory);
  85. }
  86. }
  87. /// <summary>
  88. /// Gets the display name.
  89. /// </summary>
  90. /// <param name="path">The path.</param>
  91. /// <param name="isDirectory">if set to <c>true</c> [is directory].</param>
  92. /// <returns>System.String.</returns>
  93. private static string GetDisplayName(string path, bool isDirectory)
  94. {
  95. return isDirectory ? Path.GetFileName(path) : Path.GetFileNameWithoutExtension(path);
  96. }
  97. /// <summary>
  98. /// The MB name regex
  99. /// </summary>
  100. private static readonly Regex MbNameRegex = new Regex(@"(\[.*?\])", RegexOptions.Compiled);
  101. internal static string StripBrackets(string inputString)
  102. {
  103. var output = MbNameRegex.Replace(inputString, string.Empty).Trim();
  104. return Regex.Replace(output, @"\s+", " ");
  105. }
  106. /// <summary>
  107. /// Ensures DateCreated and DateModified have values
  108. /// </summary>
  109. /// <param name="fileSystem">The file system.</param>
  110. /// <param name="item">The item.</param>
  111. /// <param name="args">The args.</param>
  112. /// <param name="includeCreationTime">if set to <c>true</c> [include creation time].</param>
  113. private static void EnsureDates(IFileSystem fileSystem, BaseItem item, ItemResolveArgs args, bool includeCreationTime)
  114. {
  115. if (fileSystem == null)
  116. {
  117. throw new ArgumentNullException("fileSystem");
  118. }
  119. if (item == null)
  120. {
  121. throw new ArgumentNullException("item");
  122. }
  123. if (args == null)
  124. {
  125. throw new ArgumentNullException("args");
  126. }
  127. // See if a different path came out of the resolver than what went in
  128. if (!string.Equals(args.Path, item.Path, StringComparison.OrdinalIgnoreCase))
  129. {
  130. var childData = args.IsDirectory ? args.GetFileSystemEntryByPath(item.Path) : null;
  131. if (childData != null)
  132. {
  133. if (includeCreationTime)
  134. {
  135. SetDateCreated(item, fileSystem, childData);
  136. }
  137. item.DateModified = fileSystem.GetLastWriteTimeUtc(childData);
  138. }
  139. else
  140. {
  141. var fileData = fileSystem.GetFileSystemInfo(item.Path);
  142. if (fileData.Exists)
  143. {
  144. if (includeCreationTime)
  145. {
  146. SetDateCreated(item, fileSystem, fileData);
  147. }
  148. item.DateModified = fileSystem.GetLastWriteTimeUtc(fileData);
  149. }
  150. }
  151. }
  152. else
  153. {
  154. if (includeCreationTime)
  155. {
  156. SetDateCreated(item, fileSystem, args.FileInfo);
  157. }
  158. item.DateModified = fileSystem.GetLastWriteTimeUtc(args.FileInfo);
  159. }
  160. }
  161. private static void SetDateCreated(BaseItem item, IFileSystem fileSystem, FileSystemMetadata info)
  162. {
  163. var config = BaseItem.ConfigurationManager.GetMetadataConfiguration();
  164. if (config.UseFileCreationTimeForDateAdded)
  165. {
  166. item.DateCreated = fileSystem.GetCreationTimeUtc(info);
  167. }
  168. else
  169. {
  170. item.DateCreated = DateTime.UtcNow;
  171. }
  172. }
  173. }
  174. }