mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-10 18:54:36 +00:00
94 lines
2.4 KiB
Go
94 lines
2.4 KiB
Go
package handler
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/caos/logging"
|
|
"github.com/caos/zitadel/internal/eventstore"
|
|
"github.com/caos/zitadel/internal/eventstore/models"
|
|
"github.com/caos/zitadel/internal/eventstore/query"
|
|
"github.com/caos/zitadel/internal/eventstore/spooler"
|
|
"github.com/caos/zitadel/internal/key/repository/eventsourcing"
|
|
es_model "github.com/caos/zitadel/internal/key/repository/eventsourcing/model"
|
|
view_model "github.com/caos/zitadel/internal/key/repository/view/model"
|
|
)
|
|
|
|
const (
|
|
keyTable = "auth.keys"
|
|
)
|
|
|
|
type Key struct {
|
|
handler
|
|
subscription *eventstore.Subscription
|
|
}
|
|
|
|
func newKey(handler handler) *Key {
|
|
h := &Key{
|
|
handler: handler,
|
|
}
|
|
|
|
h.subscribe()
|
|
|
|
return h
|
|
}
|
|
|
|
func (k *Key) subscribe() {
|
|
k.subscription = k.es.Subscribe(k.AggregateTypes()...)
|
|
go func() {
|
|
for event := range k.subscription.Events {
|
|
query.ReduceEvent(k, event)
|
|
}
|
|
}()
|
|
}
|
|
|
|
func (k *Key) ViewModel() string {
|
|
return keyTable
|
|
}
|
|
|
|
func (_ *Key) AggregateTypes() []models.AggregateType {
|
|
return []models.AggregateType{es_model.KeyPairAggregate}
|
|
}
|
|
|
|
func (k *Key) CurrentSequence() (uint64, error) {
|
|
sequence, err := k.view.GetLatestKeySequence()
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
return sequence.CurrentSequence, nil
|
|
}
|
|
|
|
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)
|
|
}
|
|
return k.view.PutKeys(privateKey, publicKey, event)
|
|
default:
|
|
return k.view.ProcessedKeySequence(event)
|
|
}
|
|
}
|
|
|
|
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)
|
|
}
|
|
|
|
func (k *Key) OnSuccess() error {
|
|
err := spooler.HandleSuccess(k.view.UpdateKeySpoolerRunTimestamp)
|
|
logging.LogWithFields("SPOOL-vM9sd", "table", keyTable).OnError(err).Warn("could not process on success func")
|
|
return err
|
|
}
|