mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-05 14:37:45 +00:00
69 lines
1.5 KiB
Go
69 lines
1.5 KiB
Go
|
package readmodel
|
||
|
|
||
|
import (
|
||
|
"time"
|
||
|
|
||
|
"github.com/zitadel/zitadel/internal/v2/eventstore"
|
||
|
"github.com/zitadel/zitadel/internal/v2/org"
|
||
|
"github.com/zitadel/zitadel/internal/v2/projection"
|
||
|
)
|
||
|
|
||
|
type Org struct {
|
||
|
ID string
|
||
|
Name string
|
||
|
PrimaryDomain *projection.OrgPrimaryDomain
|
||
|
State *projection.OrgState
|
||
|
|
||
|
Sequence uint32
|
||
|
CreationDate time.Time
|
||
|
ChangeDate time.Time
|
||
|
Owner string
|
||
|
}
|
||
|
|
||
|
func NewOrg(id string) *Org {
|
||
|
return &Org{
|
||
|
ID: id,
|
||
|
State: projection.NewStateProjection(id),
|
||
|
PrimaryDomain: projection.NewOrgPrimaryDomain(id),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (rm *Org) Filter() []*eventstore.Filter {
|
||
|
return []*eventstore.Filter{
|
||
|
// we don't need the filters of the projections as we filter all events of the read model
|
||
|
eventstore.NewFilter(
|
||
|
eventstore.AppendAggregateFilter(
|
||
|
org.AggregateType,
|
||
|
eventstore.SetAggregateID(rm.ID),
|
||
|
),
|
||
|
),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (rm *Org) Reduce(events ...*eventstore.StorageEvent) error {
|
||
|
for _, event := range events {
|
||
|
switch event.Type {
|
||
|
case org.AddedType:
|
||
|
added, err := org.AddedEventFromStorage(event)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
rm.Name = added.Payload.Name
|
||
|
rm.Owner = event.Aggregate.Owner
|
||
|
rm.CreationDate = event.CreatedAt
|
||
|
case org.ChangedType:
|
||
|
changed, err := org.ChangedEventFromStorage(event)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
rm.Name = changed.Payload.Name
|
||
|
}
|
||
|
rm.Sequence = event.Sequence
|
||
|
rm.ChangeDate = event.CreatedAt
|
||
|
}
|
||
|
if err := rm.State.Reduce(events...); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return rm.PrimaryDomain.Reduce(events...)
|
||
|
}
|