mirror of
https://github.com/zitadel/zitadel.git
synced 2025-10-15 06:51:18 +00:00
write model
This commit is contained in:
@@ -21,8 +21,6 @@ type Aggregate struct {
|
||||
|
||||
SetUpStarted Step
|
||||
SetUpDone Step
|
||||
|
||||
Members MembersAggregate
|
||||
}
|
||||
|
||||
func NewAggregate(
|
||||
@@ -42,6 +40,12 @@ func NewAggregate(
|
||||
}
|
||||
}
|
||||
|
||||
func AggregateFromWriteModel(wm *eventstore.WriteModel) *Aggregate {
|
||||
return &Aggregate{
|
||||
Aggregate: *eventstore.AggregateFromWriteModel(wm, AggregateType, AggregateVersion),
|
||||
}
|
||||
}
|
||||
|
||||
func AggregateFromReadModel(rm *ReadModel) *Aggregate {
|
||||
return &Aggregate{
|
||||
Aggregate: *eventstore.NewAggregate(rm.AggregateID, AggregateType, rm.ResourceOwner, AggregateVersion, rm.ProcessedSequence),
|
||||
|
@@ -31,6 +31,32 @@ func (rm *MemberReadModel) AppendEvents(events ...eventstore.EventReader) (err e
|
||||
return nil
|
||||
}
|
||||
|
||||
type MemberWriteModel struct {
|
||||
member.WriteModel
|
||||
}
|
||||
|
||||
func PrepareMemberWriteModel(iamID, userID string) *MemberWriteModel {
|
||||
return &MemberWriteModel{
|
||||
WriteModel: *member.PrepareWriteModel(userID, AggregateType, iamID),
|
||||
}
|
||||
}
|
||||
|
||||
func (wm *MemberWriteModel) AppendEvents(events ...eventstore.EventReader) (err error) {
|
||||
for _, event := range events {
|
||||
switch e := event.(type) {
|
||||
case *MemberAddedEvent:
|
||||
wm.WriteModel.AppendEvents(&e.AddedEvent)
|
||||
case *MemberChangedEvent:
|
||||
wm.WriteModel.AppendEvents(&e.ChangedEvent)
|
||||
case *MemberRemovedEvent:
|
||||
wm.WriteModel.AppendEvents(&e.RemovedEvent)
|
||||
default:
|
||||
wm.WriteModel.AppendEvents(e)
|
||||
}
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
type MemberAddedEvent struct {
|
||||
member.AddedEvent
|
||||
}
|
||||
@@ -63,7 +89,7 @@ func NewMemberAddedEvent(
|
||||
func NewMemberChangedEvent(
|
||||
ctx context.Context,
|
||||
current,
|
||||
changed *MemberAggregate,
|
||||
changed *MemberWriteModel,
|
||||
) (*MemberChangedEvent, error) {
|
||||
|
||||
m, err := member.NewChangedEvent(
|
||||
|
@@ -6,10 +6,6 @@ import (
|
||||
"github.com/caos/zitadel/internal/v2/repository/members"
|
||||
)
|
||||
|
||||
type MembersAggregate struct {
|
||||
members.Aggregate
|
||||
}
|
||||
|
||||
type MembersReadModel struct {
|
||||
members.ReadModel
|
||||
}
|
||||
|
Reference in New Issue
Block a user