From 9d00b407632789edae73cc89ad41440d5e7d4e02 Mon Sep 17 00:00:00 2001 From: David Rudie Date: Tue, 18 Oct 2022 14:38:09 -0500 Subject: [PATCH] Increased polling interval from default of 1s to 2s to prevent API rate limiting. Track updates will happen between 0 and 2 seconds now. Additionally changed it so that if Snip does get rate limited that it won't create duplicate track entries in the history; it just skips that interval update altogether. --- Snip/Players/Spotify.cs | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/Snip/Players/Spotify.cs b/Snip/Players/Spotify.cs index 9af007f..bcc4461 100644 --- a/Snip/Players/Spotify.cs +++ b/Snip/Players/Spotify.cs @@ -55,7 +55,9 @@ internal sealed class Spotify : MediaPlayer, IDisposable private Timer updateSpotifyTrackInformation; private double updateAuthorizationTokenDefaultInterval = 1000; - private double updateSpotifyTrackInformationDefaultInterval = 1000; + private double updateSpotifyTrackInformationDefaultInterval = 2000; + + private bool rateLimited = false; #endregion @@ -349,11 +351,20 @@ private void UpdateSpotifyTrackInformation_Elapsed(object sender, ElapsedEventAr this.updateSpotifyTrackInformation.Enabled = false; this.updateSpotifyTrackInformation.Interval = updateSpotifyTrackInformationDefaultInterval; this.updateSpotifyTrackInformation.Enabled = true; + this.rateLimited = false; } else { - // If the downloaded JSON is null or empty it's likely because there's no player running - this.ResetSnipSinceSpotifyIsNotPlaying(); + if (this.rateLimited) + { + // If we are rate limited let's just not update or do anything yet. Once there is a successful update + // then the information will update accordingly. + } + else + { + // If the downloaded JSON is null or empty it's likely because there's no player running + this.ResetSnipSinceSpotifyIsNotPlaying(); + } } } @@ -482,6 +493,8 @@ private string DownloadJson(string jsonAddress, SpotifyAddressContactType spotif { if (webHeaderCollection.GetKey(i).ToUpperInvariant() == "RETRY-AFTER") { + this.rateLimited = true; + // Set the timer to the retry seconds. Plus 1 for safety. this.updateSpotifyTrackInformation.Enabled = false; this.updateSpotifyTrackInformation.Interval = (Double.Parse(webHeaderCollection.Get(i) + 1, CultureInfo.InvariantCulture)) * 1000;