ItemRefreshController.cs 3.7 KB

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