mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-26 00:02:29 -04:00 
			
		
		
		
	* Readme refactored to be more clean and clear, taking inspiration from wiki.js's readme. * Initial backend for Collections and basic metadata implemented. * More build flavors for Raspberry Pi users and updated Install since we don't need users to set their own JWT Token Key. Update a typo in appsettings.json file for prod. * Fixed #224. Sort before getting a First?Last() chatper * The rough ability to add and get series metadata and tags. * Fix a bug on getting metadata for when it doesn't exist. * Fixed a bug where flattening directories with some unique filenames could cause reading order of images to be out of order. * Added a seed code to ensure all series have SeriesMetdata * Ensure all instances of opening an epub is using "using" so we don't lock the file. When we have a malformed html file, log the issues and inform the user we can't open the file. * Book reader now handles @Import "" statements in CSS and inlines the css into css file that references them. This allows for them to be scoped. In addition, if the html or body tag had classes, we now send back a single div with those classes. * Fixed GetSeriesDtoForCollectionAsync which was not properly returning series * Implemented cover image for collection tag. Fixed an issue in metadata update call. * Add check for user access when resolving series for a collection tag. When asking for all tags, if the user is not an admin, only give promotoed tags back. * Implemented updateTag api * Implemented the ability to update series the tags have access to. * Cleanup, sorting, and null check * More sorting changes * Ensure we can delete tags when editing a series tags * Fix order of update to make sure a tag is properly deleted * Code smells
		
			
				
	
	
		
			65 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System.Collections.Generic;
 | |
| using System.Threading.Tasks;
 | |
| using API.DTOs;
 | |
| using API.Entities;
 | |
| using API.Helpers;
 | |
| 
 | |
| namespace API.Interfaces
 | |
| {
 | |
|     public interface ISeriesRepository
 | |
|     {
 | |
|         void Add(Series series);
 | |
|         void Update(Series series);
 | |
|         Task<Series> GetSeriesByNameAsync(string name);
 | |
|         Task<bool> DoesSeriesNameExistInLibrary(string name);
 | |
|         Series GetSeriesByName(string name);
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Adds user information like progress, ratings, etc
 | |
|         /// </summary>
 | |
|         /// <param name="libraryId"></param>
 | |
|         /// <param name="userId"></param>
 | |
|         /// <param name="userParams"></param>
 | |
|         /// <returns></returns>
 | |
|         Task<PagedList<SeriesDto>> GetSeriesDtoForLibraryIdAsync(int libraryId, int userId, UserParams userParams);
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Does not add user information like progress, ratings, etc.
 | |
|         /// </summary>
 | |
|         /// <param name="libraryIds"></param>
 | |
|         /// <param name="searchQuery">Series name to search for</param>
 | |
|         /// <returns></returns>
 | |
|         Task<IEnumerable<SearchResultDto>> SearchSeries(int[] libraryIds, string searchQuery);
 | |
|         Task<IEnumerable<Series>> GetSeriesForLibraryIdAsync(int libraryId);
 | |
|         Task<IEnumerable<VolumeDto>> GetVolumesDtoAsync(int seriesId, int userId);
 | |
|         Task<IEnumerable<Volume>> GetVolumes(int seriesId);
 | |
|         Task<SeriesDto> GetSeriesDtoByIdAsync(int seriesId, int userId);
 | |
|         Task<Volume> GetVolumeAsync(int volumeId);
 | |
|         Task<VolumeDto> GetVolumeDtoAsync(int volumeId, int userId);
 | |
|         /// <summary>
 | |
|         /// A fast lookup of just the volume information with no tracking.
 | |
|         /// </summary>
 | |
|         /// <param name="volumeId"></param>
 | |
|         /// <returns></returns>
 | |
|         Task<VolumeDto> GetVolumeDtoAsync(int volumeId);
 | |
|         Task<IEnumerable<Volume>> GetVolumesForSeriesAsync(int[] seriesIds);
 | |
|         Task<bool> DeleteSeriesAsync(int seriesId);
 | |
|         Task<Volume> GetVolumeByIdAsync(int volumeId);
 | |
|         Task<Series> GetSeriesByIdAsync(int seriesId);
 | |
|         Task<int[]> GetChapterIdsForSeriesAsync(int[] seriesIds);
 | |
|         /// <summary>
 | |
|         /// Used to add Progress/Rating information to series list.
 | |
|         /// </summary>
 | |
|         /// <param name="userId"></param>
 | |
|         /// <param name="series"></param>
 | |
|         /// <returns></returns>
 | |
|         Task AddSeriesModifiers(int userId, List<SeriesDto> series);
 | |
| 
 | |
|         Task<byte[]> GetVolumeCoverImageAsync(int volumeId);
 | |
|         Task<byte[]> GetSeriesCoverImageAsync(int seriesId);
 | |
|         Task<IEnumerable<SeriesDto>> GetInProgress(int userId, int libraryId, int limit);
 | |
|         Task<IEnumerable<SeriesDto>> GetRecentlyAdded(int userId, int libraryId, int limit);
 | |
|         Task<SeriesMetadataDto> GetSeriesMetadata(int seriesId);
 | |
|         Task<PagedList<SeriesDto>> GetSeriesDtoForCollectionAsync(int collectionId, int userId, UserParams userParams);
 | |
|     }
 | |
| } |