Sistema de Notificaciones y Baja One-Click
This commit is contained in:
@@ -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);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user