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);
}
}