mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-07 12:48:05 +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>
56 lines
1.5 KiB
Go
56 lines
1.5 KiB
Go
package handler
|
|
|
|
import (
|
|
"time"
|
|
|
|
es_model "github.com/caos/zitadel/internal/key/repository/eventsourcing/model"
|
|
|
|
"github.com/caos/logging"
|
|
|
|
"github.com/caos/zitadel/internal/eventstore/models"
|
|
"github.com/caos/zitadel/internal/eventstore/spooler"
|
|
"github.com/caos/zitadel/internal/key/repository/eventsourcing"
|
|
view_model "github.com/caos/zitadel/internal/key/repository/view/model"
|
|
)
|
|
|
|
type Key struct {
|
|
handler
|
|
}
|
|
|
|
const (
|
|
keyTable = "auth.keys"
|
|
)
|
|
|
|
func (k *Key) ViewModel() string {
|
|
return keyTable
|
|
}
|
|
|
|
func (k *Key) EventQuery() (*models.SearchQuery, error) {
|
|
sequence, err := k.view.GetLatestKeySequence()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return eventsourcing.KeyPairQuery(sequence.CurrentSequence), nil
|
|
}
|
|
|
|
func (k *Key) Reduce(event *models.Event) error {
|
|
switch event.Type {
|
|
case es_model.KeyPairAdded:
|
|
privateKey, publicKey, err := view_model.KeysFromPairEvent(event)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if privateKey.Expiry.Before(time.Now()) && publicKey.Expiry.Before(time.Now()) {
|
|
return k.view.ProcessedKeySequence(event.Sequence)
|
|
}
|
|
return k.view.PutKeys(privateKey, publicKey, event.Sequence)
|
|
default:
|
|
return k.view.ProcessedKeySequence(event.Sequence)
|
|
}
|
|
}
|
|
|
|
func (k *Key) OnError(event *models.Event, err error) error {
|
|
logging.LogWithFields("SPOOL-GHa3a", "id", event.AggregateID).WithError(err).Warn("something went wrong in key handler")
|
|
return spooler.HandleError(event, err, k.view.GetLatestKeyFailedEvent, k.view.ProcessedKeyFailedEvent, k.view.ProcessedKeySequence, k.errorCountUntilSkip)
|
|
}
|