mirror of
https://github.com/zitadel/zitadel.git
synced 2025-04-24 18:01:50 +00:00

# Which Problems Are Solved Actions v2 are not executed in different functions, as provided by the actions v1. # How the Problems Are Solved Add functionality to call actions v2 through OIDC and SAML logic to complement tokens and SAMLResponses. # Additional Changes - Corrected testing for retrieved intent information - Added testing for IDP types - Corrected handling of context for issuer in SAML logic # Additional Context - Closes #7247 - Dependent on https://github.com/zitadel/saml/pull/97 - docs for migration are done in separate issue: https://github.com/zitadel/zitadel/issues/9456 --------- Co-authored-by: Silvan <27845747+adlerhurst@users.noreply.github.com>
152 lines
3.3 KiB
Go
152 lines
3.3 KiB
Go
package domain
|
|
|
|
import (
|
|
"strconv"
|
|
)
|
|
|
|
type FlowState int32
|
|
|
|
const (
|
|
FlowStateActive FlowState = iota
|
|
FlowStateInactive
|
|
flowStateCount
|
|
)
|
|
|
|
func (s FlowState) Valid() bool {
|
|
return s >= 0 && s < flowStateCount
|
|
}
|
|
|
|
type FlowType int32
|
|
|
|
const (
|
|
FlowTypeUnspecified FlowType = iota
|
|
FlowTypeExternalAuthentication
|
|
FlowTypeCustomiseToken
|
|
FlowTypeInternalAuthentication
|
|
FlowTypeCustomizeSAMLResponse
|
|
flowTypeCount
|
|
)
|
|
|
|
func AllFlowTypes() []FlowType {
|
|
return []FlowType{
|
|
FlowTypeExternalAuthentication,
|
|
FlowTypeCustomiseToken,
|
|
FlowTypeInternalAuthentication,
|
|
FlowTypeCustomizeSAMLResponse,
|
|
}
|
|
}
|
|
|
|
func (s FlowType) Valid() bool {
|
|
return s > 0 && s < flowTypeCount
|
|
}
|
|
|
|
func (s FlowType) HasTrigger(triggerType TriggerType) bool {
|
|
for _, trigger := range s.TriggerTypes() {
|
|
if trigger == triggerType {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func (s FlowType) TriggerTypes() []TriggerType {
|
|
switch s {
|
|
case FlowTypeExternalAuthentication:
|
|
return []TriggerType{
|
|
TriggerTypePostAuthentication,
|
|
TriggerTypePreCreation,
|
|
TriggerTypePostCreation,
|
|
}
|
|
case FlowTypeCustomiseToken:
|
|
return []TriggerType{
|
|
TriggerTypePreUserinfoCreation,
|
|
TriggerTypePreAccessTokenCreation,
|
|
}
|
|
case FlowTypeInternalAuthentication:
|
|
return []TriggerType{
|
|
TriggerTypePostAuthentication,
|
|
TriggerTypePreCreation,
|
|
TriggerTypePostCreation,
|
|
}
|
|
case FlowTypeCustomizeSAMLResponse:
|
|
return []TriggerType{
|
|
TriggerTypePreSAMLResponseCreation,
|
|
}
|
|
default:
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func (s FlowType) ID() string {
|
|
if s < 0 && s >= flowTypeCount {
|
|
return FlowTypeUnspecified.ID()
|
|
}
|
|
return strconv.Itoa(int(s))
|
|
}
|
|
|
|
func (s FlowType) LocalizationKey() string {
|
|
if s < 0 && s >= flowTypeCount {
|
|
return FlowTypeUnspecified.LocalizationKey()
|
|
}
|
|
|
|
switch s {
|
|
case FlowTypeExternalAuthentication:
|
|
return "Action.Flow.Type.ExternalAuthentication"
|
|
case FlowTypeCustomiseToken:
|
|
return "Action.Flow.Type.CustomiseToken"
|
|
case FlowTypeInternalAuthentication:
|
|
return "Action.Flow.Type.InternalAuthentication"
|
|
case FlowTypeCustomizeSAMLResponse:
|
|
return "Action.Flow.Type.CustomizeSAMLResponse"
|
|
default:
|
|
return "Action.Flow.Type.Unspecified"
|
|
}
|
|
}
|
|
|
|
type TriggerType int32
|
|
|
|
const (
|
|
TriggerTypeUnspecified TriggerType = iota
|
|
TriggerTypePostAuthentication
|
|
TriggerTypePreCreation
|
|
TriggerTypePostCreation
|
|
TriggerTypePreUserinfoCreation
|
|
TriggerTypePreAccessTokenCreation
|
|
TriggerTypePreSAMLResponseCreation
|
|
triggerTypeCount
|
|
)
|
|
|
|
func (s TriggerType) Valid() bool {
|
|
return s >= 0 && s < triggerTypeCount
|
|
}
|
|
|
|
func (s TriggerType) ID() string {
|
|
if !s.Valid() {
|
|
return TriggerTypeUnspecified.ID()
|
|
}
|
|
return strconv.Itoa(int(s))
|
|
}
|
|
|
|
func (s TriggerType) LocalizationKey() string {
|
|
if !s.Valid() {
|
|
return FlowTypeUnspecified.LocalizationKey()
|
|
}
|
|
|
|
switch s {
|
|
case TriggerTypePostAuthentication:
|
|
return "Action.TriggerType.PostAuthentication"
|
|
case TriggerTypePreCreation:
|
|
return "Action.TriggerType.PreCreation"
|
|
case TriggerTypePostCreation:
|
|
return "Action.TriggerType.PostCreation"
|
|
case TriggerTypePreUserinfoCreation:
|
|
return "Action.TriggerType.PreUserinfoCreation"
|
|
case TriggerTypePreAccessTokenCreation:
|
|
return "Action.TriggerType.PreAccessTokenCreation"
|
|
case TriggerTypePreSAMLResponseCreation:
|
|
return "Action.TriggerType.PreSAMLResponseCreation"
|
|
default:
|
|
return "Action.TriggerType.Unspecified"
|
|
}
|
|
}
|