From 65c143397772e0c2458a243f4110863854478ddc Mon Sep 17 00:00:00 2001 From: sunpengfei <i@angelzzz.com> Date: 星期三, 20 八月 2025 15:58:19 +0800 Subject: [PATCH] feat:开发 --- FlexJobApi.Core/Utils/DbUtils/DbUtils.cs | 51 +++++++++++++++++++++++++++++---------------------- 1 files changed, 29 insertions(+), 22 deletions(-) diff --git a/FlexJobApi.Core/Utils/DbUtils/DbUtils.cs b/FlexJobApi.Core/Utils/DbUtils/DbUtils.cs index d06c426..156ecab 100644 --- a/FlexJobApi.Core/Utils/DbUtils/DbUtils.cs +++ b/FlexJobApi.Core/Utils/DbUtils/DbUtils.cs @@ -568,37 +568,44 @@ continue; } - Db.GetRepository<DbAuditLog, LogDbContextLocator>().InsertNow(new DbAuditLog + var log = new DbAuditLog { Id = IDGen.NextID(), TableName = entityType.Name, PrimaryKey = (Guid)entity.Property("Id").CurrentValue, - NewValues = entity.State == EntityState.Added || entity.State == EntityState.Modified - ? GetPropertyValuesAsJson(entity) - : null, - OldValues = entity.State == EntityState.Deleted || entity.State == EntityState.Modified - ? GetPropertyValuesAsJson(entity, entity.State == EntityState.Modified) - : null, - Operate = entity.State == EntityState.Added - ? EnumDbAuditOperate.Added - : entity.State == EntityState.Modified - ? EnumDbAuditOperate.Modified - : EnumDbAuditOperate.Deleted, TraceId = App.GetTraceId(), CreatedTime = DateTime.Now, CreatedUserId = logier?.Id, CreatedEnterpriseId = logier?.EnterpriseId - }); + }; + log.Operate = + entity.State == EntityState.Added + ? EnumDbAuditOperate.Added + : entity.State == EntityState.Modified + ? EnumDbAuditOperate.Modified + : EnumDbAuditOperate.Deleted; + if (entity.Property(nameof(CommonEntity.IsDeleted)).CurrentValue is bool isDeleted && isDeleted == true) + { + log.Operate = EnumDbAuditOperate.Deleted; + } + log.NewValues = + log.Operate == EnumDbAuditOperate.Deleted + ? null + : JsonConvert.SerializeObject(entity.Properties + .Where(p => log.Operate == EnumDbAuditOperate.Modified + ? p.IsModified + : true) + .ToDictionary(p => p.Metadata.Name, p => p.CurrentValue)); + log.OldValues = + log.Operate == EnumDbAuditOperate.Added + ? null + : JsonConvert.SerializeObject(entity.Properties + .Where(p => log.Operate == EnumDbAuditOperate.Modified + ? p.IsModified + : true) + .ToDictionary(p => p.Metadata.Name, p => p.OriginalValue)); + Db.GetRepository<DbAuditLog, LogDbContextLocator>().InsertNow(log); } - } - - private static string GetPropertyValuesAsJson(EntityEntry entry, bool getOldValues = false) - { - var properties = entry.Properties - .Where(p => getOldValues ? p.IsModified : true) - .ToDictionary(p => p.Metadata.Name, p => getOldValues ? p.OriginalValue : p.CurrentValue); - - return JsonConvert.SerializeObject(properties); } } } -- Gitblit v1.9.1