| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 | 
							- using System;
 
- using System.Collections.Generic;
 
- using System.IO;
 
- using System.Threading;
 
- using System.Threading.Tasks;
 
- using MediaBrowser.Controller.Entities;
 
- using MediaBrowser.Controller.Entities.Audio;
 
- using MediaBrowser.Model.Configuration;
 
- using MediaBrowser.Model.Lyrics;
 
- using MediaBrowser.Model.Providers;
 
- namespace MediaBrowser.Controller.Lyrics;
 
- /// <summary>
 
- /// Interface ILyricManager.
 
- /// </summary>
 
- public interface ILyricManager
 
- {
 
-     /// <summary>
 
-     /// Occurs when a lyric download fails.
 
-     /// </summary>
 
-     event EventHandler<LyricDownloadFailureEventArgs> LyricDownloadFailure;
 
-     /// <summary>
 
-     /// Search for lyrics for the specified song.
 
-     /// </summary>
 
-     /// <param name="audio">The song.</param>
 
-     /// <param name="isAutomated">Whether the request is automated.</param>
 
-     /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
 
-     /// <returns>The list of lyrics.</returns>
 
-     Task<IReadOnlyList<RemoteLyricInfoDto>> SearchLyricsAsync(
 
-         Audio audio,
 
-         bool isAutomated,
 
-         CancellationToken cancellationToken);
 
-     /// <summary>
 
-     /// Search for lyrics.
 
-     /// </summary>
 
-     /// <param name="request">The search request.</param>
 
-     /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
 
-     /// <returns>The list of lyrics.</returns>
 
-     Task<IReadOnlyList<RemoteLyricInfoDto>> SearchLyricsAsync(
 
-         LyricSearchRequest request,
 
-         CancellationToken cancellationToken);
 
-     /// <summary>
 
-     /// Download the lyrics.
 
-     /// </summary>
 
-     /// <param name="audio">The audio.</param>
 
-     /// <param name="lyricId">The remote lyric id.</param>
 
-     /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
 
-     /// <returns>The downloaded lyrics.</returns>
 
-     Task<LyricDto?> DownloadLyricsAsync(
 
-         Audio audio,
 
-         string lyricId,
 
-         CancellationToken cancellationToken);
 
-     /// <summary>
 
-     /// Download the lyrics.
 
-     /// </summary>
 
-     /// <param name="audio">The audio.</param>
 
-     /// <param name="libraryOptions">The library options to use.</param>
 
-     /// <param name="lyricId">The remote lyric id.</param>
 
-     /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
 
-     /// <returns>The downloaded lyrics.</returns>
 
-     Task<LyricDto?> DownloadLyricsAsync(
 
-         Audio audio,
 
-         LibraryOptions libraryOptions,
 
-         string lyricId,
 
-         CancellationToken cancellationToken);
 
-     /// <summary>
 
-     /// Saves new lyrics.
 
-     /// </summary>
 
-     /// <param name="audio">The audio file the lyrics belong to.</param>
 
-     /// <param name="format">The lyrics format.</param>
 
-     /// <param name="lyrics">The lyrics.</param>
 
-     /// <returns>A <see cref="Task"/> representing the asynchronous operation.</returns>
 
-     Task<LyricDto?> SaveLyricAsync(Audio audio, string format, string lyrics);
 
-     /// <summary>
 
-     /// Saves new lyrics.
 
-     /// </summary>
 
-     /// <param name="audio">The audio file the lyrics belong to.</param>
 
-     /// <param name="format">The lyrics format.</param>
 
-     /// <param name="lyrics">The lyrics.</param>
 
-     /// <returns>A <see cref="Task"/> representing the asynchronous operation.</returns>
 
-     Task<LyricDto?> SaveLyricAsync(Audio audio, string format, Stream lyrics);
 
-     /// <summary>
 
-     /// Get the remote lyrics.
 
-     /// </summary>
 
-     /// <param name="id">The remote lyrics id.</param>
 
-     /// <param name="cancellationToken">CancellationToken to use for the operation.</param>
 
-     /// <returns>The lyric response.</returns>
 
-     Task<LyricDto?> GetRemoteLyricsAsync(string id, CancellationToken cancellationToken);
 
-     /// <summary>
 
-     /// Deletes the lyrics.
 
-     /// </summary>
 
-     /// <param name="audio">The audio file to remove lyrics from.</param>
 
-     /// <returns>A <see cref="Task"/> representing the asynchronous operation.</returns>
 
-     Task DeleteLyricsAsync(Audio audio);
 
-     /// <summary>
 
-     /// Get the list of lyric providers.
 
-     /// </summary>
 
-     /// <param name="item">The item.</param>
 
-     /// <returns>Lyric providers.</returns>
 
-     IReadOnlyList<LyricProviderInfo> GetSupportedProviders(BaseItem item);
 
-     /// <summary>
 
-     /// Get the existing lyric for the audio.
 
-     /// </summary>
 
-     /// <param name="audio">The audio item.</param>
 
-     /// <param name="cancellationToken">The cancellation token.</param>
 
-     /// <returns>The parsed lyric model.</returns>
 
-     Task<LyricDto?> GetLyricsAsync(Audio audio, CancellationToken cancellationToken);
 
- }
 
 
  |