diff options
| author | JPVenson <JPVenson@users.noreply.github.com> | 2024-09-07 22:56:51 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-09-07 14:56:51 -0600 |
| commit | 5ceedced1c4a8bac5b5b7a5f2bd0913783bd427b (patch) | |
| tree | e655f4307f550761b855c2acaddb83dd6ecfa11c /MediaBrowser.Controller/MediaSegements/IMediaSegmentProvider.cs | |
| parent | fc247dab9243b3de42193c4be351636204dbc2f2 (diff) | |
Feature/media segments plugin api (#12359)
Diffstat (limited to 'MediaBrowser.Controller/MediaSegements/IMediaSegmentProvider.cs')
| -rw-r--r-- | MediaBrowser.Controller/MediaSegements/IMediaSegmentProvider.cs | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/MediaBrowser.Controller/MediaSegements/IMediaSegmentProvider.cs b/MediaBrowser.Controller/MediaSegements/IMediaSegmentProvider.cs new file mode 100644 index 0000000000..39bb58bef2 --- /dev/null +++ b/MediaBrowser.Controller/MediaSegements/IMediaSegmentProvider.cs @@ -0,0 +1,36 @@ +using System; +using System.Collections; +using System.Collections.Generic; +using System.Threading; +using System.Threading.Tasks; +using MediaBrowser.Controller.Entities; +using MediaBrowser.Model; +using MediaBrowser.Model.MediaSegments; + +namespace MediaBrowser.Controller; + +/// <summary> +/// Provides methods for Obtaining the Media Segments from an Item. +/// </summary> +public interface IMediaSegmentProvider +{ + /// <summary> + /// Gets the provider name. + /// </summary> + string Name { get; } + + /// <summary> + /// Enumerates all Media Segments from an Media Item. + /// </summary> + /// <param name="request">Arguments to enumerate MediaSegments.</param> + /// <param name="cancellationToken">Abort token.</param> + /// <returns>A list of all MediaSegments found from this provider.</returns> + Task<IReadOnlyList<MediaSegmentDto>> GetMediaSegments(MediaSegmentGenerationRequest request, CancellationToken cancellationToken); + + /// <summary> + /// Should return support state for the given item. + /// </summary> + /// <param name="item">The base item to extract segments from.</param> + /// <returns>True if item is supported, otherwise false.</returns> + ValueTask<bool> Supports(BaseItem item); +} |
