mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-07 14:17:44 +00:00
667cc30291
* feat: remove assets * feat: minio implementation * fix: remove assets from tests * feat: minio implementation * feat: Env vars * fix: sprintf * fix: sprintf * Update internal/eventstore/repository/repository.go Co-authored-by: Livio Amstutz <livio.a@gmail.com> * fix: error handling Co-authored-by: Livio Amstutz <livio.a@gmail.com>
104 lines
2.4 KiB
Go
104 lines
2.4 KiB
Go
package iam
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"strconv"
|
|
|
|
"github.com/caos/zitadel/internal/eventstore"
|
|
|
|
"github.com/caos/zitadel/internal/domain"
|
|
"github.com/caos/zitadel/internal/errors"
|
|
"github.com/caos/zitadel/internal/eventstore/repository"
|
|
)
|
|
|
|
const (
|
|
UniqueStepStarted = "stepstarted"
|
|
UniqueStepDone = "stepdone"
|
|
SetupDoneEventType eventstore.EventType = "iam.setup.done"
|
|
SetupStartedEventType eventstore.EventType = "iam.setup.started"
|
|
)
|
|
|
|
type SetupStepEvent struct {
|
|
eventstore.BaseEvent `json:"-"`
|
|
|
|
Step domain.Step `json:"Step"`
|
|
Done bool `json:"-"`
|
|
}
|
|
|
|
func NewAddSetupStepStartedUniqueConstraint(step domain.Step) *eventstore.EventUniqueConstraint {
|
|
return eventstore.NewAddEventUniqueConstraint(
|
|
UniqueStepStarted,
|
|
strconv.Itoa(int(step)),
|
|
"Errors.Step.Started.AlreadyExists")
|
|
}
|
|
|
|
func NewAddSetupStepDoneUniqueConstraint(step domain.Step) *eventstore.EventUniqueConstraint {
|
|
return eventstore.NewAddEventUniqueConstraint(
|
|
UniqueStepDone,
|
|
strconv.Itoa(int(step)),
|
|
"Errors.Step.Done.AlreadyExists")
|
|
}
|
|
|
|
func (e *SetupStepEvent) Data() interface{} {
|
|
return e
|
|
}
|
|
|
|
func (e *SetupStepEvent) UniqueConstraints() []*eventstore.EventUniqueConstraint {
|
|
if e.Done {
|
|
return []*eventstore.EventUniqueConstraint{NewAddSetupStepDoneUniqueConstraint(e.Step)}
|
|
} else {
|
|
return []*eventstore.EventUniqueConstraint{NewAddSetupStepStartedUniqueConstraint(e.Step)}
|
|
}
|
|
}
|
|
|
|
func SetupStepMapper(event *repository.Event) (eventstore.EventReader, error) {
|
|
step := &SetupStepEvent{
|
|
BaseEvent: *eventstore.BaseEventFromRepo(event),
|
|
Done: eventstore.EventType(event.Type) == SetupDoneEventType,
|
|
Step: domain.Step1,
|
|
}
|
|
if len(event.Data) == 0 {
|
|
return step, nil
|
|
}
|
|
err := json.Unmarshal(event.Data, step)
|
|
if err != nil {
|
|
return nil, errors.ThrowInternal(err, "IAM-O6rVg", "unable to unmarshal step")
|
|
}
|
|
|
|
return step, nil
|
|
}
|
|
|
|
func NewSetupStepDoneEvent(
|
|
ctx context.Context,
|
|
aggregate *eventstore.Aggregate,
|
|
step domain.Step,
|
|
) *SetupStepEvent {
|
|
|
|
return &SetupStepEvent{
|
|
BaseEvent: *eventstore.NewBaseEventForPush(
|
|
ctx,
|
|
aggregate,
|
|
SetupDoneEventType,
|
|
),
|
|
Step: step,
|
|
Done: true,
|
|
}
|
|
}
|
|
|
|
func NewSetupStepStartedEvent(
|
|
ctx context.Context,
|
|
aggregate *eventstore.Aggregate,
|
|
step domain.Step,
|
|
) *SetupStepEvent {
|
|
|
|
return &SetupStepEvent{
|
|
BaseEvent: *eventstore.NewBaseEventForPush(
|
|
ctx,
|
|
aggregate,
|
|
SetupStartedEventType,
|
|
),
|
|
Step: step,
|
|
}
|
|
}
|