mirror of
https://github.com/zitadel/zitadel.git
synced 2025-04-26 04:40:50 +00:00

* features * features * features * fix json tags * add features handler to auth * mocks for tests * add setup step * fixes * add featurelist to auth api * grandfather state and typos * typo * merge new-eventstore * fix login policy tests * label policy in features * audit log retention
96 lines
2.6 KiB
Go
96 lines
2.6 KiB
Go
package command
|
|
|
|
import (
|
|
"github.com/caos/zitadel/internal/domain"
|
|
"github.com/caos/zitadel/internal/eventstore"
|
|
"github.com/caos/zitadel/internal/repository/org"
|
|
)
|
|
|
|
type OrgSecondFactorWriteModel struct {
|
|
SecondFactorWriteModel
|
|
}
|
|
|
|
func NewOrgSecondFactorWriteModel(orgID string, factorType domain.SecondFactorType) *OrgSecondFactorWriteModel {
|
|
return &OrgSecondFactorWriteModel{
|
|
SecondFactorWriteModel{
|
|
WriteModel: eventstore.WriteModel{
|
|
AggregateID: orgID,
|
|
ResourceOwner: orgID,
|
|
},
|
|
MFAType: factorType,
|
|
},
|
|
}
|
|
}
|
|
|
|
func (wm *OrgSecondFactorWriteModel) AppendEvents(events ...eventstore.EventReader) {
|
|
for _, event := range events {
|
|
switch e := event.(type) {
|
|
case *org.LoginPolicySecondFactorAddedEvent:
|
|
if wm.MFAType == e.MFAType {
|
|
wm.WriteModel.AppendEvents(&e.SecondFactorAddedEvent)
|
|
}
|
|
case *org.LoginPolicySecondFactorRemovedEvent:
|
|
if wm.MFAType == e.MFAType {
|
|
wm.WriteModel.AppendEvents(&e.SecondFactorRemovedEvent)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func (wm *OrgSecondFactorWriteModel) Reduce() error {
|
|
return wm.SecondFactorWriteModel.Reduce()
|
|
}
|
|
|
|
func (wm *OrgSecondFactorWriteModel) Query() *eventstore.SearchQueryBuilder {
|
|
return eventstore.NewSearchQueryBuilder(eventstore.ColumnsEvent, org.AggregateType).
|
|
AggregateIDs(wm.WriteModel.AggregateID).
|
|
ResourceOwner(wm.ResourceOwner).
|
|
EventTypes(
|
|
org.LoginPolicySecondFactorAddedEventType,
|
|
org.LoginPolicySecondFactorRemovedEventType)
|
|
}
|
|
|
|
type OrgMultiFactorWriteModel struct {
|
|
MultiFactorWriteModel
|
|
}
|
|
|
|
func NewOrgMultiFactorWriteModel(orgID string, factorType domain.MultiFactorType) *OrgMultiFactorWriteModel {
|
|
return &OrgMultiFactorWriteModel{
|
|
MultiFactorWriteModel{
|
|
WriteModel: eventstore.WriteModel{
|
|
AggregateID: orgID,
|
|
ResourceOwner: orgID,
|
|
},
|
|
MFAType: factorType,
|
|
},
|
|
}
|
|
}
|
|
|
|
func (wm *OrgMultiFactorWriteModel) AppendEvents(events ...eventstore.EventReader) {
|
|
for _, event := range events {
|
|
switch e := event.(type) {
|
|
case *org.LoginPolicyMultiFactorAddedEvent:
|
|
if wm.MFAType == e.MFAType {
|
|
wm.WriteModel.AppendEvents(&e.MultiFactorAddedEvent)
|
|
}
|
|
case *org.LoginPolicyMultiFactorRemovedEvent:
|
|
if wm.MFAType == e.MFAType {
|
|
wm.WriteModel.AppendEvents(&e.MultiFactorRemovedEvent)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func (wm *OrgMultiFactorWriteModel) Reduce() error {
|
|
return wm.MultiFactorWriteModel.Reduce()
|
|
}
|
|
|
|
func (wm *OrgMultiFactorWriteModel) Query() *eventstore.SearchQueryBuilder {
|
|
return eventstore.NewSearchQueryBuilder(eventstore.ColumnsEvent, org.AggregateType).
|
|
AggregateIDs(wm.WriteModel.AggregateID).
|
|
ResourceOwner(wm.ResourceOwner).
|
|
EventTypes(
|
|
org.LoginPolicyMultiFactorAddedEventType,
|
|
org.LoginPolicyMultiFactorRemovedEventType)
|
|
}
|