@ -5,6 +5,9 @@ using NzbDrone.Api.REST;
using NzbDrone.Core.Parser ;
using NzbDrone.Core.Qualities ;
using NzbDrone.Core.Indexers ;
using NzbDrone.Core.Parser.Model ;
using NzbDrone.Core.DecisionEngine ;
using System.Linq ;
namespace NzbDrone.Api.Indexers
{
@ -20,11 +23,9 @@ namespace NzbDrone.Api.Indexers
public int IndexerId { get ; set ; }
public string Indexer { get ; set ; }
public string ReleaseGroup { get ; set ; }
public string SubGroup { get ; set ; }
public string ReleaseHash { get ; set ; }
public string Title { get ; set ; }
public bool FullSeason { get ; set ; }
public bool SceneSource { get ; set ; }
public int SeasonNumber { get ; set ; }
public Language Language { get ; set ; }
public string AirDate { get ; set ; }
@ -45,6 +46,8 @@ namespace NzbDrone.Api.Indexers
public int ReleaseWeight { get ; set ; }
public string MagnetUrl { get ; set ; }
public string InfoHash { get ; set ; }
public int? Seeders { get ; set ; }
public int? Leechers { get ; set ; }
public DownloadProtocol Protocol { get ; set ; }
@ -74,4 +77,98 @@ namespace NzbDrone.Api.Indexers
public bool IsPossibleSpecialEpisode { get ; set ; }
public bool Special { get ; set ; }
}
public static class ReleaseResourceMapper
{
public static ReleaseResource ToResource ( this DownloadDecision model )
{
var releaseInfo = model . RemoteEpisode . Release ;
var parsedEpisodeInfo = model . RemoteEpisode . ParsedEpisodeInfo ;
var remoteEpisode = model . RemoteEpisode ;
var torrentInfo = ( model . RemoteEpisode . Release as TorrentInfo ) ? ? new TorrentInfo ( ) ;
// TODO: Clean this mess up. don't mix data from multiple classes, use sub-resources instead? (Got a huge Deja Vu, didn't we talk about this already once?)
return new ReleaseResource
{
Guid = releaseInfo . Guid ,
Quality = parsedEpisodeInfo . Quality ,
//QualityWeight
Age = releaseInfo . Age ,
AgeHours = releaseInfo . AgeHours ,
AgeMinutes = releaseInfo . AgeMinutes ,
Size = releaseInfo . Size ,
IndexerId = releaseInfo . IndexerId ,
Indexer = releaseInfo . Indexer ,
ReleaseGroup = parsedEpisodeInfo . ReleaseGroup ,
ReleaseHash = parsedEpisodeInfo . ReleaseHash ,
Title = releaseInfo . Title ,
FullSeason = parsedEpisodeInfo . FullSeason ,
SeasonNumber = parsedEpisodeInfo . SeasonNumber ,
Language = parsedEpisodeInfo . Language ,
AirDate = parsedEpisodeInfo . AirDate ,
SeriesTitle = parsedEpisodeInfo . SeriesTitle ,
EpisodeNumbers = parsedEpisodeInfo . EpisodeNumbers ,
AbsoluteEpisodeNumbers = parsedEpisodeInfo . AbsoluteEpisodeNumbers ,
Approved = model . Approved ,
TemporarilyRejected = model . TemporarilyRejected ,
Rejected = model . Rejected ,
TvdbId = releaseInfo . TvdbId ,
TvRageId = releaseInfo . TvRageId ,
Rejections = model . Rejections . Select ( r = > r . Reason ) . ToList ( ) ,
PublishDate = releaseInfo . PublishDate ,
CommentUrl = releaseInfo . CommentUrl ,
DownloadUrl = releaseInfo . DownloadUrl ,
InfoUrl = releaseInfo . InfoUrl ,
DownloadAllowed = remoteEpisode . DownloadAllowed ,
//ReleaseWeight
MagnetUrl = torrentInfo . MagnetUrl ,
InfoHash = torrentInfo . InfoHash ,
Seeders = torrentInfo . Seeders ,
Leechers = ( torrentInfo . Peers . HasValue & & torrentInfo . Seeders . HasValue ) ? ( torrentInfo . Peers . Value - torrentInfo . Seeders . Value ) : ( int? ) null ,
Protocol = releaseInfo . DownloadProtocol ,
IsDaily = parsedEpisodeInfo . IsDaily ,
IsAbsoluteNumbering = parsedEpisodeInfo . IsAbsoluteNumbering ,
IsPossibleSpecialEpisode = parsedEpisodeInfo . IsPossibleSpecialEpisode ,
Special = parsedEpisodeInfo . Special ,
} ;
}
public static ReleaseInfo ToModel ( this ReleaseResource resource )
{
ReleaseInfo model ;
if ( resource . Protocol = = DownloadProtocol . Torrent )
{
model = new TorrentInfo
{
MagnetUrl = resource . MagnetUrl ,
InfoHash = resource . InfoHash ,
Seeders = resource . Seeders ,
Peers = ( resource . Seeders . HasValue & & resource . Leechers . HasValue ) ? ( resource . Seeders + resource . Leechers ) : null
} ;
}
else
{
model = new ReleaseInfo ( ) ;
}
model . Guid = resource . Guid ;
model . Title = resource . Title ;
model . Size = resource . Size ;
model . DownloadUrl = resource . DownloadUrl ;
model . InfoUrl = resource . InfoUrl ;
model . CommentUrl = resource . CommentUrl ;
model . IndexerId = resource . IndexerId ;
model . Indexer = resource . Indexer ;
model . DownloadProtocol = resource . DownloadProtocol ;
model . TvdbId = resource . TvdbId ;
model . TvRageId = resource . TvRageId ;
model . PublishDate = resource . PublishDate ;
return model ;
}
}
}