From 873e847f080e7de3d7324197145d66e0a47aa70c Mon Sep 17 00:00:00 2001 From: Nicolas Constant Date: Mon, 25 Jan 2021 23:40:30 -0500 Subject: [PATCH 1/2] better twitter error handling --- .../TwitterTweetsService.cs | 65 ++++++++++++------- .../TwitterUserService.cs | 28 +++++--- 2 files changed, 63 insertions(+), 30 deletions(-) diff --git a/src/BirdsiteLive.Twitter/TwitterTweetsService.cs b/src/BirdsiteLive.Twitter/TwitterTweetsService.cs index 0f82429..dd9e29e 100644 --- a/src/BirdsiteLive.Twitter/TwitterTweetsService.cs +++ b/src/BirdsiteLive.Twitter/TwitterTweetsService.cs @@ -1,9 +1,11 @@ -using System.Collections.Generic; +using System; +using System.Collections.Generic; using System.Linq; using BirdsiteLive.Common.Settings; using BirdsiteLive.Statistics.Domain; using BirdsiteLive.Twitter.Extractors; using BirdsiteLive.Twitter.Models; +using Microsoft.Extensions.Logging; using Tweetinvi; using Tweetinvi.Models; using Tweetinvi.Parameters; @@ -22,50 +24,69 @@ public class TwitterTweetsService : ITwitterTweetsService private readonly ITweetExtractor _tweetExtractor; private readonly ITwitterStatisticsHandler _statisticsHandler; private readonly ITwitterUserService _twitterUserService; + private readonly ILogger _logger; #region Ctor - public TwitterTweetsService(TwitterSettings settings, ITweetExtractor tweetExtractor, ITwitterStatisticsHandler statisticsHandler, ITwitterUserService twitterUserService) + public TwitterTweetsService(TwitterSettings settings, ITweetExtractor tweetExtractor, ITwitterStatisticsHandler statisticsHandler, ITwitterUserService twitterUserService, ILogger logger) { _settings = settings; _tweetExtractor = tweetExtractor; _statisticsHandler = statisticsHandler; _twitterUserService = twitterUserService; + _logger = logger; Auth.SetApplicationOnlyCredentials(_settings.ConsumerKey, _settings.ConsumerSecret, true); + ExceptionHandler.SwallowWebExceptions = false; } #endregion - + public ExtractedTweet GetTweet(long statusId) { - TweetinviConfig.CurrentThreadSettings.TweetMode = TweetMode.Extended; - var tweet = Tweet.GetTweet(statusId); - _statisticsHandler.CalledTweetApi(); - if (tweet == null) return null; //TODO: test this - return _tweetExtractor.Extract(tweet); + try + { + TweetinviConfig.CurrentThreadSettings.TweetMode = TweetMode.Extended; + var tweet = Tweet.GetTweet(statusId); + _statisticsHandler.CalledTweetApi(); + if (tweet == null) return null; //TODO: test this + return _tweetExtractor.Extract(tweet); + } + catch (Exception e) + { + _logger.LogError(e, "Error retrieving tweet {TweetId}", statusId); + return null; + } } public ExtractedTweet[] GetTimeline(string username, int nberTweets, long fromTweetId = -1) { TweetinviConfig.CurrentThreadSettings.TweetMode = TweetMode.Extended; - + var user = _twitterUserService.GetUser(username); var tweets = new List(); - if (fromTweetId == -1) + + try { - var timeline = Timeline.GetUserTimeline(user.Id, nberTweets); - _statisticsHandler.CalledTimelineApi(); - if (timeline != null) tweets.AddRange(timeline); + if (fromTweetId == -1) + { + var timeline = Timeline.GetUserTimeline(user.Id, nberTweets); + _statisticsHandler.CalledTimelineApi(); + if (timeline != null) tweets.AddRange(timeline); + } + else + { + var timelineRequestParameters = new UserTimelineParameters + { + SinceId = fromTweetId, + MaximumNumberOfTweetsToRetrieve = nberTweets + }; + var timeline = Timeline.GetUserTimeline(user.Id, timelineRequestParameters); + _statisticsHandler.CalledTimelineApi(); + if (timeline != null) tweets.AddRange(timeline); + } } - else + catch (Exception e) { - var timelineRequestParameters = new UserTimelineParameters - { - SinceId = fromTweetId, - MaximumNumberOfTweetsToRetrieve = nberTweets - }; - var timeline = Timeline.GetUserTimeline(user.Id, timelineRequestParameters); - _statisticsHandler.CalledTimelineApi(); - if (timeline != null) tweets.AddRange(timeline); + _logger.LogError(e, "Error retrieving timeline from {Username}, from {TweetId}", username, fromTweetId); } return tweets.Select(_tweetExtractor.Extract).ToArray(); diff --git a/src/BirdsiteLive.Twitter/TwitterUserService.cs b/src/BirdsiteLive.Twitter/TwitterUserService.cs index 01a70bb..69ecc45 100644 --- a/src/BirdsiteLive.Twitter/TwitterUserService.cs +++ b/src/BirdsiteLive.Twitter/TwitterUserService.cs @@ -1,9 +1,11 @@ -using System.Linq; +using System; +using System.Linq; using BirdsiteLive.Common.Settings; using BirdsiteLive.Statistics.Domain; -using BirdsiteLive.Twitter.Extractors; using BirdsiteLive.Twitter.Models; +using Microsoft.Extensions.Logging; using Tweetinvi; +using Tweetinvi.Models; namespace BirdsiteLive.Twitter { @@ -15,24 +17,34 @@ public interface ITwitterUserService public class TwitterUserService : ITwitterUserService { private readonly TwitterSettings _settings; - private readonly ITweetExtractor _tweetExtractor; private readonly ITwitterStatisticsHandler _statisticsHandler; + private readonly ILogger _logger; #region Ctor - public TwitterUserService(TwitterSettings settings, ITweetExtractor tweetExtractor, ITwitterStatisticsHandler statisticsHandler) + public TwitterUserService(TwitterSettings settings, ITwitterStatisticsHandler statisticsHandler, ILogger logger) { _settings = settings; - _tweetExtractor = tweetExtractor; _statisticsHandler = statisticsHandler; + _logger = logger; Auth.SetApplicationOnlyCredentials(_settings.ConsumerKey, _settings.ConsumerSecret, true); + ExceptionHandler.SwallowWebExceptions = false; } #endregion public TwitterUser GetUser(string username) { - var user = User.GetUserFromScreenName(username); - _statisticsHandler.CalledUserApi(); - if (user == null) return null; + IUser user; + try + { + user = User.GetUserFromScreenName(username); + _statisticsHandler.CalledUserApi(); + if (user == null) return null; + } + catch (Exception e) + { + _logger.LogError(e, "Error retrieving user {Username}", username); + return null; + } // Expand URLs var description = user.Description; From d0a3b3beabb157937b646a14244a3fe271fffd2b Mon Sep 17 00:00:00 2001 From: Nicolas Constant Date: Mon, 25 Jan 2021 23:40:44 -0500 Subject: [PATCH 2/2] road to 0.11.1 --- src/BirdsiteLive/BirdsiteLive.csproj | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/BirdsiteLive/BirdsiteLive.csproj b/src/BirdsiteLive/BirdsiteLive.csproj index df9c11b..e09572c 100644 --- a/src/BirdsiteLive/BirdsiteLive.csproj +++ b/src/BirdsiteLive/BirdsiteLive.csproj @@ -4,7 +4,7 @@ netcoreapp3.1 d21486de-a812-47eb-a419-05682bb68856 Linux - 0.11.0 + 0.11.1