@ -26,7 +26,6 @@
# endregion
# endregion
using System ;
using System ;
using System.Collections.Generic ;
using System.Collections.Generic ;
using System.Linq ;
using Nancy ;
using Nancy ;
using Nancy.Responses.Negotiation ;
using Nancy.Responses.Negotiation ;
@ -37,19 +36,24 @@ using PlexRequests.Core;
using PlexRequests.Core.SettingModels ;
using PlexRequests.Core.SettingModels ;
using PlexRequests.Helpers ;
using PlexRequests.Helpers ;
using PlexRequests.Store ;
using PlexRequests.Store ;
using PlexRequests.UI.Jobs ;
using PlexRequests.UI.Models ;
using PlexRequests.UI.Models ;
namespace PlexRequests.UI.Modules
namespace PlexRequests.UI.Modules
{
{
public class SearchModule : BaseModule
public class SearchModule : BaseModule
{
{
public SearchModule ( ICacheProvider cache , ISettingsService < CouchPotatoSettings > cpSettings , ISettingsService < PlexRequestSettings > prSettings ) : base ( "search" )
public SearchModule ( ICacheProvider cache , ISettingsService < CouchPotatoSettings > cpSettings ,
ISettingsService < PlexRequestSettings > prSettings , IAvailabilityChecker checker ,
IRequestService request ) : base ( "search" )
{
{
CpService = cpSettings ;
CpService = cpSettings ;
PrService = prSettings ;
PrService = prSettings ;
MovieApi = new TheMovieDbApi ( ) ;
MovieApi = new TheMovieDbApi ( ) ;
TvApi = new TheTvDbApi ( ) ;
TvApi = new TheTvDbApi ( ) ;
Cache = cache ;
Cache = cache ;
Checker = checker ;
RequestService = request ;
Get [ "/" ] = parameters = > RequestLoad ( ) ;
Get [ "/" ] = parameters = > RequestLoad ( ) ;
@ -64,9 +68,11 @@ namespace PlexRequests.UI.Modules
}
}
private TheMovieDbApi MovieApi { get ; }
private TheMovieDbApi MovieApi { get ; }
private TheTvDbApi TvApi { get ; }
private TheTvDbApi TvApi { get ; }
private IRequestService RequestService { get ; }
private ICacheProvider Cache { get ; }
private ICacheProvider Cache { get ; }
private ISettingsService < CouchPotatoSettings > CpService { get ; }
private ISettingsService < CouchPotatoSettings > CpService { get ; }
private ISettingsService < PlexRequestSettings > PrService { get ; }
private ISettingsService < PlexRequestSettings > PrService { get ; }
private IAvailabilityChecker Checker { get ; }
private static Logger Log = LogManager . GetCurrentClassLogger ( ) ;
private static Logger Log = LogManager . GetCurrentClassLogger ( ) ;
private string AuthToken = > Cache . GetOrSet ( CacheKeys . TvDbToken , TvApi . Authenticate , 50 ) ;
private string AuthToken = > Cache . GetOrSet ( CacheKeys . TvDbToken , TvApi . Authenticate , 50 ) ;
@ -145,8 +151,7 @@ namespace PlexRequests.UI.Modules
private Response RequestMovie ( int movieId )
private Response RequestMovie ( int movieId )
{
{
Log . Trace ( "Requesting movie with id {0}" , movieId ) ;
Log . Trace ( "Requesting movie with id {0}" , movieId ) ;
var s = new SettingsService ( Cache ) ;
if ( RequestService . CheckRequest ( movieId ) )
if ( s . CheckRequest ( movieId ) )
{
{
Log . Trace ( "movie with id {0} exists" , movieId ) ;
Log . Trace ( "movie with id {0} exists" , movieId ) ;
return Response . AsJson ( new { Result = false , Message = "Movie has already been requested!" } ) ;
return Response . AsJson ( new { Result = false , Message = "Movie has already been requested!" } ) ;
@ -193,7 +198,7 @@ namespace PlexRequests.UI.Modules
{
{
model . Approved = true ;
model . Approved = true ;
Log . Trace ( "Adding movie to database requests (No approval required)" ) ;
Log . Trace ( "Adding movie to database requests (No approval required)" ) ;
s. AddRequest ( movieId , model ) ;
Reque stService . AddRequest ( movieId , model ) ;
return Response . AsJson ( new { Result = true } ) ;
return Response . AsJson ( new { Result = true } ) ;
}
}
@ -203,7 +208,9 @@ namespace PlexRequests.UI.Modules
try
try
{
{
Log . Trace ( "Adding movie to database requests" ) ;
Log . Trace ( "Adding movie to database requests" ) ;
s . AddRequest ( movieId , model ) ;
var id = RequestService . AddRequest ( movieId , model ) ;
//BackgroundJob.Enqueue(() => Checker.CheckAndUpdate(model.Title, (int)id));
return Response . AsJson ( new { Result = true } ) ;
return Response . AsJson ( new { Result = true } ) ;
}
}
catch ( Exception e )
catch ( Exception e )
@ -223,8 +230,7 @@ namespace PlexRequests.UI.Modules
private Response RequestTvShow ( int showId , bool latest )
private Response RequestTvShow ( int showId , bool latest )
{
{
// Latest send to Sonarr and no need to store in DB
// Latest send to Sonarr and no need to store in DB
var s = new SettingsService ( Cache ) ;
if ( RequestService . CheckRequest ( showId ) )
if ( s . CheckRequest ( showId ) )
{
{
return Response . AsJson ( new { Result = false , Message = "TV Show has already been requested!" } ) ;
return Response . AsJson ( new { Result = false , Message = "TV Show has already been requested!" } ) ;
}
}
@ -251,7 +257,7 @@ namespace PlexRequests.UI.Modules
RequestedBy = Session [ SessionKeys . UsernameKey ] . ToString ( )
RequestedBy = Session [ SessionKeys . UsernameKey ] . ToString ( )
} ;
} ;
s. AddRequest ( showId , model ) ;
Reque stService . AddRequest ( showId , model ) ;
return Response . AsJson ( new { Result = true } ) ;
return Response . AsJson ( new { Result = true } ) ;
}
}
private string GetAuthToken ( TheTvDbApi api )
private string GetAuthToken ( TheTvDbApi api )