PostConfiguration.cs 5.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. using Domain.Entities.Forum.Posts;
  2. using Microsoft.EntityFrameworkCore;
  3. using Microsoft.EntityFrameworkCore.Metadata.Builders;
  4. namespace Infrastructure.Persistence.Configurations.Forum.Posts;
  5. public sealed class PostConfiguration : IEntityTypeConfiguration<Post>
  6. {
  7. public void Configure(EntityTypeBuilder<Post> builder)
  8. {
  9. builder.HasIndex(x => x.BoardID);
  10. builder.HasIndex(x => x.BoardPrefixID);
  11. builder.HasIndex(x => x.MemberID);
  12. builder.HasIndex(x => new { x.ID, x.BoardID });
  13. builder.HasIndex(x => new { x.ID, x.BoardID, x.IsDeleted });
  14. builder.HasIndex(x => new { x.ID, x.BoardID, x.BoardPrefixID, x.IsDeleted, x.CreatedAt });
  15. builder.HasIndex(x => new { x.ID, x.BoardID, x.BoardPrefixID, x.IsDeleted, x.Views });
  16. builder.HasIndex(x => new { x.ID, x.BoardID, x.BoardPrefixID, x.IsDeleted, x.Comments });
  17. builder.HasIndex(x => new { x.ID, x.BoardID, x.BoardPrefixID, x.IsDeleted, x.Likes });
  18. builder.HasOne(x => x.Board).WithMany(x => x.Post).HasForeignKey(x => x.BoardID).OnDelete(DeleteBehavior.Restrict);
  19. builder.HasOne(x => x.BoardPrefix).WithMany().HasForeignKey(x => x.BoardPrefixID).OnDelete(DeleteBehavior.SetNull);
  20. builder.HasOne(x => x.Member).WithMany().HasForeignKey(x => x.MemberID).IsRequired(false).OnDelete(DeleteBehavior.SetNull);
  21. builder.HasMany(x => x.Comment).WithOne(x => x.Post).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  22. builder.HasMany(x => x.PostImage).WithOne(x => x.Post).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  23. builder.HasMany(x => x.PostMedia).WithOne(x => x.Post).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  24. builder.HasMany(x => x.PostFile).WithOne(x => x.Post).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  25. builder.HasMany(x => x.PostLink).WithOne(x => x.Post).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  26. builder.HasMany(x => x.PostTag).WithOne(x => x.Post).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  27. builder.HasMany(x => x.PostReaction).WithOne(x => x.Post).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  28. builder.HasMany(x => x.PostBookmark).WithOne(x => x.Post).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  29. builder.HasMany(x => x.PostReport).WithOne(x => x.Post).HasForeignKey(x => x.PostID).OnDelete(DeleteBehavior.Cascade);
  30. builder.ToTable(nameof(Post), x => x.HasComment("게시글"));
  31. builder.HasKey(x => x.ID);
  32. builder.Property(x => x.ID).ValueGeneratedOnAdd().HasComment("PK");
  33. builder.Property(x => x.BoardID).IsRequired().HasComment("게시판 ID");
  34. builder.Property(x => x.BoardPrefixID).HasComment("게시글 말머리 ID");
  35. builder.Property(x => x.MemberID).HasComment("회원 ID");
  36. builder.Property(x => x.Subject).HasMaxLength(255).IsRequired().HasComment("제목");
  37. builder.Property(x => x.Content).HasMaxLength(8000).IsRequired().HasComment("내용");
  38. builder.Property(x => x.SID).HasMaxLength(20).HasComment("회원 SID");
  39. builder.Property(x => x.Email).HasMaxLength(60).HasComment("회원 이메일");
  40. builder.Property(x => x.Name).HasMaxLength(20).HasComment("회원 이름");
  41. builder.Property(x => x.Thumbnail).HasMaxLength(255).HasComment("대표 이미지");
  42. builder.Property(x => x.IsReply).IsRequired().HasComment("답변 여부");
  43. builder.Property(x => x.IsAnonymous).IsRequired().HasComment("익명 글 여부");
  44. builder.Property(x => x.IsSecret).IsRequired().HasComment("비밀글 여부");
  45. builder.Property(x => x.IsNotice).IsRequired().HasComment("일반 공지 여부");
  46. builder.Property(x => x.IsSpeaker).IsRequired().HasComment("전체 공지 여부");
  47. builder.Property(x => x.IsDeleted).IsRequired().HasComment("삭제 여부");
  48. builder.Property(x => x.Views).IsRequired().HasComment("조회 수");
  49. builder.Property(x => x.Likes).IsRequired().HasComment("좋아요");
  50. builder.Property(x => x.Dislikes).IsRequired().HasComment("싫어요");
  51. builder.Property(x => x.Comments).IsRequired().HasComment("댓글 수");
  52. builder.Property(x => x.Bookmarks).IsRequired().HasComment("즐겨찾기 수");
  53. builder.Property(x => x.Reports).IsRequired().HasComment("신고 수");
  54. builder.Property(x => x.Images).IsRequired().HasComment("이미지 수");
  55. builder.Property(x => x.Medias).IsRequired().HasComment("미디어 수");
  56. builder.Property(x => x.Files).IsRequired().HasComment("파일 수");
  57. builder.Property(x => x.Tags).IsRequired().HasComment("Tag 수");
  58. builder.Property(x => x.IpAddress).HasMaxLength(50).HasComment("IP");
  59. builder.Property(x => x.UserAgent).HasMaxLength(255).HasComment("User-Agent");
  60. builder.Property(x => x.LastReplyUpdatedAt).HasComment("마지막 답변 일시");
  61. builder.Property(x => x.LastCommentUpdatedAt).HasComment("마지막 댓글 일시");
  62. builder.Property(x => x.DeletedAt).HasComment("삭제 일시");
  63. builder.Property(x => x.UpdatedAt).HasComment("수정 일시");
  64. builder.Property(x => x.CreatedAt).IsRequired().HasComment("등록 일시");
  65. }
  66. }