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

147 lines
6.3 KiB
C#
Raw Normal View History

2014-09-30 04:47:30 +00:00
using System;
using MediaBrowser.Controller.Entities;
2014-06-07 19:46:24 +00:00
using MediaBrowser.Model.Channels;
2014-03-18 01:45:41 +00:00
using MediaBrowser.Model.Dto;
using MediaBrowser.Model.Querying;
using System.Collections.Generic;
2014-03-18 01:45:41 +00:00
using System.Threading;
using System.Threading.Tasks;
namespace MediaBrowser.Controller.Channels
{
public interface IChannelManager
{
2014-03-18 01:45:41 +00:00
/// <summary>
/// Adds the parts.
/// </summary>
/// <param name="channels">The channels.</param>
2014-05-03 23:38:23 +00:00
/// <param name="factories">The factories.</param>
2015-09-16 03:55:26 +00:00
void AddParts(IEnumerable<IChannel> channels);
2014-03-18 01:45:41 +00:00
2014-06-02 19:32:41 +00:00
/// <summary>
/// Gets the channel download path.
/// </summary>
/// <value>The channel download path.</value>
string ChannelDownloadPath { get; }
2014-05-27 17:09:48 +00:00
/// <summary>
/// Gets the channel features.
/// </summary>
/// <param name="id">The identifier.</param>
/// <returns>ChannelFeatures.</returns>
ChannelFeatures GetChannelFeatures(string id);
2014-06-02 19:32:41 +00:00
/// <summary>
/// Gets all channel features.
/// </summary>
/// <returns>IEnumerable{ChannelFeatures}.</returns>
IEnumerable<ChannelFeatures> GetAllChannelFeatures();
/// <summary>
/// Gets the channel.
/// </summary>
/// <param name="id">The identifier.</param>
/// <returns>Channel.</returns>
Channel GetChannel(string id);
2014-07-30 03:31:35 +00:00
/// <summary>
/// Gets the channels internal.
/// </summary>
/// <param name="query">The query.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task&lt;QueryResult&lt;Channel&gt;&gt;.</returns>
Task<QueryResult<Channel>> GetChannelsInternal(ChannelQuery query, CancellationToken cancellationToken);
2014-03-18 01:45:41 +00:00
/// <summary>
/// Gets the channels.
/// </summary>
/// <param name="query">The query.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task{QueryResult{BaseItemDto}}.</returns>
Task<QueryResult<BaseItemDto>> GetChannels(ChannelQuery query, CancellationToken cancellationToken);
2014-09-22 21:56:54 +00:00
/// <summary>
/// Gets all media internal.
/// </summary>
/// <param name="query">The query.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task&lt;QueryResult&lt;BaseItem&gt;&gt;.</returns>
Task<QueryResult<BaseItem>> GetAllMediaInternal(AllChannelMediaQuery query, CancellationToken cancellationToken);
2014-06-02 19:32:41 +00:00
/// <summary>
/// Gets all media.
/// </summary>
/// <param name="query">The query.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task{QueryResult{BaseItemDto}}.</returns>
Task<QueryResult<BaseItemDto>> GetAllMedia(AllChannelMediaQuery query, CancellationToken cancellationToken);
/// <summary>
/// Gets the latest media.
/// </summary>
/// <param name="query">The query.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task{QueryResult{BaseItemDto}}.</returns>
Task<QueryResult<BaseItemDto>> GetLatestChannelItems(AllChannelMediaQuery query, CancellationToken cancellationToken);
2014-09-30 04:47:30 +00:00
/// <summary>
/// Gets the latest channel items internal.
/// </summary>
/// <param name="query">The query.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task&lt;QueryResult&lt;BaseItem&gt;&gt;.</returns>
Task<QueryResult<BaseItem>> GetLatestChannelItemsInternal(AllChannelMediaQuery query, CancellationToken cancellationToken);
2014-03-18 01:45:41 +00:00
/// <summary>
/// Gets the channel items.
/// </summary>
/// <param name="query">The query.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task{QueryResult{BaseItemDto}}.</returns>
Task<QueryResult<BaseItemDto>> GetChannelItems(ChannelItemQuery query, CancellationToken cancellationToken);
2014-05-18 19:58:42 +00:00
2014-07-30 03:31:35 +00:00
/// <summary>
/// Gets the channel items internal.
/// </summary>
/// <param name="query">The query.</param>
2014-09-30 04:47:30 +00:00
/// <param name="progress">The progress.</param>
2014-07-30 03:31:35 +00:00
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task&lt;QueryResult&lt;BaseItem&gt;&gt;.</returns>
2014-09-30 04:47:30 +00:00
Task<QueryResult<BaseItem>> GetChannelItemsInternal(ChannelItemQuery query, IProgress<double> progress, CancellationToken cancellationToken);
2014-07-30 03:31:35 +00:00
2014-05-18 19:58:42 +00:00
/// <summary>
/// Gets the channel item media sources.
/// </summary>
2015-03-28 20:22:27 +00:00
/// <param name="item">The item.</param>
/// <param name="includeCachedVersions">if set to <c>true</c> [include cached versions].</param>
2014-05-18 19:58:42 +00:00
/// <param name="cancellationToken">The cancellation token.</param>
2014-06-03 02:01:30 +00:00
/// <returns>Task{IEnumerable{MediaSourceInfo}}.</returns>
2015-03-28 20:22:27 +00:00
Task<IEnumerable<MediaSourceInfo>> GetStaticMediaSources(IChannelMediaItem item, bool includeCachedVersions, CancellationToken cancellationToken);
2014-06-07 19:46:24 +00:00
/// <summary>
/// Gets the channel folder.
/// </summary>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>BaseItemDto.</returns>
2015-08-14 18:30:08 +00:00
Task<Folder> GetInternalChannelFolder(CancellationToken cancellationToken);
2014-06-07 19:46:24 +00:00
/// <summary>
/// Gets the channel folder.
/// </summary>
/// <param name="userId">The user identifier.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>BaseItemDto.</returns>
Task<BaseItemDto> GetChannelFolder(string userId, CancellationToken cancellationToken);
2014-09-30 04:47:30 +00:00
/// <summary>
/// Downloads the channel item.
/// </summary>
/// <param name="item">The item.</param>
/// <param name="destinationPath">The destination path.</param>
/// <param name="progress">The progress.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>Task.</returns>
Task DownloadChannelItem(IChannelMediaItem item, string destinationPath, IProgress<double> progress, CancellationToken cancellationToken);
}
}