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;
|
2021-02-01 20:07:53 -05:00
|
|
|
|
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
|
|
|
|
|
{
|
2021-01-18 02:07:09 -05:00
|
|
|
|
private readonly ITwitterTweetsService _twitterTweetsService;
|
2021-02-02 22:49:37 -05:00
|
|
|
|
private readonly ICachedTwitterUserService _twitterUserService;
|
2020-07-18 23:35:19 -04:00
|
|
|
|
private readonly ITwitterUserDal _twitterUserDal;
|
2021-02-01 20:07:53 -05:00
|
|
|
|
private readonly ILogger<RetrieveTweetsProcessor> _logger;
|
2020-07-18 23:35:19 -04:00
|
|
|
|
|
|
|
|
|
#region Ctor
|
2021-02-02 22:49:37 -05:00
|
|
|
|
public RetrieveTweetsProcessor(ITwitterTweetsService twitterTweetsService, ITwitterUserDal twitterUserDal, ICachedTwitterUserService twitterUserService, ILogger<RetrieveTweetsProcessor> logger)
|
2020-07-18 23:35:19 -04:00
|
|
|
|
{
|
2021-01-18 02:07:09 -05:00
|
|
|
|
_twitterTweetsService = twitterTweetsService;
|
2020-07-18 23:35:19 -04:00
|
|
|
|
_twitterUserDal = twitterUserDal;
|
2021-02-01 20:07:53 -05:00
|
|
|
|
_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
|
|
|
|
{
|
2021-02-01 20:07:53 -05:00
|
|
|
|
var tweets = new ExtractedTweet[0];
|
|
|
|
|
|
2021-02-10 01:35:29 -05:00
|
|
|
|
// Don't retrieve TL if protected
|
|
|
|
|
var userView = _twitterUserService.GetUser(user.Acct);
|
|
|
|
|
if (userView == null || userView.Protected) return tweets;
|
|
|
|
|
|
2021-02-01 20:07:53 -05:00
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
if (user.LastTweetPostedId == -1)
|
|
|
|
|
tweets = _twitterTweetsService.GetTimeline(user.Acct, 1);
|
|
|
|
|
else
|
|
|
|
|
tweets = _twitterTweetsService.GetTimeline(user.Acct, 200, user.LastTweetSynchronizedForAllFollowersId);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
{
|
2021-02-02 22:49:37 -05:00
|
|
|
|
_logger.LogError(e, "Error retrieving TL of {Username} from {LastTweetPostedId}, purging user from cache", user.Acct, user.LastTweetPostedId);
|
|
|
|
|
_twitterUserService.PurgeUser(user.Acct);
|
2021-02-01 20:07:53 -05:00
|
|
|
|
}
|
2020-07-18 23:35:19 -04:00
|
|
|
|
|
|
|
|
|
return tweets;
|
2020-07-16 01:19:41 -04:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|