- Implementierung von LINQ-Abfragen innerhalb der Core-Bibliothek zur Minderung von SQL-Injection-Anfälligkeiten für DB-Operationen von Umschlägen und Empfängern. - Aktualisierung der Geschäftslogik in der Service-Schicht für verbessertes Transaktionshandling. - Erweiterung der ServiceMessage um eine neue Flag-Funktion zum Verfolgen von Cybersecurity- und Datenintegritätsproblemen. - Hinzufügen spezifischer Benutzerverhaltensflags zur besseren Erkennung und Behandlung potenzieller Datenverletzungen.
31 lines
1.1 KiB
C#
31 lines
1.1 KiB
C#
using DigitalData.Core.Infrastructure;
|
|
using DigitalData.UserManager.Infrastructure.Repositories;
|
|
using EnvelopeGenerator.Domain.Entities;
|
|
using EnvelopeGenerator.Infrastructure.Contracts;
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
namespace EnvelopeGenerator.Infrastructure.Repositories
|
|
{
|
|
public class EnvelopeHistoryRepository : CRUDRepository<EnvelopeHistory, long, EGDbContext>, IEnvelopeHistoryRepository
|
|
{
|
|
public EnvelopeHistoryRepository(EGDbContext dbContext) : base(dbContext)
|
|
{
|
|
}
|
|
|
|
public async Task<int> CountAsync(int? envelopeId = null, string? userReference = null, int? status = null)
|
|
{
|
|
var query = _dbSet.AsQueryable();
|
|
|
|
if (envelopeId is not null)
|
|
query = query.Where(eh => eh.EnvelopeId == envelopeId);
|
|
|
|
if (userReference is not null)
|
|
query = query.Where(eh => eh.UserReference == userReference);
|
|
|
|
if (status is not null)
|
|
query = query.Where(eh => eh.Status == status);
|
|
|
|
return await query.CountAsync();
|
|
}
|
|
}
|
|
} |