FileOrganizationService.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. using MediaBrowser.Common.Extensions;
  2. using MediaBrowser.Common.ScheduledTasks;
  3. using MediaBrowser.Controller.FileOrganization;
  4. using MediaBrowser.Controller.IO;
  5. using MediaBrowser.Controller.Library;
  6. using MediaBrowser.Controller.Persistence;
  7. using MediaBrowser.Model.FileOrganization;
  8. using MediaBrowser.Model.Logging;
  9. using MediaBrowser.Model.Querying;
  10. using System;
  11. using System.IO;
  12. using System.Threading;
  13. using System.Threading.Tasks;
  14. namespace MediaBrowser.Server.Implementations.FileOrganization
  15. {
  16. public class FileOrganizationService : IFileOrganizationService
  17. {
  18. private readonly ITaskManager _taskManager;
  19. private readonly IFileOrganizationRepository _repo;
  20. private readonly ILogger _logger;
  21. private readonly IDirectoryWatchers _directoryWatchers;
  22. private readonly ILibraryManager _libraryManager;
  23. public FileOrganizationService(ITaskManager taskManager, IFileOrganizationRepository repo, ILogger logger, IDirectoryWatchers directoryWatchers, ILibraryManager libraryManager)
  24. {
  25. _taskManager = taskManager;
  26. _repo = repo;
  27. _logger = logger;
  28. _directoryWatchers = directoryWatchers;
  29. _libraryManager = libraryManager;
  30. }
  31. public void BeginProcessNewFiles()
  32. {
  33. _taskManager.CancelIfRunningAndQueue<OrganizerScheduledTask>();
  34. }
  35. public Task SaveResult(FileOrganizationResult result, CancellationToken cancellationToken)
  36. {
  37. if (result == null || string.IsNullOrEmpty(result.OriginalPath))
  38. {
  39. throw new ArgumentNullException("result");
  40. }
  41. result.Id = result.OriginalPath.GetMD5().ToString("N");
  42. return _repo.SaveResult(result, cancellationToken);
  43. }
  44. public QueryResult<FileOrganizationResult> GetResults(FileOrganizationResultQuery query)
  45. {
  46. return _repo.GetResults(query);
  47. }
  48. public Task DeleteOriginalFile(string resultId)
  49. {
  50. var result = _repo.GetResult(resultId);
  51. _logger.Info("Requested to delete {0}", result.OriginalPath);
  52. try
  53. {
  54. File.Delete(result.OriginalPath);
  55. }
  56. catch (Exception ex)
  57. {
  58. _logger.ErrorException("Error deleting {0}", ex, result.OriginalPath);
  59. }
  60. return _repo.Delete(resultId);
  61. }
  62. public async Task PerformOrganization(string resultId)
  63. {
  64. var result = _repo.GetResult(resultId);
  65. if (string.IsNullOrEmpty(result.TargetPath))
  66. {
  67. throw new ArgumentException("No target path available.");
  68. }
  69. _logger.Info("Moving {0} to {1}", result.OriginalPath, result.TargetPath);
  70. _directoryWatchers.TemporarilyIgnore(result.TargetPath);
  71. var copy = File.Exists(result.TargetPath);
  72. try
  73. {
  74. if (copy)
  75. {
  76. File.Copy(result.OriginalPath, result.TargetPath, true);
  77. }
  78. else
  79. {
  80. File.Move(result.OriginalPath, result.TargetPath);
  81. }
  82. }
  83. finally
  84. {
  85. _directoryWatchers.RemoveTempIgnore(result.TargetPath);
  86. }
  87. if (copy)
  88. {
  89. try
  90. {
  91. File.Delete(result.OriginalPath);
  92. }
  93. catch (Exception ex)
  94. {
  95. _logger.ErrorException("Error deleting {0}", ex, result.OriginalPath);
  96. }
  97. }
  98. result.Status = FileSortingStatus.Success;
  99. result.StatusMessage = string.Empty;
  100. await SaveResult(result, CancellationToken.None).ConfigureAwait(false);
  101. await _libraryManager.ValidateMediaLibrary(new Progress<double>(), CancellationToken.None)
  102. .ConfigureAwait(false);
  103. }
  104. }
  105. }