A plugin for Microsoft.EntityFrameworkCore
that enables automatic recording of data change history.
To enable automatic recording of data changes in your application, configure your DbContext to utilize the audit logging functionality.
Follow these steps:
-
Configure Audit Settings
In yourDbContext
class, configure the audit settings by calling theApplyAuditSettings
method. This allows you to define whether all entities should be audited by default or only those explicitly configured. -
Apply Audit Entry Configuration
Specify how audit entries should be stored by calling theApplyAuditEntryConfiguration
method. You can pass a custom audit entity type, such asCustomAuditEntity
, to define the structure of your audit logs. -
Load Audit Configurations If you have custom audit configurations defined in your assembly, use the
ApplyAuditConfigurationsFromAssembly
method. This will automatically load and apply these configurations based on the types defined in your application.
internal sealed class AppDbContext : DbContext
{
public AppDbContext(DbContextOptions<AppDbContext> options)
: base(options)
{
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder
.ApplyAuditSettings(options => options.OnlyConfiguredAudited())
.ApplyAuditEntryConfiguration<CustomAuditEntity>()
.ApplyAuditConfigurationsFromAssembly(typeof(AppDbContext).Assembly);
}
}
To enable automatic audit logging for your Entity Framework Core context, you need to register an interceptor that will monitor and log changes during SaveChanges operations. This can be done by adding an interceptor to the DbContext when configuring it in your application's service container.
Here’s an example of how to register the AuditSaveChangesInterceptor:
builder.Services.AddDbContext<AppDbContext>(options =>
{
options.UseNpgsql(builder.Configuration.GetConnectionString("DefaultConnection"));
options.AddInterceptors(new AuditSaveChangesInterceptor());
});
If your application requires a custom audit entity, you can extend the functionality by creating a custom interceptor.
This custom interceptor can override the behavior of the default interceptor to accommodate the specific fields or properties your audit entity might have.
For example, consider a custom audit entity CustomAuditEntity that includes an additional CreatedBy property:
public class CustomAuditEntity : AuditEntry
{
/// <summary>
/// Gets or sets the entity identifier.
/// </summary>
public string CreatedBy { get; set; }
}
To support this custom entity, you would create a custom interceptor by extending AuditSaveChangesInterceptorBase
:
internal sealed class AuditSaveChangesInterceptor : AuditSaveChangesInterceptorBase<CustomAuditEntity>
{
protected override Func<CustomAuditEntity> AuditEntryFactory()
{
return () => new CustomAuditEntity()
{
CreatedBy = "some logic to get the current user",
};
}
}
The UserAuditConfiguration
class is used to define how the User entity is handled during auditing. By implementing the IAuditConfiguration
interface, you can control which properties are included or excluded in the audit records.
internal sealed class UserAuditConfiguration : IAuditConfiguration<User>
{
public void Configure(AuditTypeConfigurationBuilder<User> configurationBuilder)
{
configurationBuilder.IgnoreProperty(x => x.Password);
}
}
Alternatively, the UserAuditConfiguration
class can be configured to completely exclude the User
entity from being audited. This means that any changes to User records will not be logged.
internal sealed class UserAuditConfiguration : IAuditConfiguration<User>
{
public void Configure(AuditTypeConfigurationBuilder<User> configurationBuilder)
{
configurationBuilder.ExcludeEntity();
}
}