mirror of
https://github.com/zitadel/zitadel.git
synced 2025-08-11 21:37:32 +00:00
feat(actions): add token customization flow and extend functionally with modules (#4337)
* fix: potential memory leak * feat(actions): possibility to parse json feat(actions): possibility to perform http calls * add query call * feat(api): list flow and trigger types fix(api): switch flow and trigger types to dynamic objects * fix(translations): add action translations * use `domain.FlowType` * localizers * localization * trigger types * options on `query.Action` * add functions for actions * feat: management api: add list flow and trigger (#4352) * console changes * cleanup * fix: wrong localization Co-authored-by: Max Peintner <max@caos.ch> * id token works * check if claims not nil * feat(actions): metadata api * refactor(actions): modules * fix: allow prerelease * fix: test * feat(actions): deny list for http hosts * feat(actions): deny list for http hosts * refactor: actions * fix: different error ids * fix: rename statusCode to status * Actions objects as options (#4418) * fix: rename statusCode to status * fix(actions): objects as options * fix(actions): objects as options * fix(actions): set fields * add http client to old actions * fix(actions): add log module * fix(actions): add user to context where possible * fix(actions): add user to ctx in external authorization/pre creation * fix(actions): query correct flow in claims * test: actions * fix(id-generator): panic if no machine id * tests * maybe this? * fix linting * refactor: improve code * fix: metadata and usergrant usage in actions * fix: appendUserGrant * fix: allowedToFail and timeout in action execution * fix: allowed to fail in token complement flow * docs: add action log claim * Update defaults.yaml * fix log claim * remove prerelease build Co-authored-by: Max Peintner <max@caos.ch> Co-authored-by: Livio Spring <livio.a@gmail.com>
This commit is contained in:
@@ -1,5 +1,7 @@
|
||||
package domain
|
||||
|
||||
import "strconv"
|
||||
|
||||
type FlowState int32
|
||||
|
||||
const (
|
||||
@@ -17,6 +19,7 @@ type FlowType int32
|
||||
const (
|
||||
FlowTypeUnspecified FlowType = iota
|
||||
FlowTypeExternalAuthentication
|
||||
FlowTypeCustomiseToken
|
||||
flowTypeCount
|
||||
)
|
||||
|
||||
@@ -25,15 +28,51 @@ func (s FlowType) Valid() bool {
|
||||
}
|
||||
|
||||
func (s FlowType) HasTrigger(triggerType TriggerType) bool {
|
||||
switch triggerType {
|
||||
case TriggerTypePostAuthentication:
|
||||
return s == FlowTypeExternalAuthentication
|
||||
case TriggerTypePreCreation:
|
||||
return s == FlowTypeExternalAuthentication
|
||||
case TriggerTypePostCreation:
|
||||
return s == FlowTypeExternalAuthentication
|
||||
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,
|
||||
}
|
||||
default:
|
||||
return false
|
||||
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"
|
||||
default:
|
||||
return "Action.Flow.Type.Unspecified"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -44,9 +83,39 @@ const (
|
||||
TriggerTypePostAuthentication
|
||||
TriggerTypePreCreation
|
||||
TriggerTypePostCreation
|
||||
TriggerTypePreUserinfoCreation
|
||||
TriggerTypePreAccessTokenCreation
|
||||
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"
|
||||
default:
|
||||
return "Action.TriggerType.Unspecified"
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user