mirror of
https://github.com/zitadel/zitadel.git
synced 2025-08-12 00:07:36 +00:00
fix: add user metadata to the features (#2179)
* fix: add user metadata to the features * fix: remove user metadata * fix: add test * fix: add test
This commit is contained in:
@@ -2,6 +2,7 @@ package command
|
||||
|
||||
import (
|
||||
"github.com/caos/zitadel/internal/eventstore"
|
||||
"github.com/caos/zitadel/internal/repository/metadata"
|
||||
"github.com/caos/zitadel/internal/repository/user"
|
||||
)
|
||||
|
||||
@@ -28,6 +29,8 @@ func (wm *UserMetadataWriteModel) AppendEvents(events ...eventstore.EventReader)
|
||||
wm.MetadataWriteModel.AppendEvents(&e.SetEvent)
|
||||
case *user.MetadataRemovedEvent:
|
||||
wm.MetadataWriteModel.AppendEvents(&e.RemovedEvent)
|
||||
case *user.MetadataRemovedAllEvent:
|
||||
wm.MetadataWriteModel.AppendEvents(&e.RemovedAllEvent)
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -44,7 +47,8 @@ func (wm *UserMetadataWriteModel) Query() *eventstore.SearchQueryBuilder {
|
||||
AggregateTypes(user.AggregateType).
|
||||
EventTypes(
|
||||
user.MetadataSetType,
|
||||
user.MetadataRemovedType).
|
||||
user.MetadataRemovedType,
|
||||
user.MetadataRemovedAllType).
|
||||
Builder()
|
||||
}
|
||||
|
||||
@@ -71,6 +75,8 @@ func (wm *UserMetadataListWriteModel) AppendEvents(events ...eventstore.EventRea
|
||||
wm.MetadataListWriteModel.AppendEvents(&e.SetEvent)
|
||||
case *user.MetadataRemovedEvent:
|
||||
wm.MetadataListWriteModel.AppendEvents(&e.RemovedEvent)
|
||||
case *user.MetadataRemovedAllEvent:
|
||||
wm.MetadataListWriteModel.AppendEvents(&e.RemovedAllEvent)
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -87,6 +93,69 @@ func (wm *UserMetadataListWriteModel) Query() *eventstore.SearchQueryBuilder {
|
||||
AggregateTypes(user.AggregateType).
|
||||
EventTypes(
|
||||
user.MetadataSetType,
|
||||
user.MetadataRemovedType).
|
||||
user.MetadataRemovedType,
|
||||
user.MetadataRemovedAllType).
|
||||
Builder()
|
||||
}
|
||||
|
||||
type UserMetadataByOrgListWriteModel struct {
|
||||
eventstore.WriteModel
|
||||
resourceOwner string
|
||||
UserMetadata map[string]map[string][]byte
|
||||
}
|
||||
|
||||
func NewUserMetadataByOrgListWriteModel(resourceOwner string) *UserMetadataByOrgListWriteModel {
|
||||
return &UserMetadataByOrgListWriteModel{
|
||||
resourceOwner: resourceOwner,
|
||||
UserMetadata: make(map[string]map[string][]byte),
|
||||
}
|
||||
}
|
||||
|
||||
func (wm *UserMetadataByOrgListWriteModel) AppendEvents(events ...eventstore.EventReader) {
|
||||
for _, event := range events {
|
||||
switch e := event.(type) {
|
||||
case *user.MetadataSetEvent:
|
||||
wm.WriteModel.AppendEvents(&e.SetEvent)
|
||||
case *user.MetadataRemovedEvent:
|
||||
wm.WriteModel.AppendEvents(&e.RemovedEvent)
|
||||
case *user.MetadataRemovedAllEvent:
|
||||
wm.WriteModel.AppendEvents(&e.RemovedAllEvent)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func (wm *UserMetadataByOrgListWriteModel) Reduce() error {
|
||||
for _, event := range wm.Events {
|
||||
switch e := event.(type) {
|
||||
case *metadata.SetEvent:
|
||||
if val, ok := wm.UserMetadata[e.Aggregate().ID]; ok {
|
||||
val[e.Key] = e.Value
|
||||
} else {
|
||||
wm.UserMetadata[e.Aggregate().ID] = map[string][]byte{
|
||||
e.Key: e.Value,
|
||||
}
|
||||
}
|
||||
case *metadata.RemovedEvent:
|
||||
if val, ok := wm.UserMetadata[e.Aggregate().ID]; ok {
|
||||
delete(val, e.Key)
|
||||
}
|
||||
case *metadata.RemovedAllEvent:
|
||||
if _, ok := wm.UserMetadata[e.Aggregate().ID]; ok {
|
||||
delete(wm.UserMetadata, e.Aggregate().ID)
|
||||
}
|
||||
}
|
||||
}
|
||||
return wm.WriteModel.Reduce()
|
||||
}
|
||||
|
||||
func (wm *UserMetadataByOrgListWriteModel) Query() *eventstore.SearchQueryBuilder {
|
||||
return eventstore.NewSearchQueryBuilder(eventstore.ColumnsEvent).
|
||||
ResourceOwner(wm.ResourceOwner).
|
||||
AddQuery().
|
||||
AggregateTypes(user.AggregateType).
|
||||
EventTypes(
|
||||
user.MetadataSetType,
|
||||
user.MetadataRemovedType,
|
||||
user.MetadataRemovedAllType).
|
||||
Builder()
|
||||
}
|
||||
|
Reference in New Issue
Block a user