mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-11-03 19:17:05 -05:00 
			
		
		
		
	* Refactored Library Watcher to use Hangfire under the hood. * Support .kavitaignore at root level. * Refactored a lot of the library watching code to process faster and handle when FileSystemWatcher runs out of internal buffer space. It's still not perfect, but good enough for basic use. * Make folder watching as experimental and default it to off by default. * Revert #1479 * Tweaked the messaging for OPDS to remove a note about download role. Moved some code closer to where it's used. * Cleaned up how the events widget reports * Fixed a null issue when deleting series in the UI * Cleaned up some debug code * Added more information for when we skip a scan * Cleaned up some logging messages in CoverGen tasks * More log message tweaks * Added some debug to help identify a rare issue * Fixed a bug where save bookmarks as webp could get reset to false when saving other server settings * Updated some documentation on library watcher. * Make LibraryWatcher fire every 5 mins
		
			
				
	
	
		
			101 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using API.Data.Metadata;
 | 
						|
using API.Entities.Enums;
 | 
						|
 | 
						|
namespace API.Parser
 | 
						|
{
 | 
						|
    /// <summary>
 | 
						|
    /// This represents all parsed information from a single file
 | 
						|
    /// </summary>
 | 
						|
    public class ParserInfo
 | 
						|
    {
 | 
						|
        /// <summary>
 | 
						|
        /// Represents the parsed chapters from a file. By default, will be 0 which means nothing could be parsed.
 | 
						|
        /// <remarks>The chapters can only be a single float or a range of float ie) 1-2. Mainly floats should be multiples of 0.5 representing specials</remarks>
 | 
						|
        /// </summary>
 | 
						|
        public string Chapters { get; set; } = "";
 | 
						|
        /// <summary>
 | 
						|
        /// Represents the parsed series from the file or folder
 | 
						|
        /// </summary>
 | 
						|
        public string Series { get; set; } = string.Empty;
 | 
						|
        /// <summary>
 | 
						|
        /// This can be filled in from ComicInfo.xml/Epub during scanning. Will update the SortName field on <see cref="Entities.Series"/>
 | 
						|
        /// </summary>
 | 
						|
        public string SeriesSort { get; set; } = string.Empty;
 | 
						|
        /// <summary>
 | 
						|
        /// This can be filled in from ComicInfo.xml/Epub during scanning. Will update the LocalizedName field on <see cref="Entities.Series"/>
 | 
						|
        /// </summary>
 | 
						|
        public string LocalizedSeries { get; set; } = string.Empty;
 | 
						|
        /// <summary>
 | 
						|
        /// Represents the parsed volumes from a file. By default, will be 0 which means that nothing could be parsed.
 | 
						|
        /// If Volumes is 0 and Chapters is 0, the file is a special. If Chapters is non-zero, then no volume could be parsed.
 | 
						|
        /// <example>Beastars Vol 3-4 will map to "3-4"</example>
 | 
						|
        /// <remarks>The volumes can only be a single int or a range of ints ie) 1-2. Float based volumes are not supported.</remarks>
 | 
						|
        /// </summary>
 | 
						|
        public string Volumes { get; set; } = "";
 | 
						|
        /// <summary>
 | 
						|
        /// Filename of the underlying file
 | 
						|
        /// <example>Beastars v01 (digital).cbz</example>
 | 
						|
        /// </summary>
 | 
						|
        public string Filename { get; init; } = "";
 | 
						|
        /// <summary>
 | 
						|
        /// Full filepath of the underlying file
 | 
						|
        /// <example>C:/Manga/Beastars v01 (digital).cbz</example>
 | 
						|
        /// </summary>
 | 
						|
        public string FullFilePath { get; set; } = "";
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// <see cref="MangaFormat"/> that represents the type of the file
 | 
						|
        /// <remarks>Mainly used to show in the UI and so caching service knows how to cache for reading.</remarks>
 | 
						|
        /// </summary>
 | 
						|
        public MangaFormat Format { get; set; } = MangaFormat.Unknown;
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// This can potentially story things like "Omnibus, Color, Full Contact Edition, Extra, Final, etc"
 | 
						|
        /// </summary>
 | 
						|
        /// <remarks>Not Used in Database</remarks>
 | 
						|
        public string Edition { get; set; } = "";
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// If the file contains no volume/chapter information or contains Special Keywords <see cref="Parser.MangaSpecialRegex"/>
 | 
						|
        /// </summary>
 | 
						|
        public bool IsSpecial { get; set; }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Used for specials or books, stores what the UI should show.
 | 
						|
        /// <remarks>Manga does not use this field</remarks>
 | 
						|
        /// </summary>
 | 
						|
        public string Title { get; set; } = string.Empty;
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// If the ParserInfo has the IsSpecial tag or both volumes and chapters are default aka 0
 | 
						|
        /// </summary>
 | 
						|
        /// <returns></returns>
 | 
						|
        public bool IsSpecialInfo()
 | 
						|
        {
 | 
						|
            return (IsSpecial || (Volumes == "0" && Chapters == "0"));
 | 
						|
        }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// This will contain any EXTRA comicInfo information parsed from the epub or archive. If there is an archive with comicInfo.xml AND it contains
 | 
						|
        /// series, volume information, that will override what we parsed.
 | 
						|
        /// </summary>
 | 
						|
        public ComicInfo ComicInfo { get; set; }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Merges non empty/null properties from info2 into this entity.
 | 
						|
        /// </summary>
 | 
						|
        /// <remarks>This does not merge ComicInfo as they should always be the same</remarks>
 | 
						|
        /// <param name="info2"></param>
 | 
						|
        public void Merge(ParserInfo info2)
 | 
						|
        {
 | 
						|
            if (info2 == null) return;
 | 
						|
            Chapters = string.IsNullOrEmpty(Chapters) || Chapters == "0" ? info2.Chapters: Chapters;
 | 
						|
            Volumes = string.IsNullOrEmpty(Volumes) || Volumes == "0" ? info2.Volumes : Volumes;
 | 
						|
            Edition = string.IsNullOrEmpty(Edition) ? info2.Edition : Edition;
 | 
						|
            Title = string.IsNullOrEmpty(Title) ? info2.Title : Title;
 | 
						|
            Series = string.IsNullOrEmpty(Series) ? info2.Series : Series;
 | 
						|
            IsSpecial = IsSpecial || info2.IsSpecial;
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |