SPMS_API/SPMS.Infrastructure/Persistence/Configurations/NoticeConfiguration.cs

39 lines
1.5 KiB
C#

using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders;
using SPMS.Domain.Entities;
namespace SPMS.Infrastructure.Persistence.Configurations;
public class NoticeConfiguration : IEntityTypeConfiguration<Notice>
{
public void Configure(EntityTypeBuilder<Notice> builder)
{
builder.ToTable("Notice");
builder.HasKey(e => e.Id);
builder.Property(e => e.Id).ValueGeneratedOnAdd();
builder.Property(e => e.ServiceId).IsRequired();
builder.Property(e => e.Title).HasMaxLength(200).IsRequired();
builder.Property(e => e.Content).HasColumnType("text").IsRequired();
builder.Property(e => e.IsPinned).HasColumnType("tinyint(1)").IsRequired().HasDefaultValue(false);
builder.Property(e => e.IsActive).HasColumnType("tinyint(1)").IsRequired().HasDefaultValue(true);
builder.Property(e => e.CreatedAt).IsRequired();
builder.Property(e => e.CreatedBy).IsRequired();
builder.Property(e => e.UpdatedAt);
builder.Property(e => e.IsDeleted).HasColumnType("tinyint(1)").IsRequired().HasDefaultValue(false);
builder.HasOne(e => e.Service)
.WithMany()
.HasForeignKey(e => e.ServiceId)
.OnDelete(DeleteBehavior.Restrict);
builder.HasOne(e => e.CreatedByAdmin)
.WithMany()
.HasForeignKey(e => e.CreatedBy)
.OnDelete(DeleteBehavior.Restrict);
builder.HasQueryFilter(e => !e.IsDeleted);
}
}