30 lines
1.4 KiB
C#
30 lines
1.4 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.Role).HasColumnName("role");
|
|
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");
|
|
}
|
|
}
|