1
0
Fork 0
mirror of https://github.com/lidarr/Lidarr synced 2025-01-19 13:20:28 +00:00
Lidarr/NzbDrone.Core/Providers/UpcomingEpisodesProvider.cs

50 lines
1.6 KiB
C#
Raw Normal View History

2011-03-23 07:06:22 +00:00
using System;
using System.Collections.Generic;
using System.Linq;
using Ninject;
2011-03-23 07:06:22 +00:00
using NzbDrone.Core.Model;
using NzbDrone.Core.Repository;
using PetaPoco;
2011-03-23 07:06:22 +00:00
namespace NzbDrone.Core.Providers
{
2011-04-08 15:18:01 +00:00
public class UpcomingEpisodesProvider
2011-03-23 07:06:22 +00:00
{
private readonly IDatabase _database;
2011-03-23 07:06:22 +00:00
[Inject]
public UpcomingEpisodesProvider(IDatabase database)
2011-03-23 07:06:22 +00:00
{
_database = database;
2011-03-23 07:06:22 +00:00
}
2011-04-08 15:18:01 +00:00
public virtual List<Episode> Yesterday()
2011-03-23 07:06:22 +00:00
{
return RecentEpisodes().Where(c => c.AirDate.Value.Date == DateTime.Now.Date.AddDays(-1)).ToList();
2011-03-23 07:06:22 +00:00
}
2011-04-08 15:18:01 +00:00
public virtual List<Episode> Today()
2011-03-23 07:06:22 +00:00
{
return RecentEpisodes().Where(c => c.AirDate.Value.Date == DateTime.Now.Date).ToList();
2011-03-23 07:06:22 +00:00
}
public virtual List<Episode> Tomorrow()
{
return RecentEpisodes().Where(c => c.AirDate.Value.Date == DateTime.Now.Date.AddDays(1)).ToList();
}
2011-04-08 15:18:01 +00:00
public virtual List<Episode> Week()
{
return RecentEpisodes().Where(c => c.AirDate >= DateTime.Today.AddDays(2).Date).ToList();
}
private List<Episode> RecentEpisodes()
2011-03-23 07:06:22 +00:00
{
return _database.Fetch<Episode, Series>(@"SELECT * FROM Episodes
INNER JOIN Series ON Episodes.SeriesId = Series.SeriesId
WHERE Series.Monitored = 1 AND Ignored = 0 AND AirDate BETWEEN @0 AND @1"
,DateTime.Today.AddDays(-1).Date, DateTime.Today.AddDays(8).Date);
2011-03-23 07:06:22 +00:00
}
}
2011-04-10 02:44:01 +00:00
}