diff --git a/ConfusedPolarBear.Plugin.IntroSkipper/AutoSkip.cs b/ConfusedPolarBear.Plugin.IntroSkipper/AutoSkip.cs
index 305549d..f69a5e3 100644
--- a/ConfusedPolarBear.Plugin.IntroSkipper/AutoSkip.cs
+++ b/ConfusedPolarBear.Plugin.IntroSkipper/AutoSkip.cs
@@ -149,15 +149,16 @@ public class AutoSkip : IServerEntryPoint
}
// Seek is unreliable if called at the very start of an episode.
- var adjustedStart = Math.Max(5, intro.IntroStart);
+ var adjustedStart = Math.Max(5, intro.IntroStart + Plugin.Instance.Configuration.SecondsOfIntroStartToPlay);
+ var adjustedEnd = intro.IntroEnd - Plugin.Instance.Configuration.RemainingSecondsOfIntro;
_logger.LogTrace(
"Playback position is {Position}, intro runs from {Start} to {End}",
position,
adjustedStart,
- intro.IntroEnd);
+ adjustedEnd);
- if (position < adjustedStart || position > intro.IntroEnd)
+ if (position < adjustedStart || position > adjustedEnd)
{
continue;
}
@@ -180,8 +181,6 @@ public class AutoSkip : IServerEntryPoint
_logger.LogDebug("Sending seek command to {Session}", deviceId);
- var introEnd = (long)intro.IntroEnd - Plugin.Instance!.Configuration.SecondsOfIntroToPlay;
-
_sessionManager.SendPlaystateCommand(
session.Id,
session.Id,
@@ -189,7 +188,7 @@ public class AutoSkip : IServerEntryPoint
{
Command = PlaystateCommand.Seek,
ControllingUserId = session.UserId.ToString("N"),
- SeekPositionTicks = introEnd * TimeSpan.TicksPerSecond,
+ SeekPositionTicks = (long)adjustedEnd * TimeSpan.TicksPerSecond,
},
CancellationToken.None);
diff --git a/ConfusedPolarBear.Plugin.IntroSkipper/AutoSkipCredits.cs b/ConfusedPolarBear.Plugin.IntroSkipper/AutoSkipCredits.cs
index 6ac092b..1b09b55 100644
--- a/ConfusedPolarBear.Plugin.IntroSkipper/AutoSkipCredits.cs
+++ b/ConfusedPolarBear.Plugin.IntroSkipper/AutoSkipCredits.cs
@@ -142,16 +142,17 @@ public class AutoSkipCredits : IServerEntryPoint
continue;
}
- // Seek is unreliable if called at the very start of an episode.
- var adjustedStart = Math.Max(5, credit.IntroStart);
+ // Seek is unreliable if called at the very end of an episode.
+ var adjustedStart = credit.IntroStart + Plugin.Instance.Configuration.SecondsOfCreditsStartToPlay;
+ var adjustedEnd = credit.IntroEnd - Plugin.Instance.Configuration.RemainingSecondsOfIntro;
_logger.LogTrace(
"Playback position is {Position}, credits run from {Start} to {End}",
position,
adjustedStart,
- credit.IntroEnd);
+ adjustedEnd);
- if (position < adjustedStart || position > credit.IntroEnd)
+ if (position < adjustedStart || position > adjustedEnd)
{
continue;
}
@@ -174,8 +175,6 @@ public class AutoSkipCredits : IServerEntryPoint
_logger.LogDebug("Sending seek command to {Session}", deviceId);
- var creditEnd = (long)credit.IntroEnd;
-
_sessionManager.SendPlaystateCommand(
session.Id,
session.Id,
@@ -183,7 +182,7 @@ public class AutoSkipCredits : IServerEntryPoint
{
Command = PlaystateCommand.Seek,
ControllingUserId = session.UserId.ToString("N"),
- SeekPositionTicks = creditEnd * TimeSpan.TicksPerSecond,
+ SeekPositionTicks = (long)adjustedEnd * TimeSpan.TicksPerSecond,
},
CancellationToken.None);
diff --git a/ConfusedPolarBear.Plugin.IntroSkipper/Configuration/PluginConfiguration.cs b/ConfusedPolarBear.Plugin.IntroSkipper/Configuration/PluginConfiguration.cs
index 43fd7b0..7169924 100644
--- a/ConfusedPolarBear.Plugin.IntroSkipper/Configuration/PluginConfiguration.cs
+++ b/ConfusedPolarBear.Plugin.IntroSkipper/Configuration/PluginConfiguration.cs
@@ -161,7 +161,17 @@ public class PluginConfiguration : BasePluginConfiguration
///
+