jellyfin-server/MediaBrowser.Controller/Channels/IChannel.cs

108 lines
3.5 KiB
C#
Raw Normal View History

using MediaBrowser.Controller.Entities;
2014-03-18 17:05:57 +00:00
using MediaBrowser.Controller.Providers;
using MediaBrowser.Model.Entities;
using System;
using System.Collections.Generic;
using System.Threading;
using System.Threading.Tasks;
namespace MediaBrowser.Controller.Channels
{
public interface IChannel
{
/// <summary>
/// Gets the name.
/// </summary>
/// <value>The name.</value>
string Name { get; }
/// <summary>
2014-05-03 04:20:04 +00:00
/// Gets the channel information.
/// </summary>
2014-05-03 04:20:04 +00:00
/// <returns>ChannelInfo.</returns>
ChannelInfo GetChannelInfo();
2014-03-18 01:45:41 +00:00
/// <summary>
/// Determines whether [is enabled for] [the specified user].
/// </summary>
/// <param name="user">The user.</param>
/// <returns><c>true</c> if [is enabled for] [the specified user]; otherwise, <c>false</c>.</returns>
bool IsEnabledFor(User user);
/// <summary>
/// Searches the specified search term.
/// </summary>
2014-03-18 01:45:41 +00:00
/// <param name="searchInfo">The search information.</param>
/// <param name="user">The user.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task{IEnumerable{ChannelItemInfo}}.</returns>
2014-03-18 01:45:41 +00:00
Task<IEnumerable<ChannelItemInfo>> Search(ChannelSearchInfo searchInfo, User user, CancellationToken cancellationToken);
/// <summary>
/// Gets the channel items.
/// </summary>
2014-03-18 17:05:57 +00:00
/// <param name="query">The query.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task{IEnumerable{ChannelItem}}.</returns>
2014-03-18 17:05:57 +00:00
Task<ChannelItemResult> GetChannelItems(InternalChannelItemQuery query, CancellationToken cancellationToken);
/// <summary>
2014-03-18 17:05:57 +00:00
/// Gets the channel image.
/// </summary>
2014-03-18 17:05:57 +00:00
/// <param name="type">The type.</param>
/// <param name="cancellationToken">The cancellation token.</param>
2014-03-18 17:05:57 +00:00
/// <returns>Task{DynamicImageInfo}.</returns>
Task<DynamicImageResponse> GetChannelImage(ImageType type, CancellationToken cancellationToken);
/// <summary>
/// Gets the supported channel images.
/// </summary>
/// <returns>IEnumerable{ImageType}.</returns>
IEnumerable<ImageType> GetSupportedChannelImages();
}
2014-05-03 04:20:04 +00:00
public class ChannelInfo
{
2014-05-03 04:20:04 +00:00
/// <summary>
/// Gets the home page URL.
/// </summary>
/// <value>The home page URL.</value>
public string HomePageUrl { get; set; }
/// <summary>
/// Gets or sets a value indicating whether this instance can search.
/// </summary>
/// <value><c>true</c> if this instance can search; otherwise, <c>false</c>.</value>
public bool CanSearch { get; set; }
2014-05-03 04:20:04 +00:00
public List<ChannelMediaType> MediaTypes { get; set; }
public List<ChannelMediaContentType> ContentTypes { get; set; }
public ChannelInfo()
{
MediaTypes = new List<ChannelMediaType>();
ContentTypes = new List<ChannelMediaContentType>();
}
}
2014-03-18 01:45:41 +00:00
public class ChannelSearchInfo
{
public string SearchTerm { get; set; }
}
2014-03-18 17:05:57 +00:00
public class InternalChannelItemQuery
{
public string CategoryId { get; set; }
public User User { get; set; }
}
public class ChannelItemResult
{
public List<ChannelItemInfo> Items { get; set; }
public TimeSpan CacheLength { get; set; }
}
}