mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-12 11:04:25 +00:00
26c8113930
* feat: change user command side * feat: change user command side * feat: use states on write model * feat: command and query side in auth api * feat: auth commands * feat: check external idp id * feat: user state check * fix: error messages * fix: is active state
37 lines
988 B
Go
37 lines
988 B
Go
package command
|
|
|
|
import (
|
|
"github.com/caos/zitadel/internal/eventstore/v2"
|
|
"github.com/caos/zitadel/internal/v2/domain"
|
|
"github.com/caos/zitadel/internal/v2/repository/policy"
|
|
)
|
|
|
|
type PasswordLockoutPolicyWriteModel struct {
|
|
eventstore.WriteModel
|
|
|
|
MaxAttempts uint64
|
|
ShowLockOutFailures bool
|
|
State domain.PolicyState
|
|
}
|
|
|
|
func (wm *PasswordLockoutPolicyWriteModel) Reduce() error {
|
|
for _, event := range wm.Events {
|
|
switch e := event.(type) {
|
|
case *policy.PasswordLockoutPolicyAddedEvent:
|
|
wm.MaxAttempts = e.MaxAttempts
|
|
wm.ShowLockOutFailures = e.ShowLockOutFailures
|
|
wm.State = domain.PolicyStateActive
|
|
case *policy.PasswordLockoutPolicyChangedEvent:
|
|
if e.MaxAttempts != nil {
|
|
wm.MaxAttempts = *e.MaxAttempts
|
|
}
|
|
if e.ShowLockOutFailures != nil {
|
|
wm.ShowLockOutFailures = *e.ShowLockOutFailures
|
|
}
|
|
case *policy.PasswordLockoutPolicyRemovedEvent:
|
|
wm.State = domain.PolicyStateRemoved
|
|
}
|
|
}
|
|
return wm.WriteModel.Reduce()
|
|
}
|