diff --git a/src/net/KEFCore/Storage/EntityTypeChanged.cs b/src/net/KEFCore/Storage/EntityTypeChanged.cs index f2f6def8..03f4068c 100644 --- a/src/net/KEFCore/Storage/EntityTypeChanged.cs +++ b/src/net/KEFCore/Storage/EntityTypeChanged.cs @@ -42,6 +42,10 @@ public enum ChangeKindType /// The was removed /// Removed = 4, + /// + /// The was added or updated + /// + Upserted = Added | Updated, } internal EntityTypeChanged(IEntityType entityType, ChangeKindType changeKind, object key) @@ -74,4 +78,8 @@ internal EntityTypeChanged(IEntityType entityType, ChangeKindType changeKind, ob /// Helper to understand if the was removed /// public bool KeyRemoved => ChangeKind.HasFlag(ChangeKindType.Removed); + /// + /// Helper to understand if the was added or updated + /// + public bool KeyUpserted => ChangeKind.HasFlag(ChangeKindType.Added) | ChangeKind.HasFlag(ChangeKindType.Updated); } diff --git a/src/net/KEFCore/Storage/Internal/EntityTypeProducer.cs b/src/net/KEFCore/Storage/Internal/EntityTypeProducer.cs index cc497435..7bef6792 100644 --- a/src/net/KEFCore/Storage/Internal/EntityTypeProducer.cs +++ b/src/net/KEFCore/Storage/Internal/EntityTypeProducer.cs @@ -300,7 +300,7 @@ private void KafkaCompactedReplicator_OnRemoteUpdate(IKNetCompactedReplicator { - _onChangeEvent?.Invoke(new EntityTypeChanged(_entityType, arg1.ContainsKey(arg2.Key) ? EntityTypeChanged.ChangeKindType.Updated : EntityTypeChanged.ChangeKindType.Added, arg2.Key)); + _onChangeEvent?.Invoke(new EntityTypeChanged(_entityType, EntityTypeChanged.ChangeKindType.Upserted, arg2.Key)); }); }