jellyfin/MediaBrowser.Providers/Lyric/ILyricProvider.cs

37 lines
959 B
C#
Raw Normal View History

2022-09-22 14:13:53 +02:00
using System.Threading.Tasks;
using MediaBrowser.Controller.Entities;
2022-09-18 19:13:01 +02:00
using MediaBrowser.Controller.Resolvers;
2023-06-20 16:51:07 +02:00
namespace MediaBrowser.Providers.Lyric;
2022-09-17 23:37:38 +02:00
/// <summary>
/// Interface ILyricsProvider.
/// </summary>
public interface ILyricProvider
{
/// <summary>
2022-09-17 23:37:38 +02:00
/// Gets a value indicating the provider name.
/// </summary>
2022-09-17 23:37:38 +02:00
string Name { get; }
2022-09-16 02:49:25 +02:00
2022-09-18 19:13:01 +02:00
/// <summary>
/// Gets the priority.
/// </summary>
/// <value>The priority.</value>
ResolverPriority Priority { get; }
2022-09-17 23:37:38 +02:00
/// <summary>
2023-06-20 16:51:07 +02:00
/// Checks if an item has lyrics available.
2022-09-17 23:37:38 +02:00
/// </summary>
2023-06-20 16:51:07 +02:00
/// <param name="item">The media item.</param>
/// <returns>Whether lyrics where found or not.</returns>
bool HasLyrics(BaseItem item);
2022-09-17 23:37:38 +02:00
/// <summary>
/// Gets the lyrics.
/// </summary>
/// <param name="item">The media item.</param>
2022-09-22 14:13:53 +02:00
/// <returns>A task representing found lyrics.</returns>
2023-06-20 16:51:07 +02:00
Task<LyricFile?> GetLyrics(BaseItem item);
}