|
|
@ -8,6 +8,7 @@ using Microsoft.Extensions.Logging;
|
|
|
|
using Ombi.Core.Notifications;
|
|
|
|
using Ombi.Core.Notifications;
|
|
|
|
using Ombi.Helpers;
|
|
|
|
using Ombi.Helpers;
|
|
|
|
using Ombi.Notifications.Models;
|
|
|
|
using Ombi.Notifications.Models;
|
|
|
|
|
|
|
|
using Ombi.Schedule.Jobs.Plex.Models;
|
|
|
|
using Ombi.Store.Entities;
|
|
|
|
using Ombi.Store.Entities;
|
|
|
|
using Ombi.Store.Entities.Requests;
|
|
|
|
using Ombi.Store.Entities.Requests;
|
|
|
|
using Ombi.Store.Repository;
|
|
|
|
using Ombi.Store.Repository;
|
|
|
@ -99,6 +100,7 @@ namespace Ombi.Schedule.Jobs.Plex
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var availableEpisode = new List<AvailabilityModel>();
|
|
|
|
foreach (var season in child.SeasonRequests)
|
|
|
|
foreach (var season in child.SeasonRequests)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
foreach (var episode in season.Episodes)
|
|
|
|
foreach (var episode in season.Episodes)
|
|
|
@ -113,19 +115,28 @@ namespace Ombi.Schedule.Jobs.Plex
|
|
|
|
|
|
|
|
|
|
|
|
if (foundEp != null)
|
|
|
|
if (foundEp != null)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
availableEpisode.Add(new AvailabilityModel
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Id = episode.Id
|
|
|
|
|
|
|
|
});
|
|
|
|
episode.Available = true;
|
|
|
|
episode.Available = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//TODO Partial avilability notifications here
|
|
|
|
|
|
|
|
foreach(var c in availableEpisode)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
await _tvRepo.MarkEpisodeAsAvailable(c.Id);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Check to see if all of the episodes in all seasons are available for this request
|
|
|
|
// Check to see if all of the episodes in all seasons are available for this request
|
|
|
|
var allAvailable = child.SeasonRequests.All(x => x.Episodes.All(c => c.Available));
|
|
|
|
var allAvailable = child.SeasonRequests.All(x => x.Episodes.All(c => c.Available));
|
|
|
|
if (allAvailable)
|
|
|
|
if (allAvailable)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_log.LogInformation("[PAC] - Child request {0} is now available, sending notification", $"{child.Title} - {child.Id}");
|
|
|
|
_log.LogInformation("[PAC] - Child request {0} is now available, sending notification", $"{child.Title} - {child.Id}");
|
|
|
|
// We have ful-fulled this request!
|
|
|
|
// We have ful-fulled this request!
|
|
|
|
child.Available = true;
|
|
|
|
await _tvRepo.MarkChildAsAvailable(child.Id);
|
|
|
|
child.MarkedAsAvailable = DateTime.Now;
|
|
|
|
|
|
|
|
await _notificationService.Publish(new NotificationOptions
|
|
|
|
await _notificationService.Publish(new NotificationOptions
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DateTime = DateTime.Now,
|
|
|
|
DateTime = DateTime.Now,
|
|
|
@ -144,9 +155,15 @@ namespace Ombi.Schedule.Jobs.Plex
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Get all non available
|
|
|
|
// Get all non available
|
|
|
|
var movies = _movieRepo.GetAll().Include(x => x.RequestedUser).Where(x => !x.Available);
|
|
|
|
var movies = _movieRepo.GetAll().Include(x => x.RequestedUser).Where(x => !x.Available);
|
|
|
|
|
|
|
|
var itemsForAvailbility = new List<AvailabilityModel>();
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var movie in movies)
|
|
|
|
foreach (var movie in movies)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
if (movie.Available)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
PlexServerContent item = null;
|
|
|
|
PlexServerContent item = null;
|
|
|
|
if (movie.ImdbId.HasValue())
|
|
|
|
if (movie.ImdbId.HasValue())
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -165,23 +182,28 @@ namespace Ombi.Schedule.Jobs.Plex
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
movie.Available = true;
|
|
|
|
|
|
|
|
movie.MarkedAsAvailable = DateTime.Now;
|
|
|
|
|
|
|
|
item.RequestId = movie.Id;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_log.LogInformation("[PAC] - Movie request {0} is now available, sending notification", $"{movie.Title} - {movie.Id}");
|
|
|
|
_log.LogInformation("[PAC] - Movie request {0} is now available, sending notification", $"{movie.Title} - {movie.Id}");
|
|
|
|
|
|
|
|
itemsForAvailbility.Add(new AvailabilityModel
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Id = movie.Id,
|
|
|
|
|
|
|
|
RequestedUser = movie.RequestedUser != null ? movie.RequestedUser.Email : string.Empty
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var i in itemsForAvailbility)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
await _movieRepo.MarkAsAvailable(i.Id);
|
|
|
|
|
|
|
|
|
|
|
|
await _notificationService.Publish(new NotificationOptions
|
|
|
|
await _notificationService.Publish(new NotificationOptions
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DateTime = DateTime.Now,
|
|
|
|
DateTime = DateTime.Now,
|
|
|
|
NotificationType = NotificationType.RequestAvailable,
|
|
|
|
NotificationType = NotificationType.RequestAvailable,
|
|
|
|
RequestId = movie.Id,
|
|
|
|
RequestId = i.Id,
|
|
|
|
RequestType = RequestType.Movie,
|
|
|
|
RequestType = RequestType.Movie,
|
|
|
|
Recipient = movie.RequestedUser != null ? movie.RequestedUser.Email : string.Empty
|
|
|
|
Recipient = i.RequestedUser
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
await _movieRepo.Save();
|
|
|
|
|
|
|
|
await _repo.SaveChangesAsync();
|
|
|
|
await _repo.SaveChangesAsync();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|