mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-11-03 19:17:24 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			116 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
#nullable disable
 | 
						|
 | 
						|
#pragma warning disable CS1591
 | 
						|
 | 
						|
using System;
 | 
						|
using System.Collections.Generic;
 | 
						|
using System.Threading;
 | 
						|
using System.Threading.Tasks;
 | 
						|
using Jellyfin.Data.Enums;
 | 
						|
using MediaBrowser.Controller.Entities;
 | 
						|
using MediaBrowser.Model.Dto;
 | 
						|
using MediaBrowser.Model.Querying;
 | 
						|
 | 
						|
namespace MediaBrowser.Controller.Persistence;
 | 
						|
 | 
						|
/// <summary>
 | 
						|
/// Provides an interface to implement an Item repository.
 | 
						|
/// </summary>
 | 
						|
public interface IItemRepository
 | 
						|
{
 | 
						|
    /// <summary>
 | 
						|
    /// Deletes the item.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="id">The identifier.</param>
 | 
						|
    void DeleteItem(Guid id);
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Saves the items.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="items">The items.</param>
 | 
						|
    /// <param name="cancellationToken">The cancellation token.</param>
 | 
						|
    void SaveItems(IReadOnlyList<BaseItem> items, CancellationToken cancellationToken);
 | 
						|
 | 
						|
    void SaveImages(BaseItem item);
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Retrieves the item.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="id">The id.</param>
 | 
						|
    /// <returns>BaseItem.</returns>
 | 
						|
    BaseItem RetrieveItem(Guid id);
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Gets the items.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="filter">The query.</param>
 | 
						|
    /// <returns>QueryResult<BaseItem>.</returns>
 | 
						|
    QueryResult<BaseItem> GetItems(InternalItemsQuery filter);
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Gets the item ids list.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="filter">The query.</param>
 | 
						|
    /// <returns>List<Guid>.</returns>
 | 
						|
    IReadOnlyList<Guid> GetItemIdsList(InternalItemsQuery filter);
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Gets the item list.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="filter">The query.</param>
 | 
						|
    /// <returns>List<BaseItem>.</returns>
 | 
						|
    IReadOnlyList<BaseItem> GetItemList(InternalItemsQuery filter);
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Gets the item list. Used mainly by the Latest api endpoint.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="filter">The query.</param>
 | 
						|
    /// <param name="collectionType">Collection Type.</param>
 | 
						|
    /// <returns>List<BaseItem>.</returns>
 | 
						|
    IReadOnlyList<BaseItem> GetLatestItemList(InternalItemsQuery filter, CollectionType collectionType);
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Gets the list of series presentation keys for next up.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="filter">The query.</param>
 | 
						|
    /// <param name="dateCutoff">The minimum date for a series to have been most recently watched.</param>
 | 
						|
    /// <returns>The list of keys.</returns>
 | 
						|
    IReadOnlyList<string> GetNextUpSeriesKeys(InternalItemsQuery filter, DateTime dateCutoff);
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Updates the inherited values.
 | 
						|
    /// </summary>
 | 
						|
    void UpdateInheritedValues();
 | 
						|
 | 
						|
    int GetCount(InternalItemsQuery filter);
 | 
						|
 | 
						|
    ItemCounts GetItemCounts(InternalItemsQuery filter);
 | 
						|
 | 
						|
    QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetGenres(InternalItemsQuery filter);
 | 
						|
 | 
						|
    QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetMusicGenres(InternalItemsQuery filter);
 | 
						|
 | 
						|
    QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetStudios(InternalItemsQuery filter);
 | 
						|
 | 
						|
    QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetArtists(InternalItemsQuery filter);
 | 
						|
 | 
						|
    QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAlbumArtists(InternalItemsQuery filter);
 | 
						|
 | 
						|
    QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAllArtists(InternalItemsQuery filter);
 | 
						|
 | 
						|
    IReadOnlyList<string> GetMusicGenreNames();
 | 
						|
 | 
						|
    IReadOnlyList<string> GetStudioNames();
 | 
						|
 | 
						|
    IReadOnlyList<string> GetGenreNames();
 | 
						|
 | 
						|
    IReadOnlyList<string> GetAllArtistNames();
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Checks if an item has been persisted to the database.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="id">The id to check.</param>
 | 
						|
    /// <returns>True if the item exists, otherwise false.</returns>
 | 
						|
    Task<bool> ItemExistsAsync(Guid id);
 | 
						|
}
 |