using MediatR; using EnvelopeGenerator.Domain.Constants; using EnvelopeGenerator.Application.Common.Query; using EnvelopeGenerator.Application.Common.Dto; using AutoMapper; using DigitalData.Core.Abstraction.Application.Repository; using EnvelopeGenerator.Application.Common.Extensions; using EnvelopeGenerator.Domain.Entities; using Microsoft.EntityFrameworkCore; namespace EnvelopeGenerator.Application.Envelopes.Queries; /// /// Repräsentiert eine Abfrage für Umschläge. /// public record ReadEnvelopeQuery : EnvelopeQueryBase, IRequest> { /// /// Abfrage des Include des Umschlags /// public EnvelopeStatusQuery? Status { get; init; } /// /// /// public bool? HasDocResult { get; init; } } /// /// Repräsentiert den Include eines Umschlags und dessen Beziehung zum Empfänger. (vgl. auch /// Invalid (0): Ungültiger Include. /// EnvelopeCreated (1001): Der Umschlag wurde erstellt. /// EnvelopeSaved (1002): Der Umschlag wurde gespeichert. /// EnvelopeQueued (1003): Der Umschlag wurde zur Verarbeitung eingeplant. /// EnvelopeSent (1004): Der Umschlag wurde versendet. (Nicht verwendet) /// EnvelopePartlySigned (1005): Der Umschlag wurde teilweise unterschrieben. /// EnvelopeCompletelySigned (1006): Der Umschlag wurde vollständig unterschrieben. /// EnvelopeReportCreated (1007): Ein Abschlussbericht wurde für den Umschlag erstellt. /// EnvelopeArchived (1008): Der Umschlag wurde archiviert. /// EnvelopeDeleted (1009): Der Umschlag wurde gelöscht. /// AccessCodeRequested (2001): Der Zugriffscode wurde angefordert. /// AccessCodeCorrect (2002): Der Zugriffscode war korrekt. /// AccessCodeIncorrect (2003): Der Zugriffscode war falsch. /// DocumentOpened (2004): Das Dokument wurde geöffnet. /// DocumentSigned (2005): Ein Dokument wurde unterschrieben. /// SignatureConfirmed (2006): Die Signatur wurde bestätigt. /// DocumentRejected (2007): Ein Dokument wurde abgelehnt. /// EnvelopeShared (2008): Der Umschlag wurde geteilt. /// EnvelopeViewed (2009): Der Umschlag wurde angesehen. /// DocumentForwarded (4001): Das Dokument wurde weitergeleitet. /// MessageInvitationSent (3001): Einladung wurde gesendet (vom Trigger verwendet). /// MessageAccessCodeSent (3002): Zugriffscode wurde gesendet. /// MessageConfirmationSent (3003): Bestätigungsnachricht wurde gesendet. /// MessageDeletionSent (3004): Löschbenachrichtigung wurde gesendet. /// MessageCompletionSent (3005): Abschlussbenachrichtigung wurde gesendet. /// public record EnvelopeStatusQuery { /// /// Der minimale Statuswert, der berücksichtigt werden. /// public EnvelopeStatus? Min { get; init; } /// /// Der maximale Statuswert, der berücksichtigt werden. /// public EnvelopeStatus? Max { get; init; } /// /// Eine Liste von Statuswerten, die einbezogen werden. /// public EnvelopeStatus[]? Include { get; init; } /// /// Eine Liste von Statuswerten, die ignoriert werden werden. /// public EnvelopeStatus[]? Ignore { get; init; } } /// /// /// public class ReadEnvelopeQueryHandler : IRequestHandler> { private readonly IMapper _mapper; private readonly IRepository _repo; /// /// /// /// /// public ReadEnvelopeQueryHandler(IMapper mapper, IRepository repo) { _mapper = mapper; _repo = repo; } /// /// /// /// /// /// /// public async Task> Handle(ReadEnvelopeQuery request, CancellationToken cancel) { var envelopesQ = _repo.Query.Where(request, notnull: false); EnvelopeStatusQuery? statusQ = request.Status; bool? hasDocResult = request.HasDocResult; var filtered = from envelope in envelopesQ where (statusQ == null || statusQ.Include == null || statusQ.Include.Contains(envelope.Status)) && (statusQ == null || statusQ.Ignore == null || !statusQ.Ignore.Contains(envelope.Status)) && (statusQ == null || statusQ.Min == null || envelope.Status > statusQ.Min) && (statusQ == null || statusQ.Max == null || envelope.Status < statusQ.Max) && (!hasDocResult.HasValue || (hasDocResult.Value ? envelope.DocResult != null : envelope.DocResult == null)) select envelope; var envelopes = await filtered.ToListAsync(cancel); return _mapper.Map>(envelopes); } }