You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
35 lines
1.1 KiB
35 lines
1.1 KiB
11 months ago
|
using System.Collections.Generic;
|
||
|
using System.Threading;
|
||
|
using System.Threading.Tasks;
|
||
|
using MediaBrowser.Model.Lyrics;
|
||
|
using MediaBrowser.Model.Providers;
|
||
|
|
||
|
namespace MediaBrowser.Controller.Lyrics;
|
||
|
|
||
|
/// <summary>
|
||
|
/// Interface ILyricsProvider.
|
||
|
/// </summary>
|
||
|
public interface ILyricProvider
|
||
|
{
|
||
|
/// <summary>
|
||
|
/// Gets the provider name.
|
||
|
/// </summary>
|
||
|
string Name { get; }
|
||
|
|
||
|
/// <summary>
|
||
|
/// Search for lyrics.
|
||
|
/// </summary>
|
||
|
/// <param name="request">The search request.</param>
|
||
|
/// <param name="cancellationToken">The cancellation token.</param>
|
||
|
/// <returns>The list of remote lyrics.</returns>
|
||
|
Task<IEnumerable<RemoteLyricInfo>> SearchAsync(LyricSearchRequest request, CancellationToken cancellationToken);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Get the lyrics.
|
||
|
/// </summary>
|
||
|
/// <param name="id">The remote lyric id.</param>
|
||
|
/// <param name="cancellationToken">The cancellation token.</param>
|
||
|
/// <returns>The lyric response.</returns>
|
||
|
Task<LyricResponse?> GetLyricsAsync(string id, CancellationToken cancellationToken);
|
||
|
}
|