mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-26 08:12:28 -04:00 
			
		
		
		
	* Cleanup some messaging in the scan loop to be more context bearing * Added Response Caching to Series Detail for 1 min, due to the heavy nature of the call. * Refactored code to make it so that processing of series runs sync correctly. Added a log to inform the user of corrupted volume from buggy code in v0.5.6. * Moved folder watching out of experimental * Fixed an issue where empty folders could break the scan loop * Another fix for when dates aren't valid, the scanner wouldn't get the proper min and would throw an exception (develop) * Implemented the ability to edit release year from the UI for a series. * Added a unit test for some new logic * Code smells * Rewrote the handler for suspending watching to be more resilient and ensure no two threads have a race condition. * More error handling for when a ScanFolder is invoked but multiple series belong to that folder, log it to the user and default to a library scan. * ScanSeries now will check for kavitaignores higher than it's own folder and respect library level. * Fixed an issue where image series with a folder name containing the word "folder" could get ignored as it thought the image was a cover image. When a series folder is moved or deleted, skip parent ignore finding. * Removed some old files, added in scanFolder a check if the series found for a folder is in a book library and if so to always do a library scan (as books are often nested into one folder with multiple series). Added some unit tests * Refactored some scan loop logic into ComicInfo, wrote tests and updated some documentation to make the fields more clear. * Added a test for GetLastWriteTime based on recent bug * Cleaned up some redundant code * Fixed a bad merge * Code smells * Removed a package that's no longer used. * Ensure we check against ScanQueue on ScanFolder enqueuing * Documentation and more bullet proofing to ensure Hangfire checks work more as expected
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System.Collections.Generic;
 | |
| using System.Linq;
 | |
| using API.Entities;
 | |
| using API.Parser;
 | |
| 
 | |
| namespace API.Extensions;
 | |
| 
 | |
| public static class ChapterListExtensions
 | |
| {
 | |
|     /// <summary>
 | |
|     /// Returns first chapter in the list with at least one file
 | |
|     /// </summary>
 | |
|     /// <param name="chapters"></param>
 | |
|     /// <returns></returns>
 | |
|     public static Chapter GetFirstChapterWithFiles(this IList<Chapter> chapters)
 | |
|     {
 | |
|         return chapters.FirstOrDefault(c => c.Files.Any());
 | |
|     }
 | |
| 
 | |
|     /// <summary>
 | |
|     /// Gets a single chapter (or null if doesn't exist) where Range matches the info.Chapters property. If the info
 | |
|     /// is <see cref="ParserInfo.IsSpecial"/> then, the filename is used to search against Range or if filename exists within Files of said Chapter.
 | |
|     /// </summary>
 | |
|     /// <param name="chapters"></param>
 | |
|     /// <param name="info"></param>
 | |
|     /// <returns></returns>
 | |
|     public static Chapter GetChapterByRange(this IList<Chapter> chapters, ParserInfo info)
 | |
|     {
 | |
|         var specialTreatment = info.IsSpecialInfo();
 | |
|         return specialTreatment
 | |
|             ? chapters.FirstOrDefault(c => c.Range == info.Filename || (c.Files.Select(f => f.FilePath).Contains(info.FullFilePath)))
 | |
|             : chapters.FirstOrDefault(c => c.Range == info.Chapters);
 | |
|     }
 | |
| 
 | |
|     /// <summary>
 | |
|     /// Returns the minimum Release Year from all Chapters that meets the year requirement (>= 1000)
 | |
|     /// </summary>
 | |
|     /// <param name="chapters"></param>
 | |
|     /// <returns></returns>
 | |
|     public static int MinimumReleaseYear(this IList<Chapter> chapters)
 | |
|     {
 | |
|         return chapters.Select(v => v.ReleaseDate.Year).Where(y => y >= 1000).DefaultIfEmpty().Min();
 | |
|     }
 | |
| }
 |