using NPin.Framework.AuditLogging.Domain.Shared.Consts; using SqlSugar; using Volo.Abp.Auditing; using Volo.Abp.Domain.Entities; using Volo.Abp.Guids; using Volo.Abp.MultiTenancy; namespace NPin.Framework.AuditLogging.Domain.Entities; [SugarTable("NPinEntityChange")] [SugarIndex($"index_{nameof(AuditLogId)}", nameof(AuditLogId), OrderByType.Asc)] [SugarIndex($"index_{nameof(TenantId)}_{nameof(EntityId)}", nameof(TenantId), OrderByType.Asc, nameof(EntityTypeFullName), OrderByType.Asc, nameof(EntityId), OrderByType.Asc)] public class EntityChangeEntity : Entity, IMultiTenant { [SugarColumn(ColumnName = "Id", IsPrimaryKey = true)] public override Guid Id { get; protected set; } public virtual Guid AuditLogId { get; protected set; } public virtual Guid? TenantId { get; protected set; } public virtual DateTime? ChangeTime { get; protected set; } public virtual EntityChangeType? ChangeType { get; protected set; } public virtual Guid? EntityTenantId { get; protected set; } public virtual string? EntityId { get; protected set; } public virtual string? EntityTypeFullName { get; protected set; } // 关联 [Navigate(NavigateType.OneToMany, nameof(EntityPropertyChangeEntity.EntityChangeId))] public virtual List PropertyChanges { get; protected set; } public EntityChangeEntity() { } public EntityChangeEntity( IGuidGenerator guidGenerator, Guid auditLogId, EntityChangeInfo entityChangeInfo, Guid? tenantId = null) { Id = guidGenerator.Create(); AuditLogId = auditLogId; TenantId = tenantId; ChangeTime = entityChangeInfo.ChangeTime; ChangeType = entityChangeInfo.ChangeType; EntityTenantId = entityChangeInfo.EntityTenantId; EntityId = entityChangeInfo.EntityId.Truncate(EntityChangeConsts.MaxEntityTypeFullNameLength); EntityTypeFullName = entityChangeInfo.EntityTypeFullName.TruncateFromBeginning(EntityChangeConsts.MaxEntityTypeFullNameLength); PropertyChanges = entityChangeInfo .PropertyChanges? .Select(p => new EntityPropertyChangeEntity(guidGenerator, Id, p, tenantId)) .ToList() ?? new List(); } }