mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-13 19:44:21 +00:00
21ffe1b0cb
* fix: split command query side * fix: split command query side * fix: members in correct pkg structure * fix: label policy in correct pkg structure * fix: structure * fix: structure of login policy * fix: identityprovider structure * fix: org iam policy structure * fix: password age policy structure * fix: password complexity policy structure * fix: password lockout policy structure * fix: idp structure * fix: user events structure * fix: user write model * fix: profile email changed command * fix: address changed command * fix: user states * fix: user * fix: org structure and add human * begin iam setup command side * setup * step2 * step2 * fix: add user * step2 * isvalid * fix: folder structure v2 business Co-authored-by: Fabiennne <fabienne.gerschwiler@gmail.com>
62 lines
1.5 KiB
Go
62 lines
1.5 KiB
Go
package query
|
|
|
|
import (
|
|
"github.com/caos/zitadel/internal/crypto"
|
|
"github.com/caos/zitadel/internal/eventstore/v2"
|
|
"github.com/caos/zitadel/internal/v2/domain"
|
|
"github.com/caos/zitadel/internal/v2/repository/idpconfig"
|
|
)
|
|
|
|
type OIDCConfigReadModel struct {
|
|
eventstore.ReadModel
|
|
|
|
IDPConfigID string
|
|
ClientID string
|
|
ClientSecret *crypto.CryptoValue
|
|
Issuer string
|
|
Scopes []string
|
|
IDPDisplayNameMapping domain.OIDCMappingField
|
|
UserNameMapping domain.OIDCMappingField
|
|
}
|
|
|
|
func (rm *OIDCConfigReadModel) Reduce() error {
|
|
for _, event := range rm.Events {
|
|
switch e := event.(type) {
|
|
case *idpconfig.OIDCConfigAddedEvent:
|
|
rm.reduceConfigAddedEvent(e)
|
|
case *idpconfig.OIDCConfigChangedEvent:
|
|
rm.reduceConfigChangedEvent(e)
|
|
}
|
|
}
|
|
|
|
return rm.ReadModel.Reduce()
|
|
}
|
|
|
|
func (rm *OIDCConfigReadModel) reduceConfigAddedEvent(e *idpconfig.OIDCConfigAddedEvent) {
|
|
rm.IDPConfigID = e.IDPConfigID
|
|
rm.ClientID = e.ClientID
|
|
rm.ClientSecret = e.ClientSecret
|
|
rm.Issuer = e.Issuer
|
|
rm.Scopes = e.Scopes
|
|
rm.IDPDisplayNameMapping = e.IDPDisplayNameMapping
|
|
rm.UserNameMapping = e.UserNameMapping
|
|
}
|
|
|
|
func (rm *OIDCConfigReadModel) reduceConfigChangedEvent(e *idpconfig.OIDCConfigChangedEvent) {
|
|
if e.ClientID != "" {
|
|
rm.ClientID = e.ClientID
|
|
}
|
|
if e.Issuer != "" {
|
|
rm.Issuer = e.Issuer
|
|
}
|
|
if len(e.Scopes) > 0 {
|
|
rm.Scopes = e.Scopes
|
|
}
|
|
if e.IDPDisplayNameMapping.Valid() {
|
|
rm.IDPDisplayNameMapping = e.IDPDisplayNameMapping
|
|
}
|
|
if e.UserNameMapping.Valid() {
|
|
rm.UserNameMapping = e.UserNameMapping
|
|
}
|
|
}
|