ConfigConfiguration.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. using Domain.Entities.Common;
  2. using Microsoft.EntityFrameworkCore;
  3. using Microsoft.EntityFrameworkCore.Metadata.Builders;
  4. namespace Infrastructure.Persistence.Configurations.Common;
  5. public sealed class ConfigConfiguration : IEntityTypeConfiguration<Config>
  6. {
  7. public void Configure(EntityTypeBuilder<Config> builder)
  8. {
  9. builder.ToTable(nameof(Config), x => x.HasComment("운영 정보 설정 값"));
  10. builder.HasKey(x => x.ID);
  11. builder.Property(x => x.ID).ValueGeneratedOnAdd().HasComment("PK");
  12. builder.Property(x => x.LastUpdatedAt).IsRequired().HasComment("마지막 수정일시");
  13. builder.Property(x => x.RowVersion).IsRowVersion().HasComment("동시성 제어용");
  14. builder.OwnsOne(x => x.Basic, owned =>
  15. {
  16. owned.Property(x => x.SiteName).HasMaxLength(100).HasColumnName("Basic_SiteName").HasComment("사이트 이름");
  17. owned.Property(x => x.SiteURL).HasMaxLength(100).HasColumnName("Basic_SiteURL").HasComment("사이트 주소");
  18. owned.Property(x => x.RootID).HasMaxLength(100).HasColumnName("Basic_RootID").HasComment("최고 관리자 ID");
  19. owned.Property(x => x.FromEmail).HasMaxLength(100).HasColumnName("Basic_FromEmail").HasComment("송수신 이메일");
  20. owned.Property(x => x.FromName).HasMaxLength(30).HasColumnName("Basic_FromName").HasComment("송수신자 이름");
  21. owned.Property(x => x.SmtpServer).HasMaxLength(200).HasColumnName("Basic_SmtpServer").HasComment("SMTP Server");
  22. owned.Property(x => x.SmtpPort).HasColumnName("Basic_SmtpPort").HasComment("SMTP Port");
  23. owned.Property(x => x.SmtpEnableSSL).HasColumnName("Basic_SmtpEnableSSL").HasComment("SMTP Enable SSL");
  24. owned.Property(x => x.SmtpUsername).HasMaxLength(100).HasColumnName("Basic_SmtpUsername").HasComment("SMTP Username");
  25. owned.Property(x => x.SmtpPassword).HasMaxLength(200).HasColumnName("Basic_SmtpPassword").HasComment("SMTP Password");
  26. owned.Property(x => x.AdminWhiteIPList).HasMaxLength(1000).HasColumnName("Basic_AdminWhiteIPList").HasComment("관리자단 접근 가능 IP");
  27. owned.Property(x => x.FrontWhiteIPList).HasMaxLength(1000).HasColumnName("Basic_FrontWhiteIPList").HasComment("사용자단 접근 가능 IP");
  28. owned.Property(x => x.BlockAlertTitle).HasMaxLength(200).HasColumnName("Basic_BlockAlertTitle").HasComment("차단 시 안내문 제목");
  29. owned.Property(x => x.BlockAlertContent).HasMaxLength(5000).HasColumnName("Basic_BlockAlertContent").HasComment("차단 시 안내문 내용");
  30. owned.Property(x => x.IsMaintenance).HasColumnName("Basic_IsMaintenance").HasComment("점검 여부");
  31. owned.Property(x => x.MaintenanceContent).HasMaxLength(5000).HasColumnName("Basic_MaintenanceContent").HasComment("점검 내용");
  32. });
  33. builder.OwnsOne(x => x.Images, owned =>
  34. {
  35. owned.Property(x => x.Favicon).HasMaxLength(255).HasColumnName("Images_Favicon").HasComment("Favicon");
  36. owned.Property(x => x.LogoSquare).HasMaxLength(255).HasColumnName("Images_LogoSquare").HasComment("Logo-square");
  37. owned.Property(x => x.LogoHorizontal).HasMaxLength(255).HasColumnName("Images_LogoHorizontal").HasComment("Logo-horizontal");
  38. owned.Property(x => x.OgDefault).HasMaxLength(255).HasColumnName("Images_OgDefault").HasComment("og-default");
  39. owned.Property(x => x.TwitterImage).HasMaxLength(255).HasColumnName("Images_TwitterImage").HasComment("Twitter-image");
  40. owned.Property(x => x.AppleTouchIcon).HasMaxLength(255).HasColumnName("Images_AppleTouchIcon").HasComment("Apple-touch-icon");
  41. owned.Property(x => x.AppIcon_192).HasMaxLength(255).HasColumnName("Images_AppIcon_192").HasComment("App-icon-192");
  42. owned.Property(x => x.AppIcon_512).HasMaxLength(255).HasColumnName("Images_AppIcon_512").HasComment("App-icon-512");
  43. });
  44. builder.OwnsOne(x => x.Meta, owned =>
  45. {
  46. owned.Property(x => x.Keywords).HasMaxLength(255).HasColumnName("Meta_Keywords").HasComment("Meta Keywords");
  47. owned.Property(x => x.Description).HasMaxLength(255).HasColumnName("Meta_Description").HasComment("Meta Description");
  48. owned.Property(x => x.Author).HasMaxLength(255).HasColumnName("Meta_Author").HasComment("Meta Author");
  49. owned.Property(x => x.Viewport).HasMaxLength(255).HasColumnName("Meta_Viewport").HasComment("Meta Viewport");
  50. owned.Property(x => x.ApplicationName).HasMaxLength(255).HasColumnName("Meta_ApplicationName").HasComment("Meta Application Name");
  51. owned.Property(x => x.Generator).HasMaxLength(255).HasColumnName("Meta_Generator").HasComment("Meta Generator");
  52. owned.Property(x => x.Robots).HasMaxLength(255).HasColumnName("Meta_Robots").HasComment("Meta Robots");
  53. });
  54. builder.OwnsOne(x => x.Company, owned =>
  55. {
  56. owned.Property(x => x.Name).HasMaxLength(70).HasColumnName("Company_Name").HasComment("상호 명");
  57. owned.Property(x => x.RegNo).HasMaxLength(100).HasColumnName("Company_RegNo").HasComment("사업자 등록 번호");
  58. owned.Property(x => x.Address).HasMaxLength(255).HasColumnName("Company_Address").HasComment("사업장 소재지");
  59. owned.Property(x => x.ZipCode).HasMaxLength(8).HasColumnName("Company_ZipCode").HasComment("사업장 주소(우편번호)");
  60. owned.Property(x => x.Owner).HasMaxLength(50).HasColumnName("Company_Owner").HasComment("대표자 명");
  61. owned.Property(x => x.Tel).HasMaxLength(20).HasColumnName("Company_Tel").HasComment("대표 전화번호");
  62. owned.Property(x => x.Fax).HasMaxLength(20).HasColumnName("Company_Fax").HasComment("FAX");
  63. owned.Property(x => x.RetailSaleNo).HasMaxLength(20).HasColumnName("Company_RetailSaleNo").HasComment("통신판매업 신고번호");
  64. owned.Property(x => x.AddedSaleNo).HasMaxLength(20).HasColumnName("Company_AddedSaleNo").HasComment("부가통신 사업자번호");
  65. owned.Property(x => x.Hosting).HasMaxLength(100).HasColumnName("Company_Hosting").HasComment("호스팅 서비스");
  66. owned.Property(x => x.AdminName).HasMaxLength(70).HasColumnName("Company_AdminName").HasComment("정보관리책임자");
  67. owned.Property(x => x.AdminEmail).HasMaxLength(100).HasColumnName("Company_AdminEmail").HasComment("정보관리책임자 이메일");
  68. owned.Property(x => x.SiteUrl).HasMaxLength(200).HasColumnName("Company_SiteUrl").HasComment("사이트 주소");
  69. owned.Property(x => x.BankCode).HasMaxLength(10).HasColumnName("Company_BankCode").HasComment("입금계좌 - 은행");
  70. owned.Property(x => x.BankOwner).HasMaxLength(70).HasColumnName("Company_BankOwner").HasComment("입금계좌 - 예금주");
  71. owned.Property(x => x.BankNumber).HasMaxLength(100).HasColumnName("Company_BankNumber").HasComment("입금계좌 - 계좌번호");
  72. });
  73. builder.OwnsOne(x => x.Account, owned =>
  74. {
  75. owned.Property(x => x.IsRegisterBlock).HasColumnName("Account_IsRegisterBlock").HasComment("회원가입 차단");
  76. owned.Property(x => x.IsRegisterEmailAuth).HasColumnName("Account_IsRegisterEmailAuth").HasComment("회원가입 시 이메일 인증");
  77. owned.Property(x => x.PasswordMinLength).HasColumnName("Account_PasswordMinLength").HasComment("비밀번호 최소 길이");
  78. owned.Property(x => x.PasswordUppercaseLength).HasColumnName("Account_PasswordUppercaseLength").HasComment("비밀번호 최소 대문자 수");
  79. owned.Property(x => x.PasswordNumbersLength).HasColumnName("Account_PasswordNumbersLength").HasComment("비밀번호 최소 숫자 수");
  80. owned.Property(x => x.PasswordSpecialcharsLength).HasColumnName("Account_PasswordSpecialcharsLength").HasComment("비밀번호 최소 특수문자 수");
  81. owned.Property(x => x.DeniedEmailList).HasColumnName("Account_DeniedEmailList").HasComment("금지 이메일");
  82. owned.Property(x => x.DeniedNameList).HasColumnName("Account_DeniedNameList").HasComment("금지 별명");
  83. owned.Property(x => x.ChangeEmailDay).HasColumnName("Account_ChangeEmailDay").HasComment("이메일 갱신 주기(일)");
  84. owned.Property(x => x.ChangeNameDay).HasColumnName("Account_ChangeNameDay").HasComment("별명 갱신 주기(일)");
  85. owned.Property(x => x.ChangeSummaryDay).HasColumnName("Account_ChangeSummaryDay").HasComment("한마디 갱신 주기(일)");
  86. owned.Property(x => x.ChangeIntroDay).HasColumnName("Account_ChangeIntroDay").HasComment("자기소개 갱신 주기(일)");
  87. owned.Property(x => x.ChangePasswordDay).HasColumnName("Account_ChangePasswordDay").HasComment("비밀번호 갱신 주기(일)");
  88. owned.Property(x => x.MaxLoginTryCount).HasColumnName("Account_MaxLoginTryCount").HasComment("로그인 시도 제한 횟수");
  89. owned.Property(x => x.MaxLoginTryLimitSecond).HasColumnName("Account_MaxLoginTryLimitSecond").HasComment("로그인 시도 제한 시간(초)");
  90. });
  91. builder.OwnsOne(x => x.EmailTemplate, owned =>
  92. {
  93. owned.Property(x => x.RegisterEmailFormTitle).HasColumnName("EmailTemplate_RegisterEmailFormTitle").HasComment("회원가입 시 - 제목");
  94. owned.Property(x => x.RegisterEmailFormContent).HasColumnName("EmailTemplate_RegisterEmailFormContent").HasComment("회원가입 시 - 내용");
  95. owned.Property(x => x.RegistrationEmailFormTitle).HasColumnName("EmailTemplate_RegistrationEmailFormTitle").HasComment("회원가입 완료 - 제목");
  96. owned.Property(x => x.RegistrationEmailFormContent).HasColumnName("EmailTemplate_RegistrationEmailFormContent").HasComment("회원가입 완료 - 내용");
  97. owned.Property(x => x.ResetPasswordEmailFormTitle).HasColumnName("EmailTemplate_ResetPasswordEmailFormTitle").HasComment("비밀번호 재설정 - 제목");
  98. owned.Property(x => x.ResetPasswordEmailFormContent).HasColumnName("EmailTemplate_ResetPasswordEmailFormContent").HasComment("비밀번호 재설정 - 내용");
  99. owned.Property(x => x.ChangedPasswordEmailFormTitle).HasColumnName("EmailTemplate_ChangedPasswordEmailFormTitle").HasComment("비밀번호 변경 완료 - 제목");
  100. owned.Property(x => x.ChangedPasswordEmailFormContent).HasColumnName("EmailTemplate_ChangedPasswordEmailFormContent").HasComment("비밀번호 변경 완료 - 내용");
  101. owned.Property(x => x.WithdrawEmailFormTitle).HasColumnName("EmailTemplate_WithdrawEmailFormTitle").HasComment("회원탈퇴 시 - 제목");
  102. owned.Property(x => x.WithdrawEmailFormContent).HasColumnName("EmailTemplate_WithdrawEmailFormContent").HasComment("회원탈퇴 시 - 내용");
  103. owned.Property(x => x.EmailVerifyFormTitle).HasColumnName("EmailTemplate_EmailVerifyFormTitle").HasComment("이메일 변경 시 - 제목");
  104. owned.Property(x => x.EmailVerifyFormContent).HasColumnName("EmailTemplate_EmailVerifyFormContent").HasComment("이메일 변경 시 - 내용");
  105. owned.Property(x => x.ChangedEmailFormTitle).HasColumnName("EmailTemplate_ChangedEmailFormTitle").HasComment("이메일 변경 완료 - 제목");
  106. owned.Property(x => x.ChangedEmailFormContent).HasColumnName("EmailTemplate_ChangedEmailFormContent").HasComment("이메일 변경 완료 - 내용");
  107. });
  108. builder.OwnsOne(x => x.External, owned =>
  109. {
  110. owned.Property(x => x.YouTubeApiKeyEnc).HasColumnName("External_YouTubeApiKeyEnc").HasComment("YouTube API Key (암호화 저장 권장)");
  111. owned.Property(x => x.YouTubeApiName).HasColumnName("External_YouTubeApiName").HasComment("YouTube API Name");
  112. owned.Property(x => x.GoogleClientId).HasColumnName("External_GoogleClientId").HasComment("Google Client ID");
  113. owned.Property(x => x.GoogleClientSecretEnc).HasColumnName("External_GoogleClientSecretEnc").HasComment("Google Client Secret (암호화 저장 권장)");
  114. owned.Property(x => x.GoogleAppId).HasColumnName("External_GoogleAppId").HasComment("Google APP ID");
  115. });
  116. builder.OwnsOne(x => x.Payment, owned => { });
  117. builder.OwnsOne(x => x.Crypto, owned =>
  118. {
  119. owned.Property(x => x.TickerRefreshSeconds).IsRequired().HasColumnName("Crypto_TickerRefreshSeconds").HasDefaultValue(5).HasComment("시세 업데이트 주기 (초)");
  120. owned.Property(x => x.SurgeThreshold).IsRequired().HasColumnType("decimal(5,2)").HasColumnName("Crypto_SurgeThreshold").HasDefaultValue(5.0m).HasComment("급등 임계값 (%)");
  121. owned.Property(x => x.PlungeThreshold).IsRequired().HasColumnType("decimal(5,2)").HasColumnName("Crypto_PlungeThreshold").HasDefaultValue(-5.0m).HasComment("급락 임계값 (%)");
  122. owned.Property(x => x.MainPageCoinCount).IsRequired().HasColumnName("Crypto_MainPageCoinCount").HasDefaultValue(10).HasComment("메인 페이지 기본 표시 코인 수");
  123. });
  124. }
  125. }