2012-04-20 06:42:13 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using NLog;
|
|
|
|
|
using Ninject;
|
2012-04-21 08:16:15 +00:00
|
|
|
|
using NzbDrone.Core.Repository;
|
2012-04-20 06:42:13 +00:00
|
|
|
|
using NzbDrone.Core.Repository.Search;
|
|
|
|
|
using PetaPoco;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Providers
|
|
|
|
|
{
|
|
|
|
|
public class SearchResultProvider
|
|
|
|
|
{
|
|
|
|
|
private readonly IDatabase _database;
|
|
|
|
|
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
|
|
|
|
|
|
|
|
|
|
[Inject]
|
|
|
|
|
public SearchResultProvider(IDatabase database)
|
|
|
|
|
{
|
|
|
|
|
_database = database;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public SearchResultProvider()
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public virtual void Add(SearchResult searchResult)
|
|
|
|
|
{
|
|
|
|
|
logger.Trace("Adding new search result");
|
2012-04-21 08:16:15 +00:00
|
|
|
|
searchResult.SuccessfulDownload = searchResult.SearchResultItems.Any(s => s.Success);
|
2012-04-20 06:42:13 +00:00
|
|
|
|
var id = Convert.ToInt32(_database.Insert(searchResult));
|
|
|
|
|
|
2012-04-21 08:16:15 +00:00
|
|
|
|
searchResult.SearchResultItems.ForEach(s => s.SearchResultId = id);
|
2012-04-20 06:42:13 +00:00
|
|
|
|
logger.Trace("Adding search result items");
|
|
|
|
|
_database.InsertMany(searchResult.SearchResultItems);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public virtual void Delete(int id)
|
|
|
|
|
{
|
|
|
|
|
logger.Trace("Deleting search result items attached to: {0}", id);
|
|
|
|
|
_database.Execute("DELETE FROM SearchResultItems WHERE SearchResultId = @0", id);
|
|
|
|
|
|
|
|
|
|
logger.Trace("Deleting search result: {0}", id);
|
|
|
|
|
_database.Delete<SearchResult>(id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public virtual List<SearchResult> AllSearchResults()
|
|
|
|
|
{
|
2012-04-21 08:16:15 +00:00
|
|
|
|
var sql = @"SELECT SearchResults.Id, SearchResults.SeriesId, SearchResults.SeasonNumber,
|
|
|
|
|
SearchResults.EpisodeId, SearchResults.SearchTime,
|
|
|
|
|
Series.Title as SeriesTitle, Series.IsDaily,
|
|
|
|
|
Episodes.EpisodeNumber, Episodes.SeasonNumber, Episodes.Title as EpisodeTitle,
|
|
|
|
|
Episodes.AirDate,
|
|
|
|
|
Count(SearchResultItems.Id) as TotalItems,
|
|
|
|
|
SUM(CASE WHEN SearchResultItems.Success = 1 THEN 1 ELSE 0 END) as Successes
|
|
|
|
|
FROM SearchResults
|
|
|
|
|
INNER JOIN Series
|
|
|
|
|
ON Series.SeriesId = SearchResults.SeriesId
|
|
|
|
|
LEFT JOIN Episodes
|
|
|
|
|
ON Episodes.EpisodeId = SearchResults.EpisodeId
|
|
|
|
|
INNER JOIN SearchResultItems
|
|
|
|
|
ON SearchResultItems.SearchResultId = SearchResults.Id
|
|
|
|
|
GROUP BY SearchResults.Id, SearchResults.SeriesId, SearchResults.SeasonNumber,
|
|
|
|
|
SearchResults.EpisodeId, SearchResults.SearchTime,
|
|
|
|
|
Series.Title, Series.IsDaily,
|
|
|
|
|
Episodes.EpisodeNumber, Episodes.SeasonNumber, Episodes.Title,
|
|
|
|
|
Episodes.AirDate";
|
|
|
|
|
|
|
|
|
|
return _database.Fetch<SearchResult>(sql);
|
2012-04-20 06:42:13 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public virtual SearchResult GetSearchResult(int id)
|
|
|
|
|
{
|
|
|
|
|
var result = _database.Single<SearchResult>(id);
|
|
|
|
|
result.SearchResultItems = _database.Fetch<SearchResultItem>("WHERE SearchResultId = @0", id);
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|