CommentConfiguration.cs 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. using Domain.Entities.Forum.Comments;
  2. using Microsoft.EntityFrameworkCore;
  3. using Microsoft.EntityFrameworkCore.Metadata.Builders;
  4. namespace Infrastructure.Persistence.Configurations.Forum.Comments;
  5. public sealed class CommentConfiguration : IEntityTypeConfiguration<Comment>
  6. {
  7. public void Configure(EntityTypeBuilder<Comment> builder)
  8. {
  9. builder.HasIndex(x => x.BoardID);
  10. builder.HasIndex(x => x.PostID);
  11. builder.HasIndex(x => x.MemberID);
  12. builder.HasIndex(x => x.ParentID);
  13. builder.HasIndex(x => new { x.PostID, x.IsDeleted, x.ParentID, x.CreatedAt }).IsDescending(false, false, false, true);
  14. builder.HasIndex(x => new { x.PostID, x.IsDeleted, x.ParentID, x.Score, x.ID }).IsDescending(false, false, false, true, true);
  15. builder.HasIndex(x => new { x.PostID, x.MemberID, x.IsDeleted, x.ParentID, x.CreatedAt }).IsDescending(false, false, false, false, true);
  16. builder.HasIndex(x => new { x.PostID, x.MemberID, x.IsDeleted, x.ParentID, x.Score, x.ID }).IsDescending(false, false, false, false, true, true);
  17. builder.HasIndex(x => new { x.PostID, x.IsDeleted, x.ParentID, x.CreatedAt });
  18. builder.HasIndex(x => new { x.PostID, x.MemberID, x.IsDeleted, x.ParentID, x.CreatedAt });
  19. builder.HasOne(x => x.Board).WithMany().HasForeignKey(x => x.BoardID).OnDelete(DeleteBehavior.Restrict);
  20. builder.HasOne(x => x.Post).WithMany(x => x.Comment).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  21. builder.HasOne(x => x.Member).WithMany().HasForeignKey(x => x.MemberID).OnDelete(DeleteBehavior.Restrict);
  22. builder.HasOne(x => x.MentionMember).WithMany().HasForeignKey(x => x.MentionMemberID).OnDelete(DeleteBehavior.SetNull);
  23. builder.HasOne(x => x.Parent).WithMany(x => x.Children).HasForeignKey(x => x.ParentID).OnDelete(DeleteBehavior.Restrict);
  24. builder.HasMany(x => x.CommentImage).WithOne(x => x.Comment).HasForeignKey(x => x.CommentID).OnDelete(DeleteBehavior.Cascade);
  25. builder.HasMany(x => x.CommentMedia).WithOne(x => x.Comment).HasForeignKey(x => x.CommentID).OnDelete(DeleteBehavior.Cascade);
  26. builder.HasMany(x => x.CommentFile).WithOne(x => x.Comment).HasForeignKey(x => x.CommentID).OnDelete(DeleteBehavior.Cascade);
  27. builder.HasMany(x => x.CommentLink).WithOne(x => x.Comment).HasForeignKey(x => x.CommentID).OnDelete(DeleteBehavior.Cascade);
  28. builder.HasMany(x => x.CommentReaction).WithOne(x => x.Comment).HasForeignKey(x => x.CommentID).OnDelete(DeleteBehavior.Cascade);
  29. builder.HasMany(x => x.CommentReport).WithOne(x => x.Comment).HasForeignKey(x => x.CommentID).OnDelete(DeleteBehavior.Cascade);
  30. builder.HasOne(x => x.CommentMention).WithOne(x => x.Comment).HasForeignKey<CommentMention>(x => x.CommentID).OnDelete(DeleteBehavior.Cascade);
  31. builder.ToTable(nameof(Comment), x => x.HasComment("댓글"));
  32. builder.HasKey(x => x.ID);
  33. builder.Property(x => x.ID).ValueGeneratedOnAdd().HasComment("PK");
  34. builder.Property(x => x.BoardID).IsRequired().HasComment("게시판 ID");
  35. builder.Property(x => x.PostID).IsRequired().HasComment("게시글 ID");
  36. builder.Property(x => x.MemberID).IsRequired().HasComment("회원 ID");
  37. builder.Property(x => x.ParentID).HasComment("부모 댓글 ID");
  38. builder.Property(x => x.MentionMemberID).HasComment("언급 대상 회원 ID");
  39. builder.Property(x => x.Depth).IsRequired().HasComment("댓글 깊이");
  40. builder.Property(x => x.Content).HasMaxLength(4000).IsRequired().HasComment("댓글 내용");
  41. builder.Property(x => x.Status).HasConversion<byte>().HasComment("댓글 상태");
  42. builder.Property(x => x.IsDeleted).IsRequired().HasComment("삭제 여부");
  43. builder.Property(x => x.Score).IsRequired().HasComment("점수");
  44. builder.Property(x => x.CreatedAt).IsRequired().HasComment("등록 일시");
  45. }
  46. }