public async Task Run([TimerTrigger("0 */1 * * * *")] TimerInfo myTimer, ILogger log) { log.LogInformation($"TweetSchedulerFunction started executionat: { DateTime.Now}"); var config = _configurations.Value.AppSettings; var hashTags = await _hashTagRepository.WhereAsync(p => (!p.IsCurrentlyInQueue && p.LastSyncedDateTime < DateTime.UtcNow.AddMinutes(config.HashtagSyncIntervalInMinutes)) || (p.IsCurrentlyInQueue && p.LastSyncedDateTime < DateTime.UtcNow.AddHours(config.HashtagQueueThresholdIntervalInHours))); foreach (var hashTag in hashTags) { await _serviceBusOperations.SendMessageAsync(hashTag.Id, JsonConvert.SerializeObject(hashTag)); hashTag.IsCurrentlyInQueue = true; await _hashTagRepository.AddOrUpdateAsync(hashTag); } log.LogInformation($"TweetSchedulerFunction completed execution at: { DateTime.Now}"); }
public async Task <IActionResult> Run( [HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequest req, ILogger log) { log.LogInformation("SaveUserPreferences started."); string requestBody = await new StreamReader(req.Body).ReadToEndAsync(); var user = JsonConvert.DeserializeObject <User>(requestBody); var hashTags = user.Hashtags != null?user.Hashtags.Select(p => p.Text).ToList() : new List <string>(); var dbHashtagQuery = await _hashTagRepository.WhereAsync(p => hashTags.Contains(p.Text)); var dbHashtags = dbHashtagQuery.ToList(); foreach (var hashtag in user.Hashtags) { if (dbHashtags.Any(p => p.Text == hashtag.Text)) { continue; } hashtag.IsCurrentlyInQueue = false; hashtag.LastSyncedDateTime = DateTime.UtcNow.AddMinutes(_configurations.Value.AppSettings.HashtagSyncIntervalInMinutes); await _hashTagRepository.AddOrUpdateAsync(hashtag); } var dbUserQuery = await _userRepository.WhereAsync(p => p.UserId == user.UserId); var users = dbUserQuery.ToList(); if (users != null && users.Count() != 0) { user.Id = users.FirstOrDefault().Id; } await _userRepository.AddOrUpdateAsync(user); log.LogInformation("SaveUserPreferences completed."); return(new OkResult()); }