mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-08 14:07:40 +00:00
41e1a7cc7b
* one concurrent task * disable spooler * fix: improve concurrency in spooler * fix: dont block lock * fix: break if lock failed * fix: check if handler is working * fix: worker id * fix: test * fix: use limit for spoolers configured in startup.yaml * fix test * fix: factory * fix(key): only reduce if not expired * fix(searchQueryFactory): check for string-slice in aggregateID * fix(migrations): combine migrations * fix: allow saving multiple objects in one request * fix(eventstore): logging * fix(eventstore): rethink insert i locks table * fix: ignore failed tests for the moment * fix: tuubel * fix: for tests in io * fix: ignore tests for io * fix: rename concurrent tasks to workers * fix: incomment tests and remove some tests * fix: refert changes for io * refactor(eventstore): combine types of sql in one file * refactor(eventstore): logs, TODO's, tests * fix(eventstore): sql package * test(eventstore): add tests for search query factory * chore: logs * fix(spooler): optimize lock query chore(migrations): rename locks.object_type to view_name chore(migrations): refactor migrations * test: incomment tests * fix: rename PrepareSaves to PrepareBulkSave * chore: go dependencies * fix(migrations): add id in events table * refactor(lock): less magic numbers Co-authored-by: Livio Amstutz <livio.a@gmail.com>
65 lines
2.0 KiB
Go
65 lines
2.0 KiB
Go
package eventstore
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/caos/zitadel/internal/errors"
|
|
"github.com/caos/zitadel/internal/eventstore/internal/repository"
|
|
"github.com/caos/zitadel/internal/eventstore/models"
|
|
)
|
|
|
|
type Eventstore interface {
|
|
AggregateCreator() *models.AggregateCreator
|
|
Health(ctx context.Context) error
|
|
PushAggregates(ctx context.Context, aggregates ...*models.Aggregate) error
|
|
FilterEvents(ctx context.Context, searchQuery *models.SearchQuery) (events []*models.Event, err error)
|
|
LatestSequence(ctx context.Context, searchQuery *models.SearchQueryFactory) (uint64, error)
|
|
}
|
|
|
|
var _ Eventstore = (*eventstore)(nil)
|
|
|
|
type eventstore struct {
|
|
repo repository.Repository
|
|
aggregateCreator *models.AggregateCreator
|
|
}
|
|
|
|
func (es *eventstore) AggregateCreator() *models.AggregateCreator {
|
|
return es.aggregateCreator
|
|
}
|
|
|
|
func (es *eventstore) PushAggregates(ctx context.Context, aggregates ...*models.Aggregate) (err error) {
|
|
for _, aggregate := range aggregates {
|
|
if len(aggregate.Events) == 0 {
|
|
return errors.ThrowInvalidArgument(nil, "EVENT-cNhIj", "no events in aggregate")
|
|
}
|
|
for _, event := range aggregate.Events {
|
|
if err = event.Validate(); err != nil {
|
|
return errors.ThrowInvalidArgument(err, "EVENT-tzIhl", "validate event failed")
|
|
}
|
|
}
|
|
}
|
|
err = es.repo.PushAggregates(ctx, aggregates...)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (es *eventstore) FilterEvents(ctx context.Context, searchQuery *models.SearchQuery) ([]*models.Event, error) {
|
|
if err := searchQuery.Validate(); err != nil {
|
|
return nil, err
|
|
}
|
|
return es.repo.Filter(ctx, models.FactoryFromSearchQuery(searchQuery))
|
|
}
|
|
|
|
func (es *eventstore) LatestSequence(ctx context.Context, queryFactory *models.SearchQueryFactory) (uint64, error) {
|
|
sequenceFactory := *queryFactory
|
|
sequenceFactory = *(&sequenceFactory).Columns(models.Columns_Max_Sequence)
|
|
sequenceFactory = *(&sequenceFactory).SequenceGreater(0)
|
|
return es.repo.LatestSequence(ctx, &sequenceFactory)
|
|
}
|
|
|
|
func (es *eventstore) Health(ctx context.Context) error {
|
|
return es.repo.Health(ctx)
|
|
}
|