cloutier--bird.makeup/src/BirdsiteLive.Pipeline/Processors/RetrieveTweetsProcessor.cs

92 lines
3.4 KiB
C#
Raw Normal View History

2021-01-22 21:23:27 -05:00
using System;
using System.Collections.Generic;
2020-07-18 23:35:19 -04:00
using System.Linq;
using System.Threading;
2020-07-16 01:19:41 -04:00
using System.Threading.Tasks;
2020-07-18 23:35:19 -04:00
using BirdsiteLive.DAL.Contracts;
2020-07-16 01:19:41 -04:00
using BirdsiteLive.DAL.Models;
using BirdsiteLive.Pipeline.Contracts;
using BirdsiteLive.Pipeline.Models;
2020-07-18 23:35:19 -04:00
using BirdsiteLive.Twitter;
2020-07-22 20:19:40 -04:00
using BirdsiteLive.Twitter.Models;
using Microsoft.Extensions.Logging;
2020-07-18 23:35:19 -04:00
using Tweetinvi.Models;
2020-07-16 01:19:41 -04:00
namespace BirdsiteLive.Pipeline.Processors
{
public class RetrieveTweetsProcessor : IRetrieveTweetsProcessor
{
private readonly ITwitterTweetsService _twitterTweetsService;
private readonly ITwitterUserService _twitterUserService;
2020-07-18 23:35:19 -04:00
private readonly ITwitterUserDal _twitterUserDal;
private readonly ILogger<RetrieveTweetsProcessor> _logger;
2020-07-18 23:35:19 -04:00
#region Ctor
public RetrieveTweetsProcessor(ITwitterTweetsService twitterTweetsService, ITwitterUserDal twitterUserDal, ITwitterUserService twitterUserService, ILogger<RetrieveTweetsProcessor> logger)
2020-07-18 23:35:19 -04:00
{
_twitterTweetsService = twitterTweetsService;
2020-07-18 23:35:19 -04:00
_twitterUserDal = twitterUserDal;
_twitterUserService = twitterUserService;
_logger = logger;
2020-07-18 23:35:19 -04:00
}
#endregion
public async Task<UserWithTweetsToSync[]> ProcessAsync(SyncTwitterUser[] syncTwitterUsers, CancellationToken ct)
{
var usersWtTweets = new List<UserWithTweetsToSync>();
//TODO multithread this
foreach (var user in syncTwitterUsers)
{
var tweets = RetrieveNewTweets(user);
if (tweets.Length > 0 && user.LastTweetPostedId != -1)
{
var userWtTweets = new UserWithTweetsToSync
{
User = user,
Tweets = tweets
};
usersWtTweets.Add(userWtTweets);
}
else if (tweets.Length > 0 && user.LastTweetPostedId == -1)
{
2020-10-10 18:35:23 -04:00
var tweetId = tweets.Last().Id;
2021-01-22 21:23:27 -05:00
var now = DateTime.UtcNow;
await _twitterUserDal.UpdateTwitterUserAsync(user.Id, tweetId, tweetId, now);
2020-07-18 23:35:19 -04:00
}
2021-01-23 18:20:13 -05:00
else
{
var now = DateTime.UtcNow;
await _twitterUserDal.UpdateTwitterUserAsync(user.Id, user.LastTweetPostedId, user.LastTweetSynchronizedForAllFollowersId, now);
}
2020-07-18 23:35:19 -04:00
}
return usersWtTweets.ToArray();
}
2020-07-22 20:19:40 -04:00
private ExtractedTweet[] RetrieveNewTweets(SyncTwitterUser user)
2020-07-16 01:19:41 -04:00
{
var tweets = new ExtractedTweet[0];
try
{
if (user.LastTweetPostedId == -1)
tweets = _twitterTweetsService.GetTimeline(user.Acct, 1);
else
tweets = _twitterTweetsService.GetTimeline(user.Acct, 200, user.LastTweetSynchronizedForAllFollowersId);
}
catch (Exception e)
{
_logger.LogError(e, "Error retrieving TL of {Username} from {LastTweetPostedId}", user.Acct, user.LastTweetPostedId);
if (_twitterUserService is CachedTwitterUserService service)
{
_logger.LogInformation("Purge {Username} from cache", user.Acct);
service.PurgeUser(user.Acct);
}
}
2020-07-18 23:35:19 -04:00
return tweets;
2020-07-16 01:19:41 -04:00
}
}
}