ILyricManager.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Threading;
  4. using System.Threading.Tasks;
  5. using MediaBrowser.Controller.Entities;
  6. using MediaBrowser.Controller.Entities.Audio;
  7. using MediaBrowser.Model.Configuration;
  8. using MediaBrowser.Model.Lyrics;
  9. using MediaBrowser.Model.Providers;
  10. namespace MediaBrowser.Controller.Lyrics;
  11. /// <summary>
  12. /// Interface ILyricManager.
  13. /// </summary>
  14. public interface ILyricManager
  15. {
  16. /// <summary>
  17. /// Occurs when a lyric download fails.
  18. /// </summary>
  19. event EventHandler<LyricDownloadFailureEventArgs> LyricDownloadFailure;
  20. /// <summary>
  21. /// Search for lyrics for the specified song.
  22. /// </summary>
  23. /// <param name="audio">The song.</param>
  24. /// <param name="isAutomated">Whether the request is automated.</param>
  25. /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
  26. /// <returns>The list of lyrics.</returns>
  27. Task<IReadOnlyList<RemoteLyricInfoDto>> SearchLyricsAsync(
  28. Audio audio,
  29. bool isAutomated,
  30. CancellationToken cancellationToken);
  31. /// <summary>
  32. /// Search for lyrics.
  33. /// </summary>
  34. /// <param name="request">The search request.</param>
  35. /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
  36. /// <returns>The list of lyrics.</returns>
  37. Task<IReadOnlyList<RemoteLyricInfoDto>> SearchLyricsAsync(
  38. LyricSearchRequest request,
  39. CancellationToken cancellationToken);
  40. /// <summary>
  41. /// Download the lyrics.
  42. /// </summary>
  43. /// <param name="audio">The audio.</param>
  44. /// <param name="lyricId">The remote lyric id.</param>
  45. /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
  46. /// <returns>The downloaded lyrics.</returns>
  47. Task<LyricDto?> DownloadLyricsAsync(
  48. Audio audio,
  49. string lyricId,
  50. CancellationToken cancellationToken);
  51. /// <summary>
  52. /// Download the lyrics.
  53. /// </summary>
  54. /// <param name="audio">The audio.</param>
  55. /// <param name="libraryOptions">The library options to use.</param>
  56. /// <param name="lyricId">The remote lyric id.</param>
  57. /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
  58. /// <returns>The downloaded lyrics.</returns>
  59. Task<LyricDto?> DownloadLyricsAsync(
  60. Audio audio,
  61. LibraryOptions libraryOptions,
  62. string lyricId,
  63. CancellationToken cancellationToken);
  64. /// <summary>
  65. /// Upload new lyrics.
  66. /// </summary>
  67. /// <param name="audio">The audio file the lyrics belong to.</param>
  68. /// <param name="lyricResponse">The lyric response.</param>
  69. /// <returns>A <see cref="Task"/> representing the asynchronous operation.</returns>
  70. Task<LyricDto?> UploadLyricAsync(Audio audio, LyricResponse lyricResponse);
  71. /// <summary>
  72. /// Get the remote lyrics.
  73. /// </summary>
  74. /// <param name="id">The remote lyrics id.</param>
  75. /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
  76. /// <returns>The lyric response.</returns>
  77. Task<LyricDto?> GetRemoteLyricsAsync(string id, CancellationToken cancellationToken);
  78. /// <summary>
  79. /// Deletes the lyrics.
  80. /// </summary>
  81. /// <param name="audio">The audio file to remove lyrics from.</param>
  82. /// <returns>A <see cref="Task"/> representing the asynchronous operation.</returns>
  83. Task DeleteLyricsAsync(Audio audio);
  84. /// <summary>
  85. /// Get the list of lyric providers.
  86. /// </summary>
  87. /// <param name="item">The item.</param>
  88. /// <returns>Lyric providers.</returns>
  89. IReadOnlyList<LyricProviderInfo> GetSupportedProviders(BaseItem item);
  90. /// <summary>
  91. /// Get the existing lyric for the audio.
  92. /// </summary>
  93. /// <param name="audio">The audio item.</param>
  94. /// <param name="cancellationToken">The cancellation token.</param>
  95. /// <returns>The parsed lyric model.</returns>
  96. Task<LyricDto?> GetLyricsAsync(Audio audio, CancellationToken cancellationToken);
  97. }