ItemRefreshController.cs 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. using System;
  2. using System.ComponentModel;
  3. using System.Diagnostics.CodeAnalysis;
  4. using Jellyfin.Api.Constants;
  5. using MediaBrowser.Controller.Library;
  6. using MediaBrowser.Controller.Providers;
  7. using MediaBrowser.Model.IO;
  8. using Microsoft.AspNetCore.Authorization;
  9. using Microsoft.AspNetCore.Http;
  10. using Microsoft.AspNetCore.Mvc;
  11. namespace Jellyfin.Api.Controllers
  12. {
  13. /// <summary>
  14. /// Item Refresh Controller.
  15. /// </summary>
  16. /// [Authenticated]
  17. [Route("/Items")]
  18. [Authorize(Policy = Policies.DefaultAuthorization)]
  19. public class ItemRefreshController : BaseJellyfinApiController
  20. {
  21. private readonly ILibraryManager _libraryManager;
  22. private readonly IProviderManager _providerManager;
  23. private readonly IFileSystem _fileSystem;
  24. /// <summary>
  25. /// Initializes a new instance of the <see cref="ItemRefreshController"/> class.
  26. /// </summary>
  27. /// <param name="libraryManager">Instance of <see cref="ILibraryManager"/> interface.</param>
  28. /// <param name="providerManager">Instance of <see cref="IProviderManager"/> interface.</param>
  29. /// <param name="fileSystem">Instance of <see cref="IFileSystem"/> interface.</param>
  30. public ItemRefreshController(
  31. ILibraryManager libraryManager,
  32. IProviderManager providerManager,
  33. IFileSystem fileSystem)
  34. {
  35. _libraryManager = libraryManager;
  36. _providerManager = providerManager;
  37. _fileSystem = fileSystem;
  38. }
  39. /// <summary>
  40. /// Refreshes metadata for an item.
  41. /// </summary>
  42. /// <param name="itemId">Item id.</param>
  43. /// <param name="metadataRefreshMode">(Optional) Specifies the metadata refresh mode.</param>
  44. /// <param name="imageRefreshMode">(Optional) Specifies the image refresh mode.</param>
  45. /// <param name="replaceAllMetadata">(Optional) Determines if metadata should be replaced. Only applicable if mode is FullRefresh.</param>
  46. /// <param name="replaceAllImages">(Optional) Determines if images should be replaced. Only applicable if mode is FullRefresh.</param>
  47. /// <param name="recursive">(Unused) Indicates if the refresh should occur recursively.</param>
  48. /// <response code="204">Item metadata refresh queued.</response>
  49. /// <response code="404">Item to refresh not found.</response>
  50. /// <returns>An <see cref="NoContentResult"/> on success, or a <see cref="NotFoundResult"/> if the item could not be found.</returns>
  51. [HttpPost("{itemId}/Refresh")]
  52. [Description("Refreshes metadata for an item.")]
  53. [ProducesResponseType(StatusCodes.Status204NoContent)]
  54. [ProducesResponseType(StatusCodes.Status404NotFound)]
  55. [SuppressMessage("Microsoft.Performance", "CA1801:ReviewUnusedParameters", MessageId = "recursive", Justification = "Imported from ServiceStack")]
  56. public ActionResult Post(
  57. [FromRoute] Guid itemId,
  58. [FromQuery] MetadataRefreshMode metadataRefreshMode = MetadataRefreshMode.None,
  59. [FromQuery] MetadataRefreshMode imageRefreshMode = MetadataRefreshMode.None,
  60. [FromQuery] bool replaceAllMetadata = false,
  61. [FromQuery] bool replaceAllImages = false,
  62. [FromQuery] bool recursive = false)
  63. {
  64. var item = _libraryManager.GetItemById(itemId);
  65. if (item == null)
  66. {
  67. return NotFound();
  68. }
  69. var refreshOptions = new MetadataRefreshOptions(new DirectoryService(_fileSystem))
  70. {
  71. MetadataRefreshMode = metadataRefreshMode,
  72. ImageRefreshMode = imageRefreshMode,
  73. ReplaceAllImages = replaceAllImages,
  74. ReplaceAllMetadata = replaceAllMetadata,
  75. ForceSave = metadataRefreshMode == MetadataRefreshMode.FullRefresh
  76. || imageRefreshMode == MetadataRefreshMode.FullRefresh
  77. || replaceAllImages
  78. || replaceAllMetadata,
  79. IsAutomated = false
  80. };
  81. _providerManager.QueueRefresh(item.Id, refreshOptions, RefreshPriority.High);
  82. return NoContent();
  83. }
  84. }
  85. }