ItemRefreshController.cs 4.0 KB

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