mirror of
https://github.com/zitadel/zitadel.git
synced 2025-08-11 19:17:32 +00:00
feat: actions v2 execution targets command side (#7384)
Adds the API to create, update, delete targets for execution in a new ExecutionService (v3alpha)
This commit is contained in:
18
internal/repository/target/aggregate.go
Normal file
18
internal/repository/target/aggregate.go
Normal file
@@ -0,0 +1,18 @@
|
||||
package target
|
||||
|
||||
import "github.com/zitadel/zitadel/internal/eventstore"
|
||||
|
||||
const (
|
||||
AggregateType = "target"
|
||||
AggregateVersion = "v1"
|
||||
)
|
||||
|
||||
func NewAggregate(aggrID, instanceID string) *eventstore.Aggregate {
|
||||
return &eventstore.Aggregate{
|
||||
ID: aggrID,
|
||||
Type: AggregateType,
|
||||
ResourceOwner: instanceID,
|
||||
InstanceID: instanceID,
|
||||
Version: AggregateVersion,
|
||||
}
|
||||
}
|
25
internal/repository/target/constraints.go
Normal file
25
internal/repository/target/constraints.go
Normal file
@@ -0,0 +1,25 @@
|
||||
package target
|
||||
|
||||
import (
|
||||
"github.com/zitadel/zitadel/internal/eventstore"
|
||||
)
|
||||
|
||||
const (
|
||||
UniqueTarget = "target"
|
||||
DuplicateTarget = "Errors.Target.AlreadyExists"
|
||||
)
|
||||
|
||||
func NewAddUniqueConstraint(name string) *eventstore.UniqueConstraint {
|
||||
return eventstore.NewAddEventUniqueConstraint(
|
||||
UniqueTarget,
|
||||
name,
|
||||
DuplicateTarget,
|
||||
)
|
||||
}
|
||||
|
||||
func NewRemoveUniqueConstraint(name string) *eventstore.UniqueConstraint {
|
||||
return eventstore.NewRemoveUniqueConstraint(
|
||||
UniqueTarget,
|
||||
name,
|
||||
)
|
||||
}
|
9
internal/repository/target/eventstore.go
Normal file
9
internal/repository/target/eventstore.go
Normal file
@@ -0,0 +1,9 @@
|
||||
package target
|
||||
|
||||
import "github.com/zitadel/zitadel/internal/eventstore"
|
||||
|
||||
func init() {
|
||||
eventstore.RegisterFilterEventMapper(AggregateType, AddedEventType, AddedEventMapper)
|
||||
eventstore.RegisterFilterEventMapper(AggregateType, ChangedEventType, ChangedEventMapper)
|
||||
eventstore.RegisterFilterEventMapper(AggregateType, RemovedEventType, RemovedEventMapper)
|
||||
}
|
199
internal/repository/target/target.go
Normal file
199
internal/repository/target/target.go
Normal file
@@ -0,0 +1,199 @@
|
||||
package target
|
||||
|
||||
import (
|
||||
"context"
|
||||
"time"
|
||||
|
||||
"github.com/zitadel/zitadel/internal/domain"
|
||||
"github.com/zitadel/zitadel/internal/eventstore"
|
||||
"github.com/zitadel/zitadel/internal/zerrors"
|
||||
)
|
||||
|
||||
const (
|
||||
eventTypePrefix eventstore.EventType = "target."
|
||||
AddedEventType = eventTypePrefix + "added"
|
||||
ChangedEventType = eventTypePrefix + "changed"
|
||||
RemovedEventType = eventTypePrefix + "removed"
|
||||
)
|
||||
|
||||
type AddedEvent struct {
|
||||
*eventstore.BaseEvent `json:"-"`
|
||||
|
||||
Name string `json:"name"`
|
||||
TargetType domain.TargetType `json:"targetType"`
|
||||
URL string `json:"url"`
|
||||
Timeout time.Duration `json:"timeout"`
|
||||
Async bool `json:"async"`
|
||||
InterruptOnError bool `json:"interruptOnError"`
|
||||
}
|
||||
|
||||
func (e *AddedEvent) SetBaseEvent(b *eventstore.BaseEvent) {
|
||||
e.BaseEvent = b
|
||||
}
|
||||
|
||||
func (e *AddedEvent) Payload() any {
|
||||
return e
|
||||
}
|
||||
|
||||
func (e *AddedEvent) UniqueConstraints() []*eventstore.UniqueConstraint {
|
||||
return []*eventstore.UniqueConstraint{NewAddUniqueConstraint(e.Name)}
|
||||
}
|
||||
|
||||
func NewAddedEvent(
|
||||
ctx context.Context,
|
||||
aggregate *eventstore.Aggregate,
|
||||
name string,
|
||||
targetType domain.TargetType,
|
||||
url string,
|
||||
timeout time.Duration,
|
||||
async bool,
|
||||
interruptOnError bool,
|
||||
) *AddedEvent {
|
||||
return &AddedEvent{
|
||||
eventstore.NewBaseEventForPush(
|
||||
ctx, aggregate, AddedEventType,
|
||||
),
|
||||
name, targetType, url, timeout, async, interruptOnError}
|
||||
}
|
||||
|
||||
func AddedEventMapper(event eventstore.Event) (eventstore.Event, error) {
|
||||
added := &AddedEvent{
|
||||
BaseEvent: eventstore.BaseEventFromRepo(event),
|
||||
}
|
||||
err := event.Unmarshal(added)
|
||||
if err != nil {
|
||||
return nil, zerrors.ThrowInternal(err, "TARGET-fx8f8yfbn1", "unable to unmarshal target added")
|
||||
}
|
||||
|
||||
return added, nil
|
||||
}
|
||||
|
||||
type ChangedEvent struct {
|
||||
*eventstore.BaseEvent `json:"-"`
|
||||
|
||||
Name *string `json:"name,omitempty"`
|
||||
TargetType *domain.TargetType `json:"targetType,omitempty"`
|
||||
URL *string `json:"url,omitempty"`
|
||||
Timeout *time.Duration `json:"timeout,omitempty"`
|
||||
Async *bool `json:"async,omitempty"`
|
||||
InterruptOnError *bool `json:"interruptOnError,omitempty"`
|
||||
|
||||
oldName string
|
||||
}
|
||||
|
||||
func (e *ChangedEvent) Payload() interface{} {
|
||||
return e
|
||||
}
|
||||
|
||||
func (e *ChangedEvent) UniqueConstraints() []*eventstore.UniqueConstraint {
|
||||
if e.oldName == "" {
|
||||
return nil
|
||||
}
|
||||
return []*eventstore.UniqueConstraint{
|
||||
NewRemoveUniqueConstraint(e.oldName),
|
||||
NewAddUniqueConstraint(*e.Name),
|
||||
}
|
||||
}
|
||||
|
||||
func NewChangedEvent(
|
||||
ctx context.Context,
|
||||
aggregate *eventstore.Aggregate,
|
||||
changes []Changes,
|
||||
) *ChangedEvent {
|
||||
changeEvent := &ChangedEvent{
|
||||
BaseEvent: eventstore.NewBaseEventForPush(
|
||||
ctx,
|
||||
aggregate,
|
||||
ChangedEventType,
|
||||
),
|
||||
}
|
||||
for _, change := range changes {
|
||||
change(changeEvent)
|
||||
}
|
||||
return changeEvent
|
||||
}
|
||||
|
||||
type Changes func(event *ChangedEvent)
|
||||
|
||||
func ChangeName(oldName, name string) func(event *ChangedEvent) {
|
||||
return func(e *ChangedEvent) {
|
||||
e.Name = &name
|
||||
e.oldName = oldName
|
||||
}
|
||||
}
|
||||
|
||||
func ChangeTargetType(targetType domain.TargetType) func(event *ChangedEvent) {
|
||||
return func(e *ChangedEvent) {
|
||||
e.TargetType = &targetType
|
||||
}
|
||||
}
|
||||
|
||||
func ChangeURL(url string) func(event *ChangedEvent) {
|
||||
return func(e *ChangedEvent) {
|
||||
e.URL = &url
|
||||
}
|
||||
}
|
||||
|
||||
func ChangeTimeout(timeout time.Duration) func(event *ChangedEvent) {
|
||||
return func(e *ChangedEvent) {
|
||||
e.Timeout = &timeout
|
||||
}
|
||||
}
|
||||
|
||||
func ChangeAsync(async bool) func(event *ChangedEvent) {
|
||||
return func(e *ChangedEvent) {
|
||||
e.Async = &async
|
||||
}
|
||||
}
|
||||
|
||||
func ChangeInterruptOnError(interruptOnError bool) func(event *ChangedEvent) {
|
||||
return func(e *ChangedEvent) {
|
||||
e.InterruptOnError = &interruptOnError
|
||||
}
|
||||
}
|
||||
|
||||
func ChangedEventMapper(event eventstore.Event) (eventstore.Event, error) {
|
||||
changed := &ChangedEvent{
|
||||
BaseEvent: eventstore.BaseEventFromRepo(event),
|
||||
}
|
||||
err := event.Unmarshal(changed)
|
||||
if err != nil {
|
||||
return nil, zerrors.ThrowInternal(err, "TARGET-w6402p4ek7", "unable to unmarshal target changed")
|
||||
}
|
||||
|
||||
return changed, nil
|
||||
}
|
||||
|
||||
type RemovedEvent struct {
|
||||
*eventstore.BaseEvent `json:"-"`
|
||||
|
||||
name string
|
||||
}
|
||||
|
||||
func (e *RemovedEvent) SetBaseEvent(b *eventstore.BaseEvent) {
|
||||
e.BaseEvent = b
|
||||
}
|
||||
|
||||
func (e *RemovedEvent) Payload() any {
|
||||
return e
|
||||
}
|
||||
|
||||
func (e *RemovedEvent) UniqueConstraints() []*eventstore.UniqueConstraint {
|
||||
return []*eventstore.UniqueConstraint{NewRemoveUniqueConstraint(e.name)}
|
||||
}
|
||||
|
||||
func NewRemovedEvent(ctx context.Context, aggregate *eventstore.Aggregate, name string) *RemovedEvent {
|
||||
return &RemovedEvent{eventstore.NewBaseEventForPush(ctx, aggregate, RemovedEventType), name}
|
||||
}
|
||||
|
||||
func RemovedEventMapper(event eventstore.Event) (eventstore.Event, error) {
|
||||
removed := &RemovedEvent{
|
||||
BaseEvent: eventstore.BaseEventFromRepo(event),
|
||||
}
|
||||
err := event.Unmarshal(removed)
|
||||
if err != nil {
|
||||
return nil, zerrors.ThrowInternal(err, "TARGET-0kuc12c7bc", "unable to unmarshal target removed")
|
||||
}
|
||||
|
||||
return removed, nil
|
||||
}
|
Reference in New Issue
Block a user