Sistema de Notificaciones y Baja One-Click

This commit is contained in:
2026-03-12 13:52:33 -03:00
parent f1a9bb9099
commit 96fca4d9c7
21 changed files with 1384 additions and 79 deletions

View File

@@ -23,6 +23,8 @@ public class MotoresV2DbContext : DbContext
public DbSet<PaymentMethod> PaymentMethods { get; set; }
public DbSet<RefreshToken> RefreshTokens { get; set; }
public DbSet<AdViewLog> AdViewLogs { get; set; }
public DbSet<UserNotificationPreference> NotificationPreferences { get; set; }
public DbSet<UnsubscribeToken> UnsubscribeTokens { get; set; }
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
@@ -67,8 +69,31 @@ public class MotoresV2DbContext : DbContext
modelBuilder.Entity<AdFeature>().ToTable("AdFeatures");
modelBuilder.Entity<TransactionRecord>().ToTable("Transactions");
// Configuración de AdViewLog
modelBuilder.Entity<AdViewLog>().ToTable("AdViewLogs");
modelBuilder.Entity<AdViewLog>().HasIndex(l => new { l.AdID, l.IPAddress, l.ViewDate });
// Configuración de UserNotificationPreference
modelBuilder.Entity<UserNotificationPreference>().ToTable("UserNotificationPreferences");
modelBuilder.Entity<UserNotificationPreference>().HasKey(p => p.PreferenceID);
// Índice único: un usuario no puede tener dos registros para la misma categoría
modelBuilder.Entity<UserNotificationPreference>()
.HasIndex(p => new { p.UserID, p.Category })
.IsUnique();
modelBuilder.Entity<UserNotificationPreference>()
.HasOne(p => p.User)
.WithMany()
.HasForeignKey(p => p.UserID)
.OnDelete(DeleteBehavior.Cascade);
// Configuración de UnsubscribeToken
modelBuilder.Entity<UnsubscribeToken>().ToTable("UnsubscribeTokens");
modelBuilder.Entity<UnsubscribeToken>().HasKey(t => t.TokenID);
// Índice para búsqueda rápida por valor del token
modelBuilder.Entity<UnsubscribeToken>().HasIndex(t => t.Token).IsUnique();
modelBuilder.Entity<UnsubscribeToken>()
.HasOne(t => t.User)
.WithMany()
.HasForeignKey(t => t.UserID)
.OnDelete(DeleteBehavior.Cascade);
}
}