mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-20 23:07:33 +00:00
2e684684de
* message texts wrapper components * message-text sub, i18n, grid * fix routing * pack * pack * update material * audit * fix mgmt service for labelplcy * map conv * edit text from map * request map * fetch data, mgmt admin service * warn box, i18n * resetbtn * login texts * login text requests * reset, default, i18n * disabled, features, message text setter, service * locale switcher * policy grid * password reset, domain claimed i18n * lint files * fix admin service, i18n, lang setter * fix scss duplicate * privacy policy, cleanup grid, fix message, login texts (#2031) * policy grid everywhere 🦒 * cleanup home * log login text request * patch all data * refresh toggle * fix: add dialog for unsaved changes (#2057) * logintexts dialog * check for dialog on pairwise operation * fix: patch value to local state after save * fix: i18n and custom login texts (#2060) * fix: i18n and custom login texts * fix: tos and privacy texts * fix frontend * fix: tos and privacy texts and tests * fix: i18n, tos and privacy texts and tests * fix frontend maps * i18n * add ResetCustomLoginTextToDefault in admin api and fix template remove in handlers * resetlogintexttodefault Co-authored-by: Livio Amstutz <livio.a@gmail.com>
133 lines
3.8 KiB
Go
133 lines
3.8 KiB
Go
package handler
|
|
|
|
import (
|
|
"github.com/caos/logging"
|
|
caos_errs "github.com/caos/zitadel/internal/errors"
|
|
"github.com/caos/zitadel/internal/eventstore/v1"
|
|
es_models "github.com/caos/zitadel/internal/eventstore/v1/models"
|
|
"github.com/caos/zitadel/internal/eventstore/v1/query"
|
|
"github.com/caos/zitadel/internal/eventstore/v1/spooler"
|
|
iam_es_model "github.com/caos/zitadel/internal/iam/repository/eventsourcing/model"
|
|
iam_model "github.com/caos/zitadel/internal/iam/repository/view/model"
|
|
"github.com/caos/zitadel/internal/org/repository/eventsourcing/model"
|
|
)
|
|
|
|
type CustomText struct {
|
|
handler
|
|
subscription *v1.Subscription
|
|
}
|
|
|
|
func newCustomText(handler handler) *CustomText {
|
|
h := &CustomText{
|
|
handler: handler,
|
|
}
|
|
|
|
h.subscribe()
|
|
|
|
return h
|
|
}
|
|
|
|
func (m *CustomText) subscribe() {
|
|
m.subscription = m.es.Subscribe(m.AggregateTypes()...)
|
|
go func() {
|
|
for event := range m.subscription.Events {
|
|
query.ReduceEvent(m, event)
|
|
}
|
|
}()
|
|
}
|
|
|
|
const (
|
|
customTextTable = "auth.custom_texts"
|
|
)
|
|
|
|
func (m *CustomText) ViewModel() string {
|
|
return customTextTable
|
|
}
|
|
|
|
func (m *CustomText) Subscription() *v1.Subscription {
|
|
return m.subscription
|
|
}
|
|
|
|
func (_ *CustomText) AggregateTypes() []es_models.AggregateType {
|
|
return []es_models.AggregateType{model.OrgAggregate, iam_es_model.IAMAggregate}
|
|
}
|
|
|
|
func (p *CustomText) CurrentSequence() (uint64, error) {
|
|
sequence, err := p.view.GetLatestCustomTextSequence()
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
return sequence.CurrentSequence, nil
|
|
}
|
|
|
|
func (m *CustomText) EventQuery() (*es_models.SearchQuery, error) {
|
|
sequence, err := m.view.GetLatestCustomTextSequence()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return es_models.NewSearchQuery().
|
|
AggregateTypeFilter(m.AggregateTypes()...).
|
|
LatestSequenceFilter(sequence.CurrentSequence), nil
|
|
}
|
|
|
|
func (m *CustomText) Reduce(event *es_models.Event) (err error) {
|
|
switch event.AggregateType {
|
|
case model.OrgAggregate, iam_es_model.IAMAggregate:
|
|
err = m.processCustomText(event)
|
|
}
|
|
return err
|
|
}
|
|
|
|
func (m *CustomText) processCustomText(event *es_models.Event) (err error) {
|
|
customText := new(iam_model.CustomTextView)
|
|
switch event.Type {
|
|
case iam_es_model.CustomTextSet, model.CustomTextSet:
|
|
text := new(iam_model.CustomTextView)
|
|
err = text.SetData(event)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
customText, err = m.view.CustomTextByIDs(event.AggregateID, text.Template, text.Key, text.Language)
|
|
if err != nil && !caos_errs.IsNotFound(err) {
|
|
return err
|
|
}
|
|
if caos_errs.IsNotFound(err) {
|
|
err = nil
|
|
customText = new(iam_model.CustomTextView)
|
|
customText.Language = text.Language
|
|
customText.Template = text.Template
|
|
customText.CreationDate = event.CreationDate
|
|
}
|
|
err = customText.AppendEvent(event)
|
|
case iam_es_model.CustomTextRemoved, model.CustomTextRemoved:
|
|
text := new(iam_model.CustomTextView)
|
|
err = text.SetData(event)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return m.view.DeleteCustomText(event.AggregateID, text.Template, text.Language, text.Key, event)
|
|
case iam_es_model.CustomTextMessageRemoved, model.CustomTextMessageRemoved:
|
|
text := new(iam_model.CustomTextView)
|
|
err = text.SetData(event)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return m.view.DeleteCustomTextTemplate(event.AggregateID, text.Template, text.Language, event)
|
|
default:
|
|
return m.view.ProcessedCustomTextSequence(event)
|
|
}
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return m.view.PutCustomText(customText, event)
|
|
}
|
|
|
|
func (m *CustomText) OnError(event *es_models.Event, err error) error {
|
|
logging.LogWithFields("SPOOL-3m0fs", "id", event.AggregateID).WithError(err).Warn("something went wrong in custom text handler")
|
|
return spooler.HandleError(event, err, m.view.GetLatestCustomTextFailedEvent, m.view.ProcessedCustomTextFailedEvent, m.view.ProcessedCustomTextSequence, m.errorCountUntilSkip)
|
|
}
|
|
|
|
func (o *CustomText) OnSuccess() error {
|
|
return spooler.HandleSuccess(o.view.UpdateCustomTextSpoolerRunTimestamp)
|
|
}
|