API
Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

DataContext.cs 8.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. using Microsoft.EntityFrameworkCore;
  2. using UnivateProperties_API.Model.Communication;
  3. using UnivateProperties_API.Model.Users;
  4. using UnivateProperties_API.Model.Properties;
  5. using UnivateProperties_API.Model.Region;
  6. using UnivateProperties_API.Model.Timeshare;
  7. using System.Linq;
  8. using UnivateProperties_API.Model;
  9. using UnivateProperties_API.Model.Banks;
  10. using UnivateProperties_API.Model.Misc;
  11. using UnivateProperties_API.Model.ProcessFlow;
  12. using UnivateProperties_API.Model.Logging;
  13. namespace UnivateProperties_API.Context
  14. {
  15. public class DataContext : DbContext
  16. {
  17. public DataContext(DbContextOptions<DataContext> options) : base(options)
  18. {
  19. }
  20. #region User
  21. public virtual DbSet<Agency> Agencies { get; set; }
  22. public virtual DbSet<Agent> Agents { get; set; }
  23. public virtual DbSet<User> Users { get; set; }
  24. public virtual DbSet<Individual> Individuals { get; set; }
  25. public virtual DbSet<Address> Addresses { get; set; }
  26. #endregion User
  27. #region Communication
  28. public virtual DbSet<Email> Emails { get; set; }
  29. public virtual DbSet<SMTPAccount> Accounts { get; set; }
  30. public virtual DbSet<SMTPHost> Hosts { get; set; }
  31. public virtual DbSet<Template> Templates { get; set; }
  32. public virtual DbSet<PlaceHolder> PlaceHolders { get; set; }
  33. #endregion Communication
  34. #region Property
  35. public DbSet<Property> Properties { get; set; }
  36. public DbSet<PropertyImage> PropertyImages { get; set; }
  37. public DbSet<PropertyType> PropertyTypes { get; set; }
  38. public DbSet<PropertyUserField> PropertyUserFields { get; set; }
  39. public DbSet<UserDefinedField> UserDefinedFields { get; set; }
  40. public DbSet<UserDefinedGroup> UserDefinedGroups { get; set; }
  41. #endregion
  42. #region Region
  43. public DbSet<Province> Provinces { get; set; }
  44. public DbSet<City> Cities { get; set; }
  45. public DbSet<Suburb> Suburbs { get; set; }
  46. #endregion
  47. #region Timeshare
  48. public DbSet<TimeshareWeek> Weeks { get; set; }
  49. public DbSet<Status> Status { get; set; }
  50. public DbSet<UnitConfiguration> UnitConfigurations { get; set; }
  51. public DbSet<UnitConfigurationType> UnitConfigurationTypes { get; set; }
  52. public DbSet<Season> Seasons { get; set; }
  53. public DbSet<Bank> Banks { get; set; }
  54. public DbSet<BankAccount> BankAccounts { get; set; }
  55. #endregion Timeshare
  56. #region ProcessFlow
  57. public DbSet<ProcessFlow> ProcessFlows { get; set; }
  58. public DbSet<BidItem> BidItems { get; set; }
  59. #endregion
  60. #region Logs
  61. public DbSet<SearchLog> SearchLogs { get; set; }
  62. #endregion
  63. #region Misc
  64. public DbSet<Location> Location { get; set; }
  65. #endregion
  66. public override int SaveChanges()
  67. {
  68. foreach (var item in ChangeTracker
  69. .Entries()
  70. .Where(x => x.State == EntityState.Modified || x.State == EntityState.Added)
  71. .Select(x => x.Entity)
  72. .ToList())
  73. {
  74. if (item is BaseEntity)
  75. {
  76. (item as BaseEntity).UpdateModified(string.Empty);
  77. }
  78. }
  79. UpdateSoftDeleteStatuses();
  80. return base.SaveChanges();
  81. }
  82. private void UpdateSoftDeleteStatuses()
  83. {
  84. foreach (var entry in ChangeTracker.Entries())
  85. {
  86. switch (entry.State)
  87. {
  88. case EntityState.Added:
  89. entry.CurrentValues["IsDeleted"] = false;
  90. break;
  91. case EntityState.Deleted:
  92. entry.State = EntityState.Modified;
  93. entry.CurrentValues["IsDeleted"] = true;
  94. break;
  95. }
  96. }
  97. }
  98. protected override void OnModelCreating(ModelBuilder modelBuilder)
  99. {
  100. modelBuilder.Entity<SMTPHost>().ToTable("Hosts");
  101. modelBuilder.Entity<UnitConfiguration>()
  102. .HasIndex(u => u.Code)
  103. .IsUnique();
  104. modelBuilder.Entity<Individual>(b =>
  105. {
  106. b.HasKey(e => e.Id);
  107. b.Property(e => e.Id).ValueGeneratedOnAdd();
  108. });
  109. modelBuilder.Entity<Individual>()
  110. .HasIndex(i => new { i.Telephone, i.CellNumber, i.Email })
  111. .IsUnique(true);
  112. modelBuilder.Entity<Agent>(b =>
  113. {
  114. b.HasKey(e => e.Id);
  115. b.Property(e => e.Id).ValueGeneratedOnAdd();
  116. });
  117. modelBuilder.Entity<Agency>(b =>
  118. {
  119. b.HasKey(e => e.Id);
  120. b.Property(e => e.Id).ValueGeneratedOnAdd();
  121. });
  122. modelBuilder.Entity<Person>(b =>
  123. {
  124. b.HasKey(e => e.Id);
  125. b.Property(e => e.Id).ValueGeneratedOnAdd();
  126. });
  127. modelBuilder.Entity<User>()
  128. .HasIndex(u => u.Username)
  129. .IsUnique(true);
  130. modelBuilder.Entity<Email>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  131. modelBuilder.Entity<SMTPAccount>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  132. modelBuilder.Entity<SMTPHost>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  133. modelBuilder.Entity<Property>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  134. modelBuilder.Entity<PropertyImage>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  135. modelBuilder.Entity<PropertyType>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  136. modelBuilder.Entity<PropertyUserField>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  137. modelBuilder.Entity<UserDefinedField>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  138. modelBuilder.Entity<UserDefinedGroup>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  139. modelBuilder.Entity<City>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  140. modelBuilder.Entity<Province>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  141. modelBuilder.Entity<Suburb>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  142. modelBuilder.Entity<Season>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  143. modelBuilder.Entity<Status>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  144. modelBuilder.Entity<TimeshareWeek>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  145. modelBuilder.Entity<UnitConfiguration>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  146. modelBuilder.Entity<UnitConfigurationType>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  147. modelBuilder.Entity<Agency>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  148. modelBuilder.Entity<Person>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  149. modelBuilder.Entity<User>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  150. modelBuilder.Entity<Bank>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  151. modelBuilder.Entity<BankAccount>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  152. modelBuilder.Entity<SearchLog>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  153. modelBuilder.Entity<Address>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  154. modelBuilder.Entity<BidItem>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  155. modelBuilder.Entity<ProcessFlow>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  156. modelBuilder.Entity<Template>().HasQueryFilter(m => EF.Property<bool>(m, "IsDeleted") == false);
  157. }
  158. }
  159. }