mirror of https://github.com/ErsatzTV/ErsatzTV.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
104 lines
3.9 KiB
104 lines
3.9 KiB
using System.Collections.Generic; |
|
using System.Data; |
|
using System.Linq; |
|
using System.Threading.Tasks; |
|
using Dapper; |
|
using ErsatzTV.Core.Domain; |
|
using ErsatzTV.Core.Interfaces.Repositories; |
|
using LanguageExt; |
|
using Microsoft.EntityFrameworkCore; |
|
using static LanguageExt.Prelude; |
|
|
|
namespace ErsatzTV.Infrastructure.Data.Repositories |
|
{ |
|
public class LibraryRepository : ILibraryRepository |
|
{ |
|
private readonly IDbConnection _dbConnection; |
|
private readonly IDbContextFactory<TvContext> _dbContextFactory; |
|
|
|
public LibraryRepository(IDbContextFactory<TvContext> dbContextFactory, IDbConnection dbConnection) |
|
{ |
|
_dbContextFactory = dbContextFactory; |
|
_dbConnection = dbConnection; |
|
} |
|
|
|
public async Task<LibraryPath> Add(LibraryPath libraryPath) |
|
{ |
|
await using TvContext context = _dbContextFactory.CreateDbContext(); |
|
await context.LibraryPaths.AddAsync(libraryPath); |
|
await context.SaveChangesAsync(); |
|
return libraryPath; |
|
} |
|
|
|
public Task<Option<Library>> Get(int libraryId) |
|
{ |
|
using TvContext context = _dbContextFactory.CreateDbContext(); |
|
return context.Libraries |
|
.Include(l => l.Paths) |
|
.OrderBy(l => l.Id) |
|
.SingleOrDefaultAsync(l => l.Id == libraryId) |
|
.Map(Optional); |
|
} |
|
|
|
public Task<Option<LocalLibrary>> GetLocal(int libraryId) |
|
{ |
|
using TvContext context = _dbContextFactory.CreateDbContext(); |
|
return context.LocalLibraries |
|
.OrderBy(l => l.Id) |
|
.SingleOrDefaultAsync(l => l.Id == libraryId) |
|
.Map(Optional); |
|
} |
|
|
|
public Task<List<Library>> GetAll() |
|
{ |
|
using TvContext context = _dbContextFactory.CreateDbContext(); |
|
return context.Libraries |
|
.AsNoTracking() |
|
.Include(l => l.MediaSource) |
|
.ToListAsync(); |
|
} |
|
|
|
public Task<Unit> UpdateLastScan(Library library) => _dbConnection.ExecuteAsync( |
|
"UPDATE Library SET LastScan = @LastScan WHERE Id = @Id", |
|
new { library.LastScan, library.Id }).ToUnit(); |
|
|
|
public Task<List<LibraryPath>> GetLocalPaths(int libraryId) |
|
{ |
|
using TvContext context = _dbContextFactory.CreateDbContext(); |
|
return context.LocalLibraries |
|
.Include(l => l.Paths) |
|
.OrderBy(l => l.Id) |
|
.SingleOrDefaultAsync(l => l.Id == libraryId) |
|
.Map(Optional) |
|
.Match(l => l.Paths, () => new List<LibraryPath>()); |
|
} |
|
|
|
public Task<Option<LibraryPath>> GetPath(int libraryPathId) |
|
{ |
|
using TvContext context = _dbContextFactory.CreateDbContext(); |
|
return context.LibraryPaths |
|
.OrderBy(lp => lp.Id) |
|
.SingleOrDefaultAsync(lp => lp.Id == libraryPathId) |
|
.Map(Optional); |
|
} |
|
|
|
public Task<int> CountMediaItemsByPath(int libraryPathId) => |
|
_dbConnection.QuerySingleAsync<int>( |
|
@"SELECT COUNT(*) FROM MediaItem WHERE LibraryPathId = @LibraryPathId", |
|
new { LibraryPathId = libraryPathId }); |
|
|
|
public Task<List<int>> GetMediaIdsByLocalPath(int libraryPathId) => |
|
_dbConnection.QueryAsync<int>( |
|
@"SELECT Id FROM MediaItem WHERE LibraryPathId = @LibraryPathId", |
|
new { LibraryPathId = libraryPathId }) |
|
.Map(result => result.ToList()); |
|
|
|
public async Task DeleteLocalPath(int libraryPathId) |
|
{ |
|
await using TvContext context = _dbContextFactory.CreateDbContext(); |
|
LibraryPath libraryPath = await context.LibraryPaths.FindAsync(libraryPathId); |
|
context.LibraryPaths.Remove(libraryPath); |
|
await context.SaveChangesAsync(); |
|
} |
|
} |
|
}
|
|
|