using ErsatzTV.Application.MediaCollections; using ErsatzTV.Infrastructure.Data; using Microsoft.EntityFrameworkCore; using static ErsatzTV.Application.MediaCollections.Mapper; namespace ErsatzTV.Application.Search; public class SearchSmartCollectionsHandler : IRequestHandler> { private readonly IDbContextFactory _dbContextFactory; public SearchSmartCollectionsHandler(IDbContextFactory dbContextFactory) => _dbContextFactory = dbContextFactory; public async Task> Handle( SearchSmartCollections request, CancellationToken cancellationToken) { await using TvContext dbContext = await _dbContextFactory.CreateDbContextAsync(cancellationToken); return await dbContext.SmartCollections.FromSqlRaw( @"SELECT * FROM SmartCollection WHERE Name LIKE {0} ORDER BY Name LIMIT 10 COLLATE NOCASE", $"%{request.Query}%") .AsNoTracking() .ToListAsync(cancellationToken) .Map(list => list.Map(ProjectToViewModel).ToList()); } }