HRDataContext.cs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
  2. using Microsoft.EntityFrameworkCore;
  3. using MTWorkHR.Core.Entities;
  4. using MTWorkHR.Core.Entities.Base;
  5. using MTWorkHR.Core.Global;
  6. using MTWorkHR.Infrastructure.Entities;
  7. using MTWorkHR.Infrastructure.Data;
  8. using System.Reflection.Emit;
  9. using MTWorkHR.Core.Entities.User;
  10. namespace MTWorkHR.Infrastructure.DBContext
  11. {
  12. public class HRDataContext : IdentityDbContext<ApplicationUser, ApplicationRole, string>
  13. {
  14. private readonly GlobalInfo _globalInfo;
  15. public HRDataContext(DbContextOptions<HRDataContext> options, GlobalInfo globalInfo) : base(options) {
  16. this._globalInfo = globalInfo;
  17. }
  18. public DbSet<AttachmentType> AttachmentTypes { get; set; }
  19. public DbSet<UserAttachment> UserAttachments { get; set; }
  20. public DbSet<Permission> Permissions { get; set; }
  21. public DbSet<RolePermission> RolePermissions { get; set; }
  22. //-------------------------------------
  23. public DbSet<Company> Companies { get; set; }
  24. public DbSet<Project> Projects { get; set; }
  25. // public DbSet<AttachmentType> AttachmentTypes { get; set; }
  26. public DbSet<UserTaskStatus> UserTaskStatuses { get; set; }
  27. public DbSet<UserTask> UserTasks { get; set; }
  28. public DbSet<UserTaskAttachment> UserTaskAttachments { get; set; }
  29. public DbSet<UserTaskHistory> UserTaskHistories { get; set; }
  30. public DbSet<Team> Teams { get; set; }
  31. public DbSet<Meeting> Meetings { get; set; }
  32. public DbSet<Attendance> Attendances { get; set; }
  33. public DbSet<OrderType> OrderTypes { get; set; }
  34. public DbSet<LeaveType> LeaveTypes { get; set; }
  35. public DbSet<OrderAllocation> OrderAllocations { get; set; }
  36. public DbSet<OrderRequest> OrderRequests { get; set; }
  37. public DbSet<ChatMessage> ChatMessages { get; set; }
  38. public DbSet<HubConnection> HubConnections { get; set; }
  39. //-------------------Lookups---------------------------
  40. public DbSet<CountryLookup> CountryLookups { get; set; }
  41. public DbSet<Qualification> Qualifications { get; set; }
  42. public DbSet<University> Universities { get; set; }
  43. public DbSet<Industry> Industries { get; set; }
  44. public DbSet<JobTitle> JobTitles { get; set; }
  45. public DbSet<LoginOTP> LoginOTPs { get; set; }
  46. public DbSet<City> Cities { get; set; }
  47. //-----------
  48. public DbSet<Contract> Contracts { get; set; }
  49. public DbSet<Nationality> Nationalities{ get; set; }
  50. public DbSet<SubscriptionConfiguration> SubscriptionConfiguration { get; set; }
  51. public DbSet<Invoice> Invoices { get; set; }
  52. public DbSet<JobInterview> JobInterviews { get; set; }
  53. //------------------------Logs------------------------
  54. public DbSet<UserLog> UserLogs { get; set; }
  55. public DbSet<AuthLog> AuthLogs { get; set; }
  56. public DbSet<FileLog> FileLogs { get; set; }
  57. public DbSet<RoleLog> RoleLogs { get; set; }
  58. public DbSet<SettingLog> SettingLogs { get; set; }
  59. public DbSet<UserTaskLog> UserTaskLogs { get; set; }
  60. public DbSet<TeamLog> TeamLogs { get; set; }
  61. public DbSet<MeetingLog> MeetingLogs { get; set; }
  62. public DbSet<AttendanceLog> AttendanceLogs { get; set; }
  63. //----------------------------------------
  64. protected override void OnModelCreating(ModelBuilder builder)
  65. {
  66. base.OnModelCreating(builder);
  67. SetGlobalFilters(builder);
  68. builder.ApplyConfigurationsFromAssembly(typeof(HRDataContext).Assembly);
  69. CreateGlobalIndexes(builder);
  70. }
  71. private void SetGlobalFilters(ModelBuilder builder)
  72. {
  73. builder.SetQueryFilterOnAllEntities<ISoftDelete>(p => !p.IsDeleted);
  74. builder.SetQueryFilterOnAllEntities<IHaveCompany>(b => b.CompanyId == _globalInfo.CompanyId);
  75. }
  76. #region SaveChanges
  77. public override Task<int> SaveChangesAsync(CancellationToken cancellationToken = default)
  78. {
  79. BeforeSaveProccess();
  80. return base.SaveChangesAsync(cancellationToken);
  81. }
  82. public override int SaveChanges()
  83. {
  84. BeforeSaveProccess();
  85. return base.SaveChanges();
  86. }
  87. public override int SaveChanges(bool acceptAllChangesOnSuccess)
  88. {
  89. BeforeSaveProccess();
  90. return base.SaveChanges(acceptAllChangesOnSuccess);
  91. }
  92. private void BeforeSaveProccess()
  93. {
  94. var changes = from e in this.ChangeTracker.Entries()
  95. where e.State != EntityState.Unchanged
  96. select e;
  97. foreach (var change in changes)
  98. {
  99. if (change.State == EntityState.Added)
  100. {
  101. if (change.Entity is IAudit)
  102. {
  103. ((IAudit)change.Entity).CreateUser = _globalInfo.UserId;
  104. ((IAudit)change.Entity).CreateDate = DateTime.UtcNow;
  105. }
  106. if ( _globalInfo.CompanyId > 0 && change.Entity is IHaveCompany)
  107. {
  108. ((IHaveCompany)change.Entity).CompanyId = (long)_globalInfo.CompanyId;
  109. }
  110. }
  111. else if (change.State == EntityState.Modified)
  112. {
  113. if (_globalInfo.CompanyId > 0 && change.Entity is IHaveCompany)
  114. {
  115. var originalValues = this.Entry(change.Entity).OriginalValues;
  116. var original = (long)originalValues["CompanyId"];
  117. if (original != (long)_globalInfo.CompanyId)
  118. throw new AppException(ExceptionEnum.NotAuthorized);
  119. }
  120. if (change.Entity is IAudit
  121. && ((change.Entity is IFullAudit && !((IFullAudit)change.Entity).IsDeleted) || change.Entity is not IFullAudit))
  122. {
  123. ((IAudit)change.Entity).UpdateUser = _globalInfo.UserId;
  124. ((IAudit)change.Entity).UpdateDate = DateTime.UtcNow;
  125. }
  126. if (change.Entity is IFullAudit && ((IFullAudit)change.Entity).IsDeleted)
  127. {
  128. ((IFullAudit)change.Entity).DeleteUserId = _globalInfo.UserId;
  129. }
  130. }
  131. else if (change.State == EntityState.Deleted)
  132. {
  133. }
  134. }
  135. }
  136. private void CreateGlobalIndexes(ModelBuilder builder)
  137. {
  138. builder.HasIndexOnAllEntities<IHaveCompany>(p => p.CompanyId);
  139. }
  140. #endregion
  141. }
  142. }