API
Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

DataContext.cs 9.7KB

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