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 q = _repo.Query.Where(request, notnull: false); if (request.Status is EnvelopeStatusQuery statusQ) { // including status if (statusQ.Include is EnvelopeStatus[] incStatus) q = q.Where(e => incStatus.Contains(e.Status)); // ignoring status if (statusQ.Ignore is EnvelopeStatus[] ignoreStatus) q = q.Where(e => !ignoreStatus.Contains(e.Status)); // max status if (statusQ.Max is EnvelopeStatus maxStatus) q = q.Where(e => e.Status < maxStatus); // min status if (statusQ.Min is EnvelopeStatus minStatus) q = q.Where(e => e.Status > minStatus); } if (request.HasDocResult is bool hasDocResult) q = hasDocResult ? q.Where(e => e.DocResult != null) : q.Where(e => e.DocResult == null); var envelopes = await q.ToListAsync(cancel); return _mapper.Map>(envelopes); } }