2020-11-25 20:04:32 +01:00
|
|
|
package iam
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2021-01-20 11:06:52 +01:00
|
|
|
|
2020-11-25 20:04:32 +01:00
|
|
|
"github.com/caos/zitadel/internal/crypto"
|
|
|
|
"github.com/caos/zitadel/internal/eventstore/v2"
|
2020-11-26 13:14:07 +01:00
|
|
|
"github.com/caos/zitadel/internal/eventstore/v2/repository"
|
2021-01-04 14:52:13 +01:00
|
|
|
"github.com/caos/zitadel/internal/v2/domain"
|
|
|
|
"github.com/caos/zitadel/internal/v2/repository/idpconfig"
|
2020-11-25 20:04:32 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
2021-01-04 14:52:13 +01:00
|
|
|
IDPOIDCConfigAddedEventType eventstore.EventType = "iam.idp." + idpconfig.OIDCConfigAddedEventType
|
|
|
|
IDPOIDCConfigChangedEventType eventstore.EventType = "iam.idp." + idpconfig.ConfigChangedEventType
|
2020-11-25 20:04:32 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type IDPOIDCConfigAddedEvent struct {
|
2021-01-04 14:52:13 +01:00
|
|
|
idpconfig.OIDCConfigAddedEvent
|
2020-11-25 20:04:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewIDPOIDCConfigAddedEvent(
|
|
|
|
ctx context.Context,
|
|
|
|
clientID,
|
|
|
|
idpConfigID,
|
|
|
|
issuer string,
|
|
|
|
clientSecret *crypto.CryptoValue,
|
|
|
|
idpDisplayNameMapping,
|
2021-01-04 14:52:13 +01:00
|
|
|
userNameMapping domain.OIDCMappingField,
|
2020-11-25 20:04:32 +01:00
|
|
|
scopes ...string,
|
|
|
|
) *IDPOIDCConfigAddedEvent {
|
|
|
|
|
|
|
|
return &IDPOIDCConfigAddedEvent{
|
2021-01-04 14:52:13 +01:00
|
|
|
OIDCConfigAddedEvent: *idpconfig.NewOIDCConfigAddedEvent(
|
2020-11-25 20:04:32 +01:00
|
|
|
eventstore.NewBaseEventForPush(
|
|
|
|
ctx,
|
|
|
|
IDPOIDCConfigAddedEventType,
|
|
|
|
),
|
|
|
|
clientID,
|
|
|
|
idpConfigID,
|
|
|
|
issuer,
|
|
|
|
clientSecret,
|
|
|
|
idpDisplayNameMapping,
|
|
|
|
userNameMapping,
|
|
|
|
scopes...,
|
|
|
|
),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-26 13:14:07 +01:00
|
|
|
func IDPOIDCConfigAddedEventMapper(event *repository.Event) (eventstore.EventReader, error) {
|
2021-01-04 14:52:13 +01:00
|
|
|
e, err := idpconfig.OIDCConfigAddedEventMapper(event)
|
2020-11-26 13:14:07 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2021-01-04 14:52:13 +01:00
|
|
|
return &IDPOIDCConfigAddedEvent{OIDCConfigAddedEvent: *e.(*idpconfig.OIDCConfigAddedEvent)}, nil
|
2020-11-26 13:14:07 +01:00
|
|
|
}
|
|
|
|
|
2020-11-25 20:04:32 +01:00
|
|
|
type IDPOIDCConfigChangedEvent struct {
|
2021-01-04 14:52:13 +01:00
|
|
|
idpconfig.OIDCConfigChangedEvent
|
2020-11-25 20:04:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewIDPOIDCConfigChangedEvent(
|
|
|
|
ctx context.Context,
|
2021-01-20 11:06:52 +01:00
|
|
|
idpConfigID string,
|
|
|
|
changes []idpconfig.OIDCConfigChanges,
|
|
|
|
) (*IDPOIDCConfigChangedEvent, error) {
|
|
|
|
changeEvent, err := idpconfig.NewOIDCConfigChangedEvent(
|
|
|
|
eventstore.NewBaseEventForPush(ctx, IDPOIDCConfigChangedEventType),
|
|
|
|
idpConfigID,
|
|
|
|
changes,
|
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
2020-11-25 20:04:32 +01:00
|
|
|
}
|
2021-01-20 11:06:52 +01:00
|
|
|
return &IDPOIDCConfigChangedEvent{OIDCConfigChangedEvent: *changeEvent}, nil
|
2020-11-25 20:04:32 +01:00
|
|
|
}
|
2020-11-26 13:14:07 +01:00
|
|
|
|
|
|
|
func IDPOIDCConfigChangedEventMapper(event *repository.Event) (eventstore.EventReader, error) {
|
2021-01-04 14:52:13 +01:00
|
|
|
e, err := idpconfig.OIDCConfigChangedEventMapper(event)
|
2020-11-26 13:14:07 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2021-01-04 14:52:13 +01:00
|
|
|
return &IDPOIDCConfigChangedEvent{OIDCConfigChangedEvent: *e.(*idpconfig.OIDCConfigChangedEvent)}, nil
|
2020-11-26 13:14:07 +01:00
|
|
|
}
|