mirror of
https://github.com/zitadel/zitadel.git
synced 2025-08-12 06:57:33 +00:00
feat: handle ui_locales in login (#1994)
* fix: handle ui_locales in login * move supportedlanguage func into i18n package * update oidc pkg
This commit is contained in:
2
go.mod
2
go.mod
@@ -16,7 +16,7 @@ require (
|
|||||||
github.com/allegro/bigcache v1.2.1
|
github.com/allegro/bigcache v1.2.1
|
||||||
github.com/boombuler/barcode v1.0.1-0.20190219062509-6c824513bacc
|
github.com/boombuler/barcode v1.0.1-0.20190219062509-6c824513bacc
|
||||||
github.com/caos/logging v0.0.2
|
github.com/caos/logging v0.0.2
|
||||||
github.com/caos/oidc v0.15.3
|
github.com/caos/oidc v0.15.6
|
||||||
github.com/caos/orbos v1.5.14-0.20210428081839-983ffc569980
|
github.com/caos/orbos v1.5.14-0.20210428081839-983ffc569980
|
||||||
github.com/cockroachdb/cockroach-go/v2 v2.1.0
|
github.com/cockroachdb/cockroach-go/v2 v2.1.0
|
||||||
github.com/duo-labs/webauthn v0.0.0-20200714211715-1daaee874e43
|
github.com/duo-labs/webauthn v0.0.0-20200714211715-1daaee874e43
|
||||||
|
4
go.sum
4
go.sum
@@ -145,8 +145,8 @@ github.com/boombuler/barcode v1.0.1-0.20190219062509-6c824513bacc/go.mod h1:paBW
|
|||||||
github.com/caos/logging v0.0.2 h1:ebg5C/HN0ludYR+WkvnFjwSExF4wvyiWPyWGcKMYsoo=
|
github.com/caos/logging v0.0.2 h1:ebg5C/HN0ludYR+WkvnFjwSExF4wvyiWPyWGcKMYsoo=
|
||||||
github.com/caos/logging v0.0.2/go.mod h1:9LKiDE2ChuGv6CHYif/kiugrfEXu9AwDiFWSreX7Wp0=
|
github.com/caos/logging v0.0.2/go.mod h1:9LKiDE2ChuGv6CHYif/kiugrfEXu9AwDiFWSreX7Wp0=
|
||||||
github.com/caos/oidc v0.14.4/go.mod h1:H5Y2zw3YIrWqQOoy0wcmZva2a66bumDyU2iOhXiM9uA=
|
github.com/caos/oidc v0.14.4/go.mod h1:H5Y2zw3YIrWqQOoy0wcmZva2a66bumDyU2iOhXiM9uA=
|
||||||
github.com/caos/oidc v0.15.3 h1:DNzzvSgUbhUewrZKOVF9nDop0AfMy0wjnMy/rD9f8xA=
|
github.com/caos/oidc v0.15.6 h1:DKX5gGBbN0j7fpcDNNTjlVCA+I9D0gePFGnZFteTERs=
|
||||||
github.com/caos/oidc v0.15.3/go.mod h1:doQ1B/mGnQWbgS+UOANIQCPJe1+KACyxQ8wjV2d11h0=
|
github.com/caos/oidc v0.15.6/go.mod h1:doQ1B/mGnQWbgS+UOANIQCPJe1+KACyxQ8wjV2d11h0=
|
||||||
github.com/caos/orbos v1.5.14-0.20210428081839-983ffc569980 h1:Fz0aYUwGMA2tsu5w7SryqFGjqGClJVHbyhBMT5SXtPU=
|
github.com/caos/orbos v1.5.14-0.20210428081839-983ffc569980 h1:Fz0aYUwGMA2tsu5w7SryqFGjqGClJVHbyhBMT5SXtPU=
|
||||||
github.com/caos/orbos v1.5.14-0.20210428081839-983ffc569980/go.mod h1:2I8oiZb5SMRm/qTLvwpSmdV0M6ex8J/UKyxUGfKaqJo=
|
github.com/caos/orbos v1.5.14-0.20210428081839-983ffc569980/go.mod h1:2I8oiZb5SMRm/qTLvwpSmdV0M6ex8J/UKyxUGfKaqJo=
|
||||||
github.com/casbin/casbin/v2 v2.1.2/go.mod h1:YcPU1XXisHhLzuxH9coDNf2FbKpjGlbCg3n9yuLkIJQ=
|
github.com/casbin/casbin/v2 v2.1.2/go.mod h1:YcPU1XXisHhLzuxH9coDNf2FbKpjGlbCg3n9yuLkIJQ=
|
||||||
|
@@ -6,6 +6,8 @@ import (
|
|||||||
|
|
||||||
"github.com/caos/logging"
|
"github.com/caos/logging"
|
||||||
"github.com/caos/oidc/pkg/op"
|
"github.com/caos/oidc/pkg/op"
|
||||||
|
"github.com/rakyll/statik/fs"
|
||||||
|
"golang.org/x/text/language"
|
||||||
|
|
||||||
http_utils "github.com/caos/zitadel/internal/api/http"
|
http_utils "github.com/caos/zitadel/internal/api/http"
|
||||||
"github.com/caos/zitadel/internal/api/http/middleware"
|
"github.com/caos/zitadel/internal/api/http/middleware"
|
||||||
@@ -13,6 +15,7 @@ import (
|
|||||||
"github.com/caos/zitadel/internal/command"
|
"github.com/caos/zitadel/internal/command"
|
||||||
"github.com/caos/zitadel/internal/config/types"
|
"github.com/caos/zitadel/internal/config/types"
|
||||||
"github.com/caos/zitadel/internal/crypto"
|
"github.com/caos/zitadel/internal/crypto"
|
||||||
|
"github.com/caos/zitadel/internal/i18n"
|
||||||
"github.com/caos/zitadel/internal/id"
|
"github.com/caos/zitadel/internal/id"
|
||||||
"github.com/caos/zitadel/internal/query"
|
"github.com/caos/zitadel/internal/query"
|
||||||
"github.com/caos/zitadel/internal/telemetry/metrics"
|
"github.com/caos/zitadel/internal/telemetry/metrics"
|
||||||
@@ -74,6 +77,9 @@ func NewProvider(ctx context.Context, config OPHandlerConfig, command *command.C
|
|||||||
copy(config.OPConfig.CryptoKey[:], cryptoKey)
|
copy(config.OPConfig.CryptoKey[:], cryptoKey)
|
||||||
config.OPConfig.CodeMethodS256 = true
|
config.OPConfig.CodeMethodS256 = true
|
||||||
config.OPConfig.GrantTypeRefreshToken = true
|
config.OPConfig.GrantTypeRefreshToken = true
|
||||||
|
supportedLanguages, err := getSupportedLanguages()
|
||||||
|
logging.Log("OIDC-GBd3t").OnError(err).Panic("cannot get supported languages")
|
||||||
|
config.OPConfig.SupportedUILocales = supportedLanguages
|
||||||
metricTypes := []metrics.MetricType{metrics.MetricTypeRequestCount, metrics.MetricTypeStatusCode, metrics.MetricTypeTotalCount}
|
metricTypes := []metrics.MetricType{metrics.MetricTypeRequestCount, metrics.MetricTypeStatusCode, metrics.MetricTypeTotalCount}
|
||||||
provider, err := op.NewOpenIDProvider(
|
provider, err := op.NewOpenIDProvider(
|
||||||
ctx,
|
ctx,
|
||||||
@@ -114,3 +120,11 @@ func newStorage(config StorageConfig, command *command.Commands, query *query.Qu
|
|||||||
func (o *OPStorage) Health(ctx context.Context) error {
|
func (o *OPStorage) Health(ctx context.Context) error {
|
||||||
return o.repo.Health(ctx)
|
return o.repo.Health(ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getSupportedLanguages() ([]language.Tag, error) {
|
||||||
|
statikLoginFS, err := fs.NewWithNamespace("login")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return i18n.SupportedLanguages(statikLoginFS)
|
||||||
|
}
|
||||||
|
@@ -6,6 +6,7 @@ import (
|
|||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"github.com/BurntSushi/toml"
|
"github.com/BurntSushi/toml"
|
||||||
"github.com/caos/logging"
|
"github.com/caos/logging"
|
||||||
@@ -24,9 +25,10 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type Translator struct {
|
type Translator struct {
|
||||||
bundle *i18n.Bundle
|
bundle *i18n.Bundle
|
||||||
cookieName string
|
cookieName string
|
||||||
cookieHandler *http_util.CookieHandler
|
cookieHandler *http_util.CookieHandler
|
||||||
|
preferredLanguages []string
|
||||||
}
|
}
|
||||||
|
|
||||||
type TranslatorConfig struct {
|
type TranslatorConfig struct {
|
||||||
@@ -87,6 +89,30 @@ func addFileFromFileSystemToBundle(dir http.FileSystem, bundle *i18n.Bundle, fil
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func SupportedLanguages(dir http.FileSystem) ([]language.Tag, error) {
|
||||||
|
i18nDir, err := dir.Open("/i18n")
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.ThrowNotFound(err, "I18N-Dbt42", "cannot open dir")
|
||||||
|
}
|
||||||
|
defer i18nDir.Close()
|
||||||
|
files, err := i18nDir.Readdir(0)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.ThrowNotFound(err, "I18N-Gh4zk", "cannot read dir")
|
||||||
|
}
|
||||||
|
languages := make([]language.Tag, 0, len(files))
|
||||||
|
for _, file := range files {
|
||||||
|
lang := language.Make(strings.TrimSuffix(file.Name(), ".yaml"))
|
||||||
|
if lang != language.Und {
|
||||||
|
languages = append(languages, lang)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return languages, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *Translator) SupportedLanguages() []language.Tag {
|
||||||
|
return t.bundle.LanguageTags()
|
||||||
|
}
|
||||||
|
|
||||||
func (t *Translator) AddMessages(tag language.Tag, messages ...Message) error {
|
func (t *Translator) AddMessages(tag language.Tag, messages ...Message) error {
|
||||||
if len(messages) == 0 {
|
if len(messages) == 0 {
|
||||||
return nil
|
return nil
|
||||||
@@ -136,7 +162,7 @@ func (t *Translator) localizer(langs ...string) *i18n.Localizer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (t *Translator) langsFromRequest(r *http.Request) []string {
|
func (t *Translator) langsFromRequest(r *http.Request) []string {
|
||||||
langs := make([]string, 0)
|
langs := t.preferredLanguages
|
||||||
if r != nil {
|
if r != nil {
|
||||||
lang, err := t.cookieHandler.GetCookieValue(r, t.cookieName)
|
lang, err := t.cookieHandler.GetCookieValue(r, t.cookieName)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
@@ -148,7 +174,7 @@ func (t *Translator) langsFromRequest(r *http.Request) []string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (t *Translator) langsFromCtx(ctx context.Context) []string {
|
func (t *Translator) langsFromCtx(ctx context.Context) []string {
|
||||||
langs := make([]string, 0)
|
langs := t.preferredLanguages
|
||||||
if ctx != nil {
|
if ctx != nil {
|
||||||
ctxData := authz.GetCtxData(ctx)
|
ctxData := authz.GetCtxData(ctx)
|
||||||
if ctxData.PreferredLanguage != "" {
|
if ctxData.PreferredLanguage != "" {
|
||||||
@@ -159,6 +185,10 @@ func (t *Translator) langsFromCtx(ctx context.Context) []string {
|
|||||||
return langs
|
return langs
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (t *Translator) SetPreferredLanguages(langs ...string) {
|
||||||
|
t.preferredLanguages = langs
|
||||||
|
}
|
||||||
|
|
||||||
func getAcceptLanguageHeader(ctx context.Context) string {
|
func getAcceptLanguageHeader(ctx context.Context) string {
|
||||||
return metautils.ExtractIncoming(ctx).Get("grpcgateway-accept-language")
|
return metautils.ExtractIncoming(ctx).Get("grpcgateway-accept-language")
|
||||||
}
|
}
|
||||||
|
@@ -343,6 +343,7 @@ func (l *Login) getTranslator(authReq *domain.AuthRequest) *i18n.Translator {
|
|||||||
if authReq != nil {
|
if authReq != nil {
|
||||||
l.addLoginTranslations(translator, authReq.DefaultTranslations)
|
l.addLoginTranslations(translator, authReq.DefaultTranslations)
|
||||||
l.addLoginTranslations(translator, authReq.OrgTranslations)
|
l.addLoginTranslations(translator, authReq.OrgTranslations)
|
||||||
|
translator.SetPreferredLanguages(authReq.UiLocales...)
|
||||||
}
|
}
|
||||||
return translator
|
return translator
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user