using System.Diagnostics; using MediaBrowser.Model.Plugins; namespace ConfusedPolarBear.Plugin.IntroSkipper.Configuration; /// /// Plugin configuration. /// public class PluginConfiguration : BasePluginConfiguration { /// /// Initializes a new instance of the class. /// public PluginConfiguration() { } // ===== Analysis settings ===== /// /// Gets or sets the max degree of parallelism used when analyzing episodes. /// public int MaxParallelism { get; set; } = 2; /// /// Gets or sets the comma separated list of library names to analyze. If empty, all libraries will be analyzed. /// public string SelectedLibraries { get; set; } = string.Empty; /// /// Gets or sets a value indicating whether to scan for intros during a scheduled task. /// public bool AutoDetectIntros { get; set; } = false; /// /// Gets or sets a value indicating whether to scan for credits during a scheduled task. /// public bool AutoDetectCredits { get; set; } = false; /// /// Gets or sets a value indicating whether to analyze season 0. /// public bool AnalyzeSeasonZero { get; set; } = false; /// /// Gets or sets a value indicating whether the episode's fingerprint should be cached to the filesystem. /// public bool CacheFingerprints { get; set; } = true; /// /// Gets or sets a value indicating whether analysis will use Chromaprint to determine fingerprints. /// public bool UseChromaprint { get; set; } = true; // ===== EDL handling ===== /// /// Gets or sets a value indicating the action to write to created EDL files. /// public EdlAction EdlAction { get; set; } = EdlAction.None; /// /// Gets or sets a value indicating whether to regenerate all EDL files during the next scan. /// By default, EDL files are only written for a season if the season had at least one newly analyzed episode. /// If this is set, all EDL files will be regenerated and overwrite any existing EDL file. /// public bool RegenerateEdlFiles { get; set; } = false; // ===== Custom analysis settings ===== /// /// Gets or sets the percentage of each episode's audio track to analyze. /// public int AnalysisPercent { get; set; } = 25; /// /// Gets or sets the upper limit (in minutes) on the length of each episode's audio track that will be analyzed. /// public int AnalysisLengthLimit { get; set; } = 10; /// /// Gets or sets the minimum length of similar audio that will be considered an introduction. /// public int MinimumIntroDuration { get; set; } = 15; /// /// Gets or sets the maximum length of similar audio that will be considered an introduction. /// public int MaximumIntroDuration { get; set; } = 120; /// /// Gets or sets the minimum length of similar audio that will be considered ending credits. /// public int MinimumCreditsDuration { get; set; } = 15; /// /// Gets or sets the upper limit (in seconds) on the length of each episode's audio track that will be analyzed when searching for ending credits. /// public int MaximumEpisodeCreditsDuration { get; set; } = 240; /// /// Gets or sets the minimum percentage of a frame that must consist of black pixels before it is considered a black frame. /// public int BlackFrameMinimumPercentage { get; set; } = 85; /// /// Gets or sets the regular expression used to detect introduction chapters. /// public string ChapterAnalyzerIntroductionPattern { get; set; } = @"(^|\s)(Intro|Introduction|OP|Opening)(\s|$)"; /// /// Gets or sets the regular expression used to detect ending credit chapters. /// public string ChapterAnalyzerEndCreditsPattern { get; set; } = @"(^|\s)(Credits?|ED|Ending)(\s|$)"; // ===== Playback settings ===== /// /// Gets or sets a value indicating whether to show the skip intro button. /// public bool SkipButtonVisible { get; set; } = true; /// /// Gets or sets a value indicating whether introductions should be automatically skipped. /// public bool AutoSkip { get; set; } /// /// Gets or sets a value indicating whether credits should be automatically skipped. /// public bool AutoSkipCredits { get; set; } /// /// Gets or sets the seconds before the intro starts to show the skip prompt at. /// public int ShowPromptAdjustment { get; set; } = 5; /// /// Gets or sets the seconds after the intro starts to hide the skip prompt at. /// public int HidePromptAdjustment { get; set; } = 10; /// /// Gets or sets a value indicating whether the introduction in the first episode of a season should be ignored. /// public bool SkipFirstEpisode { get; set; } = true; /// /// Gets or sets a value indicating whether the skip button should be displayed for the duration of the intro. /// public bool PersistSkipButton { get; set; } = true; /// /// Gets or sets the amount of intro to play (in seconds). /// public int SecondsOfIntroToPlay { get; set; } = 2; // ===== Internal algorithm settings ===== /// /// Gets or sets the maximum number of bits (out of 32 total) that can be different between two Chromaprint points before they are considered dissimilar. /// Defaults to 6 (81% similar). /// public int MaximumFingerprintPointDifferences { get; set; } = 6; /// /// Gets or sets the maximum number of seconds that can pass between two similar fingerprint points before a new time range is started. /// public double MaximumTimeSkip { get; set; } = 3.5; /// /// Gets or sets the amount to shift inverted indexes by. /// public int InvertedIndexShift { get; set; } = 2; /// /// Gets or sets the maximum amount of noise (in dB) that is considered silent. /// Lowering this number will increase the filter's sensitivity to noise. /// public int SilenceDetectionMaximumNoise { get; set; } = -50; /// /// Gets or sets the minimum duration of audio (in seconds) that is considered silent. /// public double SilenceDetectionMinimumDuration { get; set; } = 0.33; // ===== Localization support ===== /// /// Gets or sets the text to display in the skip button in introduction mode. /// public string SkipButtonIntroText { get; set; } = "Skip Intro"; /// /// Gets or sets the text to display in the skip button in end credits mode. /// public string SkipButtonEndCreditsText { get; set; } = "Next"; /// /// Gets or sets the notification text sent after automatically skipping an introduction. /// public string AutoSkipNotificationText { get; set; } = "Intro skipped"; /// /// Gets or sets the notification text sent after automatically skipping credits. /// public string AutoSkipCreditsNotificationText { get; set; } = "Intro skipped"; /// /// Gets or sets the number of threads for an ffmpeg process. /// public int ProcessThreads { get; set; } = 0; /// /// Gets or sets the relative priority for an ffmpeg process. /// public ProcessPriorityClass ProcessPriority { get; set; } = ProcessPriorityClass.BelowNormal; }