// using System; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Infrastructure; using Microsoft.EntityFrameworkCore.Storage.ValueConversion; using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; using ROLAC.API.Data; #nullable disable namespace ROLAC.API.Migrations { [DbContext(typeof(AppDbContext))] partial class AppDbContextModelSnapshot : ModelSnapshot { protected override void BuildModel(ModelBuilder modelBuilder) { #pragma warning disable 612, 618 modelBuilder .HasAnnotation("ProductVersion", "8.0.11") .HasAnnotation("Relational:MaxIdentifierLength", 63); NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("ClaimType") .HasColumnType("text"); b.Property("ClaimValue") .HasColumnType("text"); b.Property("RoleId") .IsRequired() .HasColumnType("text"); b.HasKey("Id"); b.HasIndex("RoleId"); b.ToTable("AspNetRoleClaims", (string)null); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("ClaimType") .HasColumnType("text"); b.Property("ClaimValue") .HasColumnType("text"); b.Property("UserId") .IsRequired() .HasColumnType("text"); b.HasKey("Id"); b.HasIndex("UserId"); b.ToTable("AspNetUserClaims", (string)null); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b => { b.Property("LoginProvider") .HasColumnType("text"); b.Property("ProviderKey") .HasColumnType("text"); b.Property("ProviderDisplayName") .HasColumnType("text"); b.Property("UserId") .IsRequired() .HasColumnType("text"); b.HasKey("LoginProvider", "ProviderKey"); b.HasIndex("UserId"); b.ToTable("AspNetUserLogins", (string)null); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b => { b.Property("UserId") .HasColumnType("text"); b.Property("RoleId") .HasColumnType("text"); b.HasKey("UserId", "RoleId"); b.HasIndex("RoleId"); b.ToTable("AspNetUserRoles", (string)null); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b => { b.Property("UserId") .HasColumnType("text"); b.Property("LoginProvider") .HasColumnType("text"); b.Property("Name") .HasColumnType("text"); b.Property("Value") .HasColumnType("text"); b.HasKey("UserId", "LoginProvider", "Name"); b.ToTable("AspNetUserTokens", (string)null); }); modelBuilder.Entity("ROLAC.API.Entities.AppRole", b => { b.Property("Id") .HasColumnType("text"); b.Property("ConcurrencyStamp") .IsConcurrencyToken() .HasColumnType("text"); b.Property("Description") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("Name") .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("NormalizedName") .HasMaxLength(256) .HasColumnType("character varying(256)"); b.HasKey("Id"); b.HasIndex("NormalizedName") .IsUnique() .HasDatabaseName("RoleNameIndex"); b.ToTable("AspNetRoles", (string)null); }); modelBuilder.Entity("ROLAC.API.Entities.AppUser", b => { b.Property("Id") .HasColumnType("text"); b.Property("AccessFailedCount") .HasColumnType("integer"); b.Property("ConcurrencyStamp") .IsConcurrencyToken() .HasColumnType("text"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("Email") .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("EmailConfirmed") .HasColumnType("boolean"); b.Property("IsActive") .HasColumnType("boolean"); b.Property("LanguagePreference") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(10) .HasColumnType("character varying(10)") .HasDefaultValue("en"); b.Property("LastLoginAt") .HasColumnType("timestamp with time zone"); b.Property("LockoutEnabled") .HasColumnType("boolean"); b.Property("LockoutEnd") .HasColumnType("timestamp with time zone"); b.Property("MemberId") .HasColumnType("integer"); b.Property("NormalizedEmail") .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("NormalizedUserName") .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("PasswordHash") .HasColumnType("text"); b.Property("PhoneNumber") .HasColumnType("text"); b.Property("PhoneNumberConfirmed") .HasColumnType("boolean"); b.Property("SecurityStamp") .HasColumnType("text"); b.Property("TwoFactorEnabled") .HasColumnType("boolean"); b.Property("UserName") .HasMaxLength(256) .HasColumnType("character varying(256)"); b.HasKey("Id"); b.HasIndex("MemberId") .IsUnique() .HasFilter("\"MemberId\" IS NOT NULL"); b.HasIndex("NormalizedEmail") .HasDatabaseName("EmailIndex"); b.HasIndex("NormalizedUserName") .IsUnique() .HasDatabaseName("UserNameIndex"); b.ToTable("AspNetUsers", (string)null); }); modelBuilder.Entity("ROLAC.API.Entities.Check", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Amount") .HasColumnType("decimal(18,2)"); b.Property("CheckDate") .HasColumnType("date"); b.Property("CheckNumber") .IsRequired() .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("DeletedAt") .HasColumnType("timestamp with time zone"); b.Property("DeletedBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("IsDeleted") .HasColumnType("boolean"); b.Property("IssuedAt") .HasColumnType("timestamp with time zone"); b.Property("IssuedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("MemberId") .HasColumnType("integer"); b.Property("Memo") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("PayeeAddress") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("PayeeCity") .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("PayeeName") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("PayeeState") .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("PayeeType") .IsRequired() .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("PayeeZip") .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("ReceiptCapturedBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("ReceiptSignatureBlobPath") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("ReceiptSignedAt") .HasColumnType("timestamp with time zone"); b.Property("ReceiptSignedName") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("Status") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(20) .HasColumnType("character varying(20)") .HasDefaultValue("Issued"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("VoidReason") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("VoidedAt") .HasColumnType("timestamp with time zone"); b.Property("VoidedBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("CheckDate"); b.HasIndex("CheckNumber") .IsUnique() .HasFilter("\"IsDeleted\" = false"); b.HasIndex("MemberId"); b.HasIndex("Status") .HasFilter("\"IsDeleted\" = false"); b.ToTable("Checks"); }); modelBuilder.Entity("ROLAC.API.Entities.CheckLine", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Amount") .HasColumnType("decimal(18,2)"); b.Property("CheckId") .HasColumnType("integer"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Description") .IsRequired() .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("ExpenseId") .HasColumnType("integer"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("CheckId"); b.HasIndex("ExpenseId"); b.ToTable("CheckLines"); }); modelBuilder.Entity("ROLAC.API.Entities.ChurchProfile", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Address") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("BankAccountNumber") .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("BankName") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("BankRoutingNumber") .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("City") .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Email") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("Name") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("NameZh") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("NextCheckNumber") .HasColumnType("integer"); b.Property("Phone") .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("State") .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Website") .HasMaxLength(300) .HasColumnType("character varying(300)"); b.Property("ZipCode") .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("xmin") .IsConcurrencyToken() .ValueGeneratedOnAddOrUpdate() .HasColumnType("xid") .HasColumnName("xmin"); b.HasKey("Id"); b.ToTable("ChurchProfiles"); }); modelBuilder.Entity("ROLAC.API.Entities.Expense", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Amount") .HasColumnType("decimal(18,2)"); b.Property("CheckNumber") .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("DeletedAt") .HasColumnType("timestamp with time zone"); b.Property("DeletedBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Description") .IsRequired() .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("ExpenseDate") .HasColumnType("date"); b.Property("IsDeleted") .HasColumnType("boolean"); b.Property("MemberId") .HasColumnType("integer"); b.Property("MinistryId") .HasColumnType("integer"); b.Property("Notes") .HasColumnType("text"); b.Property("PaidAt") .HasColumnType("timestamp with time zone"); b.Property("PaidBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("ReceiptBlobPath") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("ReviewNotes") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("ReviewedAt") .HasColumnType("timestamp with time zone"); b.Property("ReviewedBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Status") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(30) .HasColumnType("character varying(30)") .HasDefaultValue("Draft"); b.Property("SubmittedAt") .HasColumnType("timestamp with time zone"); b.Property("SubmittedBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Type") .IsRequired() .HasMaxLength(30) .HasColumnType("character varying(30)"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("VendorName") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.HasKey("Id"); b.HasIndex("ExpenseDate"); b.HasIndex("MemberId"); b.HasIndex("MinistryId"); b.HasIndex("Status") .HasFilter("\"IsDeleted\" = false"); b.ToTable("Expenses"); }); modelBuilder.Entity("ROLAC.API.Entities.ExpenseCategoryGroup", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Form990LineId") .HasColumnType("integer"); b.Property("IsActive") .HasColumnType("boolean"); b.Property("Name_en") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("Name_zh") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("SortOrder") .HasColumnType("integer"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("Form990LineId"); b.ToTable("ExpenseCategoryGroups"); }); modelBuilder.Entity("ROLAC.API.Entities.ExpenseLine", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Amount") .HasColumnType("decimal(18,2)"); b.Property("CategoryGroupId") .HasColumnType("integer"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Description") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("ExpenseId") .HasColumnType("integer"); b.Property("FunctionalClass") .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("SubCategoryId") .HasColumnType("integer"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("CategoryGroupId"); b.HasIndex("ExpenseId"); b.HasIndex("SubCategoryId"); b.ToTable("ExpenseLines"); }); modelBuilder.Entity("ROLAC.API.Entities.ExpenseSubCategory", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Form990LineId") .HasColumnType("integer"); b.Property("GroupId") .HasColumnType("integer"); b.Property("IsActive") .HasColumnType("boolean"); b.Property("Name_en") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("Name_zh") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("SortOrder") .HasColumnType("integer"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("Form990LineId"); b.HasIndex("GroupId"); b.ToTable("ExpenseSubCategories"); }); modelBuilder.Entity("ROLAC.API.Entities.FamilyUnit", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasColumnType("text"); b.Property("FamilyName_en") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("FamilyName_zh") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("Notes") .HasColumnType("text"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasColumnType("text"); b.HasKey("Id"); b.ToTable("FamilyUnits"); }); modelBuilder.Entity("ROLAC.API.Entities.Form990ExpenseLine", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("IsActive") .HasColumnType("boolean"); b.Property("LineCode") .IsRequired() .HasMaxLength(10) .HasColumnType("character varying(10)"); b.Property("Name_en") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("Name_zh") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("SortOrder") .HasColumnType("integer"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("LineCode") .IsUnique(); b.ToTable("Form990ExpenseLines"); }); modelBuilder.Entity("ROLAC.API.Entities.Giving", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Amount") .HasColumnType("decimal(18,2)"); b.Property("CheckNumber") .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("GivingCategoryId") .HasColumnType("integer"); b.Property("GivingDate") .HasColumnType("date"); b.Property("IsAnonymous") .HasColumnType("boolean"); b.Property("MemberId") .HasColumnType("integer"); b.Property("Notes") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("OfferingSessionId") .HasColumnType("integer"); b.Property("PayPalTransactionId") .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("PaymentMethod") .IsRequired() .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("ZelleReferenceCode") .HasMaxLength(100) .HasColumnType("character varying(100)"); b.HasKey("Id"); b.HasIndex("GivingCategoryId"); b.HasIndex("GivingDate"); b.HasIndex("OfferingSessionId") .HasFilter("\"OfferingSessionId\" IS NOT NULL"); b.HasIndex("MemberId", "GivingDate"); b.ToTable("Givings"); }); modelBuilder.Entity("ROLAC.API.Entities.GivingCategory", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Description_en") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("Description_zh") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("IsActive") .HasColumnType("boolean"); b.Property("Name_en") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("Name_zh") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("SortOrder") .HasColumnType("integer"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.ToTable("GivingCategories"); }); modelBuilder.Entity("ROLAC.API.Entities.Logging.AuditLog", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("bigint"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Action") .IsRequired() .HasMaxLength(40) .HasColumnType("character varying(40)"); b.Property("Category") .IsRequired() .HasMaxLength(40) .HasColumnType("character varying(40)"); b.Property("Changes") .HasColumnType("jsonb"); b.Property("CorrelationId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("EntityId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("EntityName") .HasMaxLength(128) .HasColumnType("character varying(128)"); b.Property("IpAddress") .HasMaxLength(45) .HasColumnType("character varying(45)"); b.Property("Level") .HasColumnType("smallint"); b.Property("Summary") .HasMaxLength(512) .HasColumnType("character varying(512)"); b.Property("Timestamp") .HasColumnType("timestamp with time zone"); b.Property("UserEmail") .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("UserId") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("Action"); b.HasIndex("Timestamp"); b.HasIndex("UserId") .HasFilter("\"UserId\" IS NOT NULL"); b.HasIndex("Category", "Timestamp"); b.HasIndex("EntityName", "EntityId"); b.ToTable("AuditLogs", (string)null); }); modelBuilder.Entity("ROLAC.API.Entities.Logging.SystemLog", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("bigint"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Category") .IsRequired() .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("CorrelationId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("EventId") .HasColumnType("integer"); b.Property("Exception") .HasColumnType("text"); b.Property("HttpMethod") .HasMaxLength(10) .HasColumnType("character varying(10)"); b.Property("IpAddress") .HasMaxLength(45) .HasColumnType("character varying(45)"); b.Property("Level") .HasColumnType("smallint"); b.Property("Message") .IsRequired() .HasColumnType("text"); b.Property("RequestPath") .HasMaxLength(2048) .HasColumnType("character varying(2048)"); b.Property("StatusCode") .HasColumnType("integer"); b.Property("Timestamp") .HasColumnType("timestamp with time zone"); b.Property("UserId") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("Level"); b.HasIndex("Timestamp"); b.HasIndex("UserId") .HasFilter("\"UserId\" IS NOT NULL"); b.HasIndex("Timestamp", "Level"); b.ToTable("SystemLogs", (string)null); }); modelBuilder.Entity("ROLAC.API.Entities.MealAttendance", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("AdultCount") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasDefaultValue(0); b.Property("AttendanceDate") .HasColumnType("date"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("KidCount") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasDefaultValue(0); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("YouthCount") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasDefaultValue(0); b.HasKey("Id"); b.HasIndex("AttendanceDate") .IsUnique(); b.ToTable("MealAttendances"); }); modelBuilder.Entity("ROLAC.API.Entities.Member", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Address") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("BaptismChurch") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("BaptismDate") .HasColumnType("date"); b.Property("City") .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("Country") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(100) .HasColumnType("character varying(100)") .HasDefaultValue("USA"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("DateOfBirth") .HasColumnType("date"); b.Property("DeletedAt") .HasColumnType("timestamp with time zone"); b.Property("DeletedBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Email") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("Entity") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("FamilyUnitId") .HasColumnType("integer"); b.Property("FirstName_en") .IsRequired() .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("FirstName_zh") .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("Gender") .HasMaxLength(10) .HasColumnType("character varying(10)"); b.Property("IsDeleted") .HasColumnType("boolean"); b.Property("JoinDate") .HasColumnType("date"); b.Property("LanguagePreference") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(10) .HasColumnType("character varying(10)") .HasDefaultValue("en"); b.Property("LastName_en") .IsRequired() .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("LastName_zh") .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("NickName") .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("Notes") .HasColumnType("text"); b.Property("PhoneCell") .HasMaxLength(30) .HasColumnType("character varying(30)"); b.Property("PhoneHome") .HasMaxLength(30) .HasColumnType("character varying(30)"); b.Property("PhotoBlobPath") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("State") .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("Status") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(20) .HasColumnType("character varying(20)") .HasDefaultValue("Member"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("ZipCode") .HasMaxLength(20) .HasColumnType("character varying(20)"); b.HasKey("Id"); b.HasIndex("Email") .HasFilter("\"Email\" IS NOT NULL"); b.HasIndex("FamilyUnitId"); b.HasIndex("Status") .HasFilter("\"IsDeleted\" = false"); b.ToTable("Members"); }); modelBuilder.Entity("ROLAC.API.Entities.Ministry", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("DefaultFunctionalClass") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(20) .HasColumnType("character varying(20)") .HasDefaultValue("Program"); b.Property("Description_en") .HasColumnType("text"); b.Property("Description_zh") .HasColumnType("text"); b.Property("IsActive") .HasColumnType("boolean"); b.Property("Name_en") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("Name_zh") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("SortOrder") .HasColumnType("integer"); b.HasKey("Id"); b.ToTable("Ministries"); }); modelBuilder.Entity("ROLAC.API.Entities.MonthlyStatement", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("BankStatementBalance") .HasColumnType("decimal(18,2)"); b.Property("CalculatedClosingBalance") .HasColumnType("decimal(18,2)"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Difference") .HasColumnType("decimal(18,2)"); b.Property("FinalizedAt") .HasColumnType("timestamp with time zone"); b.Property("FinalizedBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("IsFinalized") .HasColumnType("boolean"); b.Property("Month") .HasColumnType("integer"); b.Property("Notes") .HasColumnType("text"); b.Property("OpeningBalance") .HasColumnType("decimal(18,2)"); b.Property("TotalExpenses") .HasColumnType("decimal(18,2)"); b.Property("TotalGiving") .HasColumnType("decimal(18,2)"); b.Property("TotalOtherIncome") .HasColumnType("decimal(18,2)"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Year") .HasColumnType("integer"); b.HasKey("Id"); b.HasIndex("Year", "Month") .IsUnique(); b.ToTable("MonthlyStatements"); }); modelBuilder.Entity("ROLAC.API.Entities.NotificationSetting", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("EnableEmail") .HasColumnType("boolean"); b.Property("EnableLine") .HasColumnType("boolean"); b.Property("FromAddress") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("FromName") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("LineChannelAccessToken") .IsRequired() .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("LineChannelSecret") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("SmtpHost") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("SmtpPassword") .IsRequired() .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("SmtpPort") .HasColumnType("integer"); b.Property("SmtpUseSsl") .HasColumnType("boolean"); b.Property("SmtpUser") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.ToTable("NotificationSettings"); }); modelBuilder.Entity("ROLAC.API.Entities.Notifications.LineBindingCode", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Code") .IsRequired() .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("ConsumedAt") .HasColumnType("timestamp with time zone"); b.Property("ExpiresAt") .HasColumnType("timestamp with time zone"); b.Property("MemberId") .HasColumnType("integer"); b.HasKey("Id"); b.HasIndex("Code"); b.HasIndex("MemberId"); b.ToTable("LineBindingCodes"); }); modelBuilder.Entity("ROLAC.API.Entities.Notifications.MemberChannelBinding", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("BoundAt") .HasColumnType("timestamp with time zone"); b.Property("Channel") .IsRequired() .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("ExternalId") .IsRequired() .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("MemberId") .HasColumnType("integer"); b.HasKey("Id"); b.HasIndex("Channel", "ExternalId") .IsUnique(); b.HasIndex("MemberId", "Channel") .IsUnique(); b.ToTable("MemberChannelBindings"); }); modelBuilder.Entity("ROLAC.API.Entities.Notifications.MessagingGroup", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Channel") .IsRequired() .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("ExternalId") .IsRequired() .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("IsActive") .HasColumnType("boolean"); b.Property("Name") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("RegisteredAt") .HasColumnType("timestamp with time zone"); b.HasKey("Id"); b.HasIndex("Channel", "ExternalId") .IsUnique(); b.ToTable("MessagingGroups"); }); modelBuilder.Entity("ROLAC.API.Entities.Notifications.NotificationLog", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("bigint"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Body") .IsRequired() .HasColumnType("text"); b.Property("Channel") .IsRequired() .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("Error") .HasColumnType("text"); b.Property("MemberId") .HasColumnType("integer"); b.Property("MessagingGroupId") .HasColumnType("integer"); b.Property("SentAt") .HasColumnType("timestamp with time zone"); b.Property("SentByUserId") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Status") .IsRequired() .HasMaxLength(20) .HasColumnType("character varying(20)"); b.Property("Subject") .HasMaxLength(300) .HasColumnType("character varying(300)"); b.Property("TargetExternalId") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("TargetType") .IsRequired() .HasMaxLength(20) .HasColumnType("character varying(20)"); b.HasKey("Id"); b.HasIndex("Channel"); b.HasIndex("MemberId"); b.HasIndex("MessagingGroupId"); b.HasIndex("SentAt"); b.ToTable("NotificationLogs"); }); modelBuilder.Entity("ROLAC.API.Entities.OfferingSession", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CashTotal") .HasColumnType("decimal(18,2)"); b.Property("CheckTotal") .HasColumnType("decimal(18,2)"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Difference") .HasColumnType("decimal(18,2)"); b.Property("Notes") .HasColumnType("text"); b.Property("ProofPdfPath") .HasMaxLength(500) .HasColumnType("character varying(500)"); b.Property("ReconciledAt") .HasColumnType("timestamp with time zone"); b.Property("ReconciledBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("SessionDate") .HasColumnType("date"); b.Property("Status") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(20) .HasColumnType("character varying(20)") .HasDefaultValue("Draft"); b.Property("SubmittedAt") .HasColumnType("timestamp with time zone"); b.Property("SubmittedBy") .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("SystemTotal") .HasColumnType("decimal(18,2)"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("SessionDate") .IsUnique(); b.ToTable("OfferingSessions"); }); modelBuilder.Entity("ROLAC.API.Entities.RefreshToken", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("DeviceInfo") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("ExpiresAt") .HasColumnType("timestamp with time zone"); b.Property("IpAddress") .HasMaxLength(45) .HasColumnType("character varying(45)"); b.Property("ReplacedByHash") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("RevokedAt") .HasColumnType("timestamp with time zone"); b.Property("TokenHash") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("UserId") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("TokenHash") .IsUnique(); b.HasIndex("UserId"); b.ToTable("RefreshTokens"); }); modelBuilder.Entity("ROLAC.API.Entities.RolePermission", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CanApprove") .HasColumnType("boolean"); b.Property("CanDelete") .HasColumnType("boolean"); b.Property("CanRead") .HasColumnType("boolean"); b.Property("CanWrite") .HasColumnType("boolean"); b.Property("Module") .IsRequired() .HasMaxLength(60) .HasColumnType("character varying(60)"); b.Property("RoleId") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("RoleId", "Module") .IsUnique(); b.ToTable("RolePermissions"); }); modelBuilder.Entity("ROLAC.API.Entities.SiteSetting", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("Currency") .IsRequired() .HasMaxLength(10) .HasColumnType("character varying(10)"); b.Property("DateFormat") .IsRequired() .HasMaxLength(50) .HasColumnType("character varying(50)"); b.Property("DefaultLanguage") .IsRequired() .HasMaxLength(10) .HasColumnType("character varying(10)"); b.Property("SiteTitle") .IsRequired() .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("SiteTitleZh") .HasMaxLength(200) .HasColumnType("character varying(200)"); b.Property("TimeZone") .IsRequired() .HasMaxLength(100) .HasColumnType("character varying(100)"); b.Property("UpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("UpdatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.ToTable("SiteSettings"); }); modelBuilder.Entity("ROLAC.API.Entities.UserInvitation", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("CreatedBy") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.Property("ExpiresAt") .HasColumnType("timestamp with time zone"); b.Property("RevokedAt") .HasColumnType("timestamp with time zone"); b.Property("TokenHash") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("UsedAt") .HasColumnType("timestamp with time zone"); b.Property("UserId") .IsRequired() .HasMaxLength(450) .HasColumnType("character varying(450)"); b.HasKey("Id"); b.HasIndex("TokenHash") .IsUnique(); b.HasIndex("UserId"); b.ToTable("UserInvitations"); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b => { b.HasOne("ROLAC.API.Entities.AppRole", null) .WithMany() .HasForeignKey("RoleId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b => { b.HasOne("ROLAC.API.Entities.AppUser", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b => { b.HasOne("ROLAC.API.Entities.AppUser", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b => { b.HasOne("ROLAC.API.Entities.AppRole", null) .WithMany() .HasForeignKey("RoleId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("ROLAC.API.Entities.AppUser", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b => { b.HasOne("ROLAC.API.Entities.AppUser", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("ROLAC.API.Entities.Check", b => { b.HasOne("ROLAC.API.Entities.Member", "Member") .WithMany() .HasForeignKey("MemberId") .OnDelete(DeleteBehavior.SetNull); b.Navigation("Member"); }); modelBuilder.Entity("ROLAC.API.Entities.CheckLine", b => { b.HasOne("ROLAC.API.Entities.Check", "Check") .WithMany("Lines") .HasForeignKey("CheckId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("ROLAC.API.Entities.Expense", "Expense") .WithMany() .HasForeignKey("ExpenseId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.Navigation("Check"); b.Navigation("Expense"); }); modelBuilder.Entity("ROLAC.API.Entities.Expense", b => { b.HasOne("ROLAC.API.Entities.Member", "Member") .WithMany() .HasForeignKey("MemberId") .OnDelete(DeleteBehavior.SetNull); b.HasOne("ROLAC.API.Entities.Ministry", "Ministry") .WithMany() .HasForeignKey("MinistryId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.Navigation("Member"); b.Navigation("Ministry"); }); modelBuilder.Entity("ROLAC.API.Entities.ExpenseCategoryGroup", b => { b.HasOne("ROLAC.API.Entities.Form990ExpenseLine", "Form990Line") .WithMany() .HasForeignKey("Form990LineId") .OnDelete(DeleteBehavior.SetNull); b.Navigation("Form990Line"); }); modelBuilder.Entity("ROLAC.API.Entities.ExpenseLine", b => { b.HasOne("ROLAC.API.Entities.ExpenseCategoryGroup", "CategoryGroup") .WithMany() .HasForeignKey("CategoryGroupId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.HasOne("ROLAC.API.Entities.Expense", "Expense") .WithMany("Lines") .HasForeignKey("ExpenseId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("ROLAC.API.Entities.ExpenseSubCategory", "SubCategory") .WithMany() .HasForeignKey("SubCategoryId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.Navigation("CategoryGroup"); b.Navigation("Expense"); b.Navigation("SubCategory"); }); modelBuilder.Entity("ROLAC.API.Entities.ExpenseSubCategory", b => { b.HasOne("ROLAC.API.Entities.Form990ExpenseLine", "Form990Line") .WithMany() .HasForeignKey("Form990LineId") .OnDelete(DeleteBehavior.SetNull); b.HasOne("ROLAC.API.Entities.ExpenseCategoryGroup", "Group") .WithMany("SubCategories") .HasForeignKey("GroupId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.Navigation("Form990Line"); b.Navigation("Group"); }); modelBuilder.Entity("ROLAC.API.Entities.Giving", b => { b.HasOne("ROLAC.API.Entities.GivingCategory", "GivingCategory") .WithMany() .HasForeignKey("GivingCategoryId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.HasOne("ROLAC.API.Entities.Member", "Member") .WithMany() .HasForeignKey("MemberId") .OnDelete(DeleteBehavior.SetNull); b.HasOne("ROLAC.API.Entities.OfferingSession", "OfferingSession") .WithMany("Givings") .HasForeignKey("OfferingSessionId") .OnDelete(DeleteBehavior.Cascade); b.Navigation("GivingCategory"); b.Navigation("Member"); b.Navigation("OfferingSession"); }); modelBuilder.Entity("ROLAC.API.Entities.Member", b => { b.HasOne("ROLAC.API.Entities.FamilyUnit", "FamilyUnit") .WithMany() .HasForeignKey("FamilyUnitId") .OnDelete(DeleteBehavior.SetNull); b.Navigation("FamilyUnit"); }); modelBuilder.Entity("ROLAC.API.Entities.Notifications.LineBindingCode", b => { b.HasOne("ROLAC.API.Entities.Member", "Member") .WithMany() .HasForeignKey("MemberId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Member"); }); modelBuilder.Entity("ROLAC.API.Entities.Notifications.MemberChannelBinding", b => { b.HasOne("ROLAC.API.Entities.Member", "Member") .WithMany() .HasForeignKey("MemberId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Member"); }); modelBuilder.Entity("ROLAC.API.Entities.Notifications.NotificationLog", b => { b.HasOne("ROLAC.API.Entities.Member", "Member") .WithMany() .HasForeignKey("MemberId") .OnDelete(DeleteBehavior.SetNull); b.HasOne("ROLAC.API.Entities.Notifications.MessagingGroup", "MessagingGroup") .WithMany() .HasForeignKey("MessagingGroupId") .OnDelete(DeleteBehavior.SetNull); b.Navigation("Member"); b.Navigation("MessagingGroup"); }); modelBuilder.Entity("ROLAC.API.Entities.RefreshToken", b => { b.HasOne("ROLAC.API.Entities.AppUser", "User") .WithMany("RefreshTokens") .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("User"); }); modelBuilder.Entity("ROLAC.API.Entities.RolePermission", b => { b.HasOne("ROLAC.API.Entities.AppRole", "Role") .WithMany() .HasForeignKey("RoleId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Role"); }); modelBuilder.Entity("ROLAC.API.Entities.UserInvitation", b => { b.HasOne("ROLAC.API.Entities.AppUser", "User") .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("User"); }); modelBuilder.Entity("ROLAC.API.Entities.AppUser", b => { b.Navigation("RefreshTokens"); }); modelBuilder.Entity("ROLAC.API.Entities.Check", b => { b.Navigation("Lines"); }); modelBuilder.Entity("ROLAC.API.Entities.Expense", b => { b.Navigation("Lines"); }); modelBuilder.Entity("ROLAC.API.Entities.ExpenseCategoryGroup", b => { b.Navigation("SubCategories"); }); modelBuilder.Entity("ROLAC.API.Entities.OfferingSession", b => { b.Navigation("Givings"); }); #pragma warning restore 612, 618 } } }