summaryrefslogtreecommitdiffstats
path: root/api/WhatApi/Database/Tables/AuditTrail.cs
diff options
context:
space:
mode:
Diffstat (limited to 'api/WhatApi/Database/Tables/AuditTrail.cs')
-rw-r--r--api/WhatApi/Database/Tables/AuditTrail.cs39
1 files changed, 39 insertions, 0 deletions
diff --git a/api/WhatApi/Database/Tables/AuditTrail.cs b/api/WhatApi/Database/Tables/AuditTrail.cs
new file mode 100644
index 0000000..4ded46c
--- /dev/null
+++ b/api/WhatApi/Database/Tables/AuditTrail.cs
@@ -0,0 +1,39 @@
+namespace WhatApi.Database.Tables;
+
+public class AuditTrail
+{
+ public Guid Id { get; init; }
+ public Guid? UserId { get; init; }
+ public required string EntityName { get; init; }
+ public string? PrimaryKey { get; set; }
+ public TrailType TrailType { get; set; }
+ public DateTimeOffset DateUtc { get; init; }
+
+ public Dictionary<string, object?> OldValues { get; init; } = [];
+ public Dictionary<string, object?> NewValues { get; init; } = [];
+ public List<string> ChangedColumns { get; init; } = [];
+}
+
+public class AuditTrailConfiguration : IEntityTypeConfiguration<AuditTrail>
+{
+ public void Configure(EntityTypeBuilder<AuditTrail> builder)
+ {
+ builder.ToTable("audit_trails");
+ builder.HasIndex(e => e.EntityName);
+ builder.Property(e => e.EntityName).HasMaxLength(100).IsRequired();
+ builder.Property(e => e.PrimaryKey).HasMaxLength(100);
+ builder.Property(e => e.DateUtc).IsRequired();
+ builder.Property(e => e.TrailType).HasConversion<string>();
+ builder.Property(e => e.OldValues).HasColumnType("jsonb");
+ builder.Property(e => e.NewValues).HasColumnType("jsonb");
+ builder.Property(e => e.ChangedColumns).HasColumnType("jsonb");
+ }
+}
+
+public enum TrailType : byte
+{
+ None = 0,
+ Create = 1,
+ Update = 2,
+ Delete = 3
+} \ No newline at end of file