2021-01-04 14:52:13 +01:00
|
|
|
package query
|
2020-12-11 15:49:19 +01:00
|
|
|
|
2021-01-04 14:52:13 +01:00
|
|
|
import (
|
|
|
|
"github.com/caos/zitadel/internal/eventstore/v2"
|
|
|
|
"github.com/caos/zitadel/internal/v2/repository/policy"
|
|
|
|
)
|
2020-12-11 15:49:19 +01:00
|
|
|
|
2021-01-04 14:52:13 +01:00
|
|
|
type PasswordLockoutPolicyReadModel struct {
|
2020-12-11 15:49:19 +01:00
|
|
|
eventstore.ReadModel
|
|
|
|
|
|
|
|
MaxAttempts uint64
|
|
|
|
ShowLockOutFailures bool
|
|
|
|
}
|
|
|
|
|
2021-01-04 14:52:13 +01:00
|
|
|
func (rm *PasswordLockoutPolicyReadModel) Reduce() error {
|
2020-12-11 15:49:19 +01:00
|
|
|
for _, event := range rm.Events {
|
|
|
|
switch e := event.(type) {
|
2021-01-04 14:52:13 +01:00
|
|
|
case *policy.PasswordLockoutPolicyAddedEvent:
|
2020-12-11 15:49:19 +01:00
|
|
|
rm.MaxAttempts = e.MaxAttempts
|
|
|
|
rm.ShowLockOutFailures = e.ShowLockOutFailures
|
2021-01-04 14:52:13 +01:00
|
|
|
case *policy.PasswordLockoutPolicyChangedEvent:
|
2021-01-06 11:12:56 +01:00
|
|
|
if e.MaxAttempts != nil {
|
|
|
|
rm.MaxAttempts = *e.MaxAttempts
|
|
|
|
}
|
|
|
|
if e.ShowLockOutFailures != nil {
|
|
|
|
rm.ShowLockOutFailures = *e.ShowLockOutFailures
|
|
|
|
}
|
2020-12-11 15:49:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return rm.ReadModel.Reduce()
|
|
|
|
}
|