Lidarr/src/NzbDrone.Core/MediaFiles/MediaFileRepository.cs

70 lines
2.8 KiB
C#
Raw Normal View History

using System;
2013-03-01 07:03:41 +00:00
using System.Collections.Generic;
using NzbDrone.Core.Datastore;
using NzbDrone.Core.Messaging.Events;
2013-09-11 06:33:47 +00:00
2013-03-01 07:03:41 +00:00
namespace NzbDrone.Core.MediaFiles
{
public interface IMediaFileRepository : IBasicRepository<TrackFile>
2013-03-01 07:03:41 +00:00
{
List<TrackFile> GetFilesByArtist(int artistId);
List<TrackFile> GetFilesByAlbum(int albumId);
List<TrackFile> GetFilesWithoutMediaInfo();
List<TrackFile> GetFilesWithRelativePath(int artistId, string relativePath);
2013-03-01 07:03:41 +00:00
}
public class MediaFileRepository : BasicRepository<TrackFile>, IMediaFileRepository
2013-03-01 07:03:41 +00:00
{
public MediaFileRepository(IMainDatabase database, IEventAggregator eventAggregator)
: base(database, eventAggregator)
2013-03-01 07:03:41 +00:00
{
}
public List<TrackFile> GetFilesWithoutMediaInfo()
2013-06-02 19:29:00 +00:00
{
return Query.Where(c => c.MediaInfo == null).ToList();
2013-03-01 07:03:41 +00:00
}
2014-04-10 17:58:50 +00:00
public List<TrackFile> GetFilesByArtist(int artistId)
2014-04-10 17:58:50 +00:00
{
string query = string.Format("SELECT TrackFiles.* " +
"FROM Artists " +
"JOIN Albums ON Albums.ArtistMetadataId = Artists.ArtistMetadataId " +
"JOIN AlbumReleases ON AlbumReleases.AlbumId == Albums.Id " +
"JOIN Tracks ON Tracks.AlbumReleaseId == AlbumReleases.Id " +
"JOIN TrackFiles ON TrackFiles.Id == Tracks.TrackFileId " +
"WHERE Artists.Id == {0} " +
"AND AlbumReleases.Monitored = 1",
artistId);
return Query.QueryText(query).ToList();
2014-04-10 17:58:50 +00:00
}
public List<TrackFile> GetFilesByAlbum(int albumId)
{
return Query.Where(c => c.AlbumId == albumId).ToList();
}
public List<TrackFile> GetFilesWithRelativePath(int artistId, string relativePath)
{
var mapper = DataMapper;
mapper.AddParameter("artistId", artistId);
mapper.AddParameter("relativePath", relativePath);
string query = "SELECT TrackFiles.* " +
"FROM Artists " +
"JOIN Albums ON Albums.ArtistMetadataId = Artists.ArtistMetadataId " +
"JOIN AlbumReleases ON AlbumReleases.AlbumId == Albums.Id " +
"JOIN Tracks ON Tracks.AlbumReleaseId == AlbumReleases.Id " +
"JOIN TrackFiles ON TrackFiles.Id == Tracks.TrackFileId " +
"WHERE Artists.Id == @artistId " +
"AND AlbumReleases.Monitored = 1 " +
"AND TrackFiles.RelativePath == @relativePath";
return mapper.Query<TrackFile>(query);
}
2013-03-01 07:03:41 +00:00
}
}