mirror of
https://github.com/zitadel/zitadel.git
synced 2025-08-11 20:57:31 +00:00
feat: actions (#2377)
* feat(actions): begin api * feat(actions): begin api * api and projections * fix: handle multiple statements for a single event in projections * export func type * fix test * update to new reduce interface * flows in login * feat: jwt idp * feat: command side * feat: add tests * actions and flows * fill idp views with jwt idps and return apis * add jwtEndpoint to jwt idp * begin jwt request handling * add feature * merge * merge * handle jwt idp * cleanup * bug fixes * autoregister * get token from specific header name * fix: proto * fixes * i18n * begin tests * fix and log http proxy * remove docker cache * fixes * usergrants in actions api * tests adn cleanup * cleanup * fix add user grant * set login context * i18n Co-authored-by: fabi <fabienne.gerschwiler@gmail.com>
This commit is contained in:
194
internal/command/org_action_model.go
Normal file
194
internal/command/org_action_model.go
Normal file
@@ -0,0 +1,194 @@
|
||||
package command
|
||||
|
||||
import (
|
||||
"context"
|
||||
"time"
|
||||
|
||||
"github.com/caos/zitadel/internal/domain"
|
||||
"github.com/caos/zitadel/internal/eventstore"
|
||||
"github.com/caos/zitadel/internal/repository/action"
|
||||
)
|
||||
|
||||
type ActionWriteModel struct {
|
||||
eventstore.WriteModel
|
||||
|
||||
Name string
|
||||
Script string
|
||||
Timeout time.Duration
|
||||
AllowedToFail bool
|
||||
State domain.ActionState
|
||||
}
|
||||
|
||||
func NewActionWriteModel(actionID string, resourceOwner string) *ActionWriteModel {
|
||||
return &ActionWriteModel{
|
||||
WriteModel: eventstore.WriteModel{
|
||||
AggregateID: actionID,
|
||||
ResourceOwner: resourceOwner,
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
func (wm *ActionWriteModel) Reduce() error {
|
||||
for _, event := range wm.Events {
|
||||
switch e := event.(type) {
|
||||
case *action.AddedEvent:
|
||||
wm.Name = e.Name
|
||||
wm.Script = e.Script
|
||||
wm.Timeout = e.Timeout
|
||||
wm.AllowedToFail = e.AllowedToFail
|
||||
wm.State = domain.ActionStateActive
|
||||
case *action.ChangedEvent:
|
||||
if e.Name != nil {
|
||||
wm.Name = *e.Name
|
||||
}
|
||||
if e.Script != nil {
|
||||
wm.Script = *e.Script
|
||||
}
|
||||
if e.Timeout != nil {
|
||||
wm.Timeout = *e.Timeout
|
||||
}
|
||||
if e.AllowedToFail != nil {
|
||||
wm.AllowedToFail = *e.AllowedToFail
|
||||
}
|
||||
case *action.DeactivatedEvent:
|
||||
wm.State = domain.ActionStateInactive
|
||||
case *action.ReactivatedEvent:
|
||||
wm.State = domain.ActionStateActive
|
||||
case *action.RemovedEvent:
|
||||
wm.State = domain.ActionStateRemoved
|
||||
}
|
||||
}
|
||||
return wm.WriteModel.Reduce()
|
||||
}
|
||||
|
||||
func (wm *ActionWriteModel) Query() *eventstore.SearchQueryBuilder {
|
||||
return eventstore.NewSearchQueryBuilder(eventstore.ColumnsEvent).
|
||||
ResourceOwner(wm.ResourceOwner).
|
||||
AddQuery().
|
||||
AggregateTypes(action.AggregateType).
|
||||
AggregateIDs(wm.AggregateID).
|
||||
EventTypes(action.AddedEventType,
|
||||
action.ChangedEventType,
|
||||
action.DeactivatedEventType,
|
||||
action.ReactivatedEventType,
|
||||
action.RemovedEventType).
|
||||
Builder()
|
||||
}
|
||||
|
||||
func (wm *ActionWriteModel) NewChangedEvent(
|
||||
ctx context.Context,
|
||||
agg *eventstore.Aggregate,
|
||||
name string,
|
||||
script string,
|
||||
timeout time.Duration,
|
||||
allowedToFail bool,
|
||||
) (*action.ChangedEvent, error) {
|
||||
changes := make([]action.ActionChanges, 0)
|
||||
if wm.Name != name {
|
||||
changes = append(changes, action.ChangeName(name, wm.Name))
|
||||
}
|
||||
if wm.Script != script {
|
||||
changes = append(changes, action.ChangeScript(script))
|
||||
}
|
||||
if wm.Timeout != timeout {
|
||||
changes = append(changes, action.ChangeTimeout(timeout))
|
||||
}
|
||||
if wm.AllowedToFail != allowedToFail {
|
||||
changes = append(changes, action.ChangeAllowedToFail(allowedToFail))
|
||||
}
|
||||
return action.NewChangedEvent(ctx, agg, changes)
|
||||
}
|
||||
|
||||
func ActionAggregateFromWriteModel(wm *eventstore.WriteModel) *eventstore.Aggregate {
|
||||
return eventstore.AggregateFromWriteModel(wm, action.AggregateType, action.AggregateVersion)
|
||||
}
|
||||
|
||||
func NewActionAggregate(id, resourceOwner string) *eventstore.Aggregate {
|
||||
return ActionAggregateFromWriteModel(&eventstore.WriteModel{
|
||||
AggregateID: id,
|
||||
ResourceOwner: resourceOwner,
|
||||
})
|
||||
}
|
||||
|
||||
type ActionExistsModel struct {
|
||||
eventstore.WriteModel
|
||||
|
||||
actionIDs []string
|
||||
checkedIDs []string
|
||||
}
|
||||
|
||||
func NewActionsExistModel(actionIDs []string, resourceOwner string) *ActionExistsModel {
|
||||
return &ActionExistsModel{
|
||||
WriteModel: eventstore.WriteModel{
|
||||
ResourceOwner: resourceOwner,
|
||||
},
|
||||
actionIDs: actionIDs,
|
||||
}
|
||||
}
|
||||
|
||||
func (wm *ActionExistsModel) Reduce() error {
|
||||
for _, event := range wm.Events {
|
||||
switch e := event.(type) {
|
||||
case *action.AddedEvent:
|
||||
wm.checkedIDs = append(wm.checkedIDs, e.Aggregate().ID)
|
||||
case *action.RemovedEvent:
|
||||
for i := len(wm.checkedIDs) - 1; i >= 0; i-- {
|
||||
if wm.checkedIDs[i] == e.Aggregate().ID {
|
||||
wm.checkedIDs[i] = wm.checkedIDs[len(wm.checkedIDs)-1]
|
||||
wm.checkedIDs[len(wm.checkedIDs)-1] = ""
|
||||
wm.checkedIDs = wm.checkedIDs[:len(wm.checkedIDs)-1]
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return wm.WriteModel.Reduce()
|
||||
}
|
||||
|
||||
func (wm *ActionExistsModel) Query() *eventstore.SearchQueryBuilder {
|
||||
return eventstore.NewSearchQueryBuilder(eventstore.ColumnsEvent).
|
||||
ResourceOwner(wm.ResourceOwner).
|
||||
AddQuery().
|
||||
AggregateTypes(action.AggregateType).
|
||||
AggregateIDs(wm.actionIDs...).
|
||||
EventTypes(action.AddedEventType,
|
||||
action.RemovedEventType).
|
||||
Builder()
|
||||
}
|
||||
|
||||
type ActionsListByOrgModel struct {
|
||||
eventstore.WriteModel
|
||||
|
||||
Actions map[string]string
|
||||
}
|
||||
|
||||
func NewActionsListByOrgModel(resourceOwner string) *ActionsListByOrgModel {
|
||||
return &ActionsListByOrgModel{
|
||||
WriteModel: eventstore.WriteModel{
|
||||
ResourceOwner: resourceOwner,
|
||||
},
|
||||
Actions: make(map[string]string),
|
||||
}
|
||||
}
|
||||
|
||||
func (wm *ActionsListByOrgModel) Reduce() error {
|
||||
for _, event := range wm.Events {
|
||||
switch e := event.(type) {
|
||||
case *action.AddedEvent:
|
||||
wm.Actions[e.Aggregate().ID] = e.Name
|
||||
case *action.RemovedEvent:
|
||||
delete(wm.Actions, e.Aggregate().ID)
|
||||
}
|
||||
}
|
||||
return wm.WriteModel.Reduce()
|
||||
}
|
||||
|
||||
func (wm *ActionsListByOrgModel) Query() *eventstore.SearchQueryBuilder {
|
||||
return eventstore.NewSearchQueryBuilder(eventstore.ColumnsEvent).
|
||||
ResourceOwner(wm.ResourceOwner).
|
||||
AddQuery().
|
||||
AggregateTypes(action.AggregateType).
|
||||
EventTypes(action.AddedEventType,
|
||||
action.RemovedEventType).
|
||||
Builder()
|
||||
}
|
Reference in New Issue
Block a user