6824d7ce7d
🚀 Create and publish a Docker image / Detect changes in backend and frontend (push) Successful in 9s
🚀 Create and publish a Docker image / Build & publish backend image (push) Successful in 2m6s
🚀 Create and publish a Docker image / Build & publish frontend image (push) Successful in 26s
🚀 Create and publish a Docker image / Update stack on Portainer (push) Successful in 6s
34 lines
1.5 KiB
C#
34 lines
1.5 KiB
C#
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.EntityFrameworkCore.Metadata.Builders;
|
|
using UniVerse.Domain.Entities;
|
|
|
|
namespace UniVerse.Infrastructure.Data.Configurations;
|
|
|
|
public class UserConfiguration : IEntityTypeConfiguration<User>
|
|
{
|
|
public void Configure(EntityTypeBuilder<User> builder)
|
|
{
|
|
builder.ToTable("users");
|
|
|
|
builder.HasKey(u => u.Id);
|
|
builder.Property(u => u.Id).HasColumnName("id");
|
|
builder.Property(u => u.Email).HasColumnName("email").HasMaxLength(255).IsRequired();
|
|
builder.Property(u => u.DisplayName).HasColumnName("display_name").HasMaxLength(255);
|
|
builder.Property(u => u.AvatarUrl).HasColumnName("avatar_url").HasMaxLength(500);
|
|
builder.Property(u => u.IsActive).HasColumnName("is_active").HasDefaultValue(true);
|
|
builder.Property(u => u.MicrosoftId).HasColumnName("microsoft_id").HasMaxLength(255);
|
|
builder.Property(u => u.Xp).HasColumnName("xp").HasDefaultValue(0);
|
|
builder.Property(u => u.Coins).HasColumnName("coins").HasDefaultValue(0);
|
|
builder.Property(u => u.CreatedAt).HasColumnName("created_at").HasDefaultValueSql("NOW()");
|
|
builder.Property(u => u.UpdatedAt).HasColumnName("updated_at").HasDefaultValueSql("NOW()");
|
|
|
|
builder.HasIndex(u => u.Email).IsUnique();
|
|
builder.HasIndex(u => u.MicrosoftId).IsUnique().HasFilter("microsoft_id IS NOT NULL");
|
|
|
|
builder.HasMany(u => u.Roles)
|
|
.WithOne(ur => ur.User)
|
|
.HasForeignKey(ur => ur.UserId)
|
|
.OnDelete(DeleteBehavior.Cascade);
|
|
}
|
|
}
|