1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-12-14 11:23:42 +02:00
Sonarr/NzbDrone.Core/Providers/UpcomingEpisodesProvider.cs

63 lines
2.8 KiB
C#
Raw Normal View History

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