2021-07-05 13:10:49 +00:00
|
|
|
package view
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/jinzhu/gorm"
|
|
|
|
|
|
|
|
"github.com/caos/zitadel/internal/domain"
|
|
|
|
caos_errs "github.com/caos/zitadel/internal/errors"
|
|
|
|
iam_model "github.com/caos/zitadel/internal/iam/model"
|
|
|
|
"github.com/caos/zitadel/internal/iam/repository/view/model"
|
|
|
|
"github.com/caos/zitadel/internal/view/repository"
|
|
|
|
)
|
|
|
|
|
|
|
|
func GetCustomTexts(db *gorm.DB, table string, aggregateID, template, lang string) ([]*model.CustomTextView, error) {
|
|
|
|
texts := make([]*model.CustomTextView, 0)
|
|
|
|
queries := []*iam_model.CustomTextSearchQuery{
|
|
|
|
{
|
|
|
|
Key: iam_model.CustomTextSearchKeyAggregateID,
|
|
|
|
Value: aggregateID,
|
|
|
|
Method: domain.SearchMethodEquals,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: iam_model.CustomTextSearchKeyTemplate,
|
|
|
|
Value: template,
|
|
|
|
Method: domain.SearchMethodEquals,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: iam_model.CustomTextSearchKeyLanguage,
|
|
|
|
Value: lang,
|
|
|
|
Method: domain.SearchMethodEquals,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
query := repository.PrepareSearchQuery(table, model.CustomTextSearchRequest{Queries: queries})
|
|
|
|
_, err := query(db, &texts)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return texts, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func GetCustomTextsByAggregateIDAndTemplate(db *gorm.DB, table string, aggregateID, template string) ([]*model.CustomTextView, error) {
|
|
|
|
texts := make([]*model.CustomTextView, 0)
|
|
|
|
queries := []*iam_model.CustomTextSearchQuery{
|
|
|
|
{
|
|
|
|
Key: iam_model.CustomTextSearchKeyAggregateID,
|
|
|
|
Value: aggregateID,
|
|
|
|
Method: domain.SearchMethodEquals,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: iam_model.CustomTextSearchKeyTemplate,
|
|
|
|
Value: template,
|
|
|
|
Method: domain.SearchMethodEquals,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
query := repository.PrepareSearchQuery(table, model.CustomTextSearchRequest{Queries: queries})
|
|
|
|
_, err := query(db, &texts)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return texts, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func CustomTextByIDs(db *gorm.DB, table, aggregateID, template, lang, key string) (*model.CustomTextView, error) {
|
|
|
|
customText := new(model.CustomTextView)
|
|
|
|
aggregateIDQuery := &model.CustomTextSearchQuery{Key: iam_model.CustomTextSearchKeyAggregateID, Value: aggregateID, Method: domain.SearchMethodEquals}
|
|
|
|
textTypeQuery := &model.CustomTextSearchQuery{Key: iam_model.CustomTextSearchKeyTemplate, Value: template, Method: domain.SearchMethodEquals}
|
|
|
|
languageQuery := &model.CustomTextSearchQuery{Key: iam_model.CustomTextSearchKeyLanguage, Value: lang, Method: domain.SearchMethodEquals}
|
|
|
|
keyQuery := &model.CustomTextSearchQuery{Key: iam_model.CustomTextSearchKeyKey, Value: key, Method: domain.SearchMethodEquals}
|
|
|
|
query := repository.PrepareGetByQuery(table, aggregateIDQuery, textTypeQuery, languageQuery, keyQuery)
|
|
|
|
err := query(db, customText)
|
|
|
|
if caos_errs.IsNotFound(err) {
|
|
|
|
return nil, caos_errs.ThrowNotFound(nil, "VIEW-8nUU3", "Errors.CustomCustomText.NotExisting")
|
|
|
|
}
|
|
|
|
return customText, err
|
|
|
|
}
|
|
|
|
|
|
|
|
func PutCustomText(db *gorm.DB, table string, customText *model.CustomTextView) error {
|
|
|
|
save := repository.PrepareSave(table)
|
|
|
|
return save(db, customText)
|
|
|
|
}
|
|
|
|
|
2021-07-20 09:40:53 +00:00
|
|
|
func DeleteCustomText(db *gorm.DB, table, aggregateID, template, lang, key string) error {
|
2021-07-05 13:10:49 +00:00
|
|
|
aggregateIDSearch := repository.Key{Key: model.CustomTextSearchKey(iam_model.CustomTextSearchKeyAggregateID), Value: aggregateID}
|
|
|
|
templateSearch := repository.Key{Key: model.CustomTextSearchKey(iam_model.CustomTextSearchKeyTemplate), Value: template}
|
|
|
|
languageSearch := repository.Key{Key: model.CustomTextSearchKey(iam_model.CustomTextSearchKeyLanguage), Value: lang}
|
2021-07-20 09:40:53 +00:00
|
|
|
keySearch := repository.Key{Key: model.CustomTextSearchKey(iam_model.CustomTextSearchKeyKey), Value: key}
|
|
|
|
delete := repository.PrepareDeleteByKeys(table, aggregateIDSearch, templateSearch, keySearch, languageSearch)
|
2021-07-05 13:10:49 +00:00
|
|
|
return delete(db)
|
|
|
|
}
|
feat(console): message and login texts, privacy policy (#2016)
* 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>
2021-07-26 10:44:45 +00:00
|
|
|
|
|
|
|
func DeleteCustomTextTemplate(db *gorm.DB, table, aggregateID, template, lang string) error {
|
|
|
|
aggregateIDSearch := repository.Key{Key: model.CustomTextSearchKey(iam_model.CustomTextSearchKeyAggregateID), Value: aggregateID}
|
|
|
|
templateSearch := repository.Key{Key: model.CustomTextSearchKey(iam_model.CustomTextSearchKeyTemplate), Value: template}
|
|
|
|
languageSearch := repository.Key{Key: model.CustomTextSearchKey(iam_model.CustomTextSearchKeyLanguage), Value: lang}
|
|
|
|
delete := repository.PrepareDeleteByKeys(table, aggregateIDSearch, templateSearch, languageSearch)
|
|
|
|
return delete(db)
|
|
|
|
}
|