using JSMR.Application.Common.Caching; using JSMR.Application.Integrations.DLSite.Models; using JSMR.Application.Integrations.Ports; using JSMR.Application.Scanning.Contracts; using JSMR.Application.Scanning.Ports; using Microsoft.Extensions.DependencyInjection; namespace JSMR.Application.Scanning; public sealed class ScanVoiceWorksHandler(IServiceProvider serviceProvider, IDLSiteClient dlsiteClient, ISpamCircleCache spamCircleCache) { public async Task HandleAsync(ScanVoiceWorksRequest request, CancellationToken cancellationToken) { IVoiceWorksScanner? scanner = serviceProvider.GetKeyedService(request.Locale); if (scanner is null) return new(); VoiceWorkScanOptions options = new( PageNumber: request.PageNumber, PageSize: request.PageSize, ExcludedMakerIds: await spamCircleCache.GetAsync(cancellationToken), ExcludePartiallyAIGeneratedWorks: true, ExcludeAIGeneratedWorks: true ); IReadOnlyList works = await scanner.ScanPageAsync(options, cancellationToken); if (works.Count == 0) return new(); string[] productIds = [.. works.Where(x => !string.IsNullOrWhiteSpace(x.ProductId)).Select(x => x.ProductId!)]; VoiceWorkDetailCollection voiceWorkDetails = await dlsiteClient.GetVoiceWorkDetailsAsync(productIds, cancellationToken); // TODO /* var ingests = works.Select(VoiceWorkIngest.From).ToList(); var upsert = await _writer.UpsertAsync(ingests, ct); // only update search text for affected rows await _search.UpdateAsync(upsert.AffectedVoiceWorkIds, ct); return new ScanVoiceWorksResponse { Inserted = upsert.Inserted, Updated = upsert.Updated }; */ return new(); } }