Developer 02 622cb1f702 feat: Implementiere kaskadierende Löschung für die User-Entität im UserRepository
- Überriding der DeleteAsync-Methode hinzugefügt, um verwandte ModuleOfUser- und GroupOfUser-Entitäten zu behandeln.
- Sicherstellung der Entfernung verwandter Datensätze bei der Löschung eines Benutzers.
- TODO-Kommentar hinzugefügt, um zu empfehlen, .OnDelete(DeleteBehavior.ClientCascade) im DbContext für ein verbessertes Verhalten zu verwenden.
2024-10-29 16:13:58 +01:00

50 lines
2.0 KiB
C#

using DigitalData.UserManager.Domain.Entities;
using Microsoft.EntityFrameworkCore;
namespace DigitalData.UserManager.Infrastructure
{
public static class DbContextExtensions
{
public static ModelBuilder ConfigureUserManager(this ModelBuilder modelBuilder)
{
modelBuilder.Entity<User>()
.ToTable(tb => tb.HasTrigger("TBDD_USER_AFT_DEL"))
.ToTable(tb => tb.HasTrigger("TBDD_USER_AFT_INS"))
.ToTable(tb => tb.HasTrigger("TBDD_USER_AFT_UPD"))
.ToTable(tb => tb.HasTrigger("TBDD_USER_AFT_UPD_LOG"));
modelBuilder.Entity<GroupOfUser>()
.ToTable(tb => tb.HasTrigger("TBDD_GROUPS_USER_AFT_DEL"))
.ToTable(tb => tb.HasTrigger("TBDD_GROUPS_USER_AFT_UPD"));
modelBuilder.Entity<Group>()
.ToTable(tb => tb.HasTrigger("TBDD_GROUPS_AFT_UPD"))
.HasKey(group => group.Id);
modelBuilder.Entity<Module>()
.ToTable(tb => tb.HasTrigger("TBDD_MODULE_AFT_UPD"));
modelBuilder.Entity<ModuleOfUser>();
modelBuilder.Entity<UserRep>()
.ToTable(tb => tb.HasTrigger("TBDD_USER_REPRESENTATION_AFT_UPD"));
return modelBuilder;
}
}
}
//TODO: DeleteBehavior.Restrict (see example comment below) is not working, probably due to table relationships. Because it tries to delete, for example, User first and then GroupOfUser. However, since GroupOfUser is not deleted while Users is deleted, the error is thrown because of the table relationship. Apply this approach after finding the solution.
/*
modelBuilder.Entity<User>()
.HasMany<GroupOfUser>()
.WithOne(gou => gou.User)
.HasForeignKey(gou => gou.UserId)
.OnDelete(DeleteBehavior.ClientCascade);
modelBuilder.Entity<User>()
.HasMany<ModuleOfUser>()
.WithOne(mou => mou.User)
.HasForeignKey(mou => mou.UserId)
.OnDelete(DeleteBehavior.ClientCascade);
*/