mirror of
https://github.com/zitadel/zitadel.git
synced 2025-11-06 19:21:26 +00:00
* feat: login policy * feat: password complexity policy * feat: org iam policy * feat: label policy * feat: add and change policies * feat: second factors * feat: second and multi factors * feat: better naming * feat: better naming
36 lines
878 B
Go
36 lines
878 B
Go
package login
|
|
|
|
import (
|
|
"github.com/caos/zitadel/internal/eventstore/v2"
|
|
)
|
|
|
|
type ReadModel struct {
|
|
eventstore.ReadModel
|
|
|
|
AllowUserNamePassword bool
|
|
AllowRegister bool
|
|
AllowExternalIDP bool
|
|
ForceMFA bool
|
|
PasswordlessType PasswordlessType
|
|
}
|
|
|
|
func (rm *ReadModel) Reduce() error {
|
|
for _, event := range rm.Events {
|
|
switch e := event.(type) {
|
|
case *AddedEvent:
|
|
rm.AllowUserNamePassword = e.AllowUserNamePassword
|
|
rm.AllowExternalIDP = e.AllowExternalIDP
|
|
rm.AllowRegister = e.AllowRegister
|
|
rm.ForceMFA = e.ForceMFA
|
|
rm.PasswordlessType = e.PasswordlessType
|
|
case *ChangedEvent:
|
|
rm.AllowUserNamePassword = e.AllowUserNamePassword
|
|
rm.AllowExternalIDP = e.AllowExternalIDP
|
|
rm.AllowRegister = e.AllowRegister
|
|
rm.ForceMFA = e.ForceMFA
|
|
rm.PasswordlessType = e.PasswordlessType
|
|
}
|
|
}
|
|
return rm.ReadModel.Reduce()
|
|
}
|