summaryrefslogtreecommitdiffstats
path: root/utils
diff options
context:
space:
mode:
authorSaturnino Abril <saturnino.abril@gmail.com>2017-08-06 06:45:46 +0800
committerGitHub <noreply@github.com>2017-08-06 06:45:46 +0800
commit9f3713aa98011596a62315fd3b96fa2e77044081 (patch)
treeb19f16ac6cd421d6540f7c8b6495fceb29838524 /utils
parent2ab2baba5899758b909e8ce80479d497eea4c80c (diff)
downloadchat-9f3713aa98011596a62315fd3b96fa2e77044081.tar.gz
chat-9f3713aa98011596a62315fd3b96fa2e77044081.tar.bz2
chat-9f3713aa98011596a62315fd3b96fa2e77044081.zip
[PLT-7231/PLT-7306] Fix GitLab SSO failure with non-English locale and make config locales more forgiving (#7125)
Diffstat (limited to 'utils')
-rw-r--r--utils/config.go35
-rw-r--r--utils/config_test.go120
2 files changed, 149 insertions, 6 deletions
diff --git a/utils/config.go b/utils/config.go
index 87f3d11f9..6a973fe1c 100644
--- a/utils/config.go
+++ b/utils/config.go
@@ -343,7 +343,12 @@ func LoadConfig(fileName string) {
}
if err := ValidateLocales(&config); err != nil {
- panic(T(err.Id))
+ cfgMutex.Unlock()
+ if err := SaveConfig(CfgFileName, &config); err != nil {
+ err.Translate(T)
+ l4g.Warn(err.Error())
+ }
+ cfgMutex.Lock()
}
if err := ValidateLdapFilter(&config); err != nil {
@@ -562,26 +567,44 @@ func ValidateLdapFilter(cfg *model.Config) *model.AppError {
}
func ValidateLocales(cfg *model.Config) *model.AppError {
+ var err *model.AppError
locales := GetSupportedLocales()
if _, ok := locales[*cfg.LocalizationSettings.DefaultServerLocale]; !ok {
- return model.NewLocAppError("ValidateLocales", "utils.config.supported_server_locale.app_error", nil, "")
+ *cfg.LocalizationSettings.DefaultServerLocale = model.DEFAULT_LOCALE
+ err = model.NewLocAppError("ValidateLocales", "utils.config.supported_server_locale.app_error", nil, "")
}
if _, ok := locales[*cfg.LocalizationSettings.DefaultClientLocale]; !ok {
- return model.NewLocAppError("ValidateLocales", "utils.config.supported_client_locale.app_error", nil, "")
+ *cfg.LocalizationSettings.DefaultClientLocale = model.DEFAULT_LOCALE
+ err = model.NewLocAppError("ValidateLocales", "utils.config.supported_client_locale.app_error", nil, "")
}
if len(*cfg.LocalizationSettings.AvailableLocales) > 0 {
+ isDefaultClientLocaleInAvailableLocales := false
for _, word := range strings.Split(*cfg.LocalizationSettings.AvailableLocales, ",") {
+ if _, ok := locales[word]; !ok {
+ *cfg.LocalizationSettings.AvailableLocales = ""
+ isDefaultClientLocaleInAvailableLocales = true
+ err = model.NewLocAppError("ValidateLocales", "utils.config.supported_available_locales.app_error", nil, "")
+ break
+ }
+
if word == *cfg.LocalizationSettings.DefaultClientLocale {
- return nil
+ isDefaultClientLocaleInAvailableLocales = true
}
}
- return model.NewLocAppError("ValidateLocales", "utils.config.validate_locale.app_error", nil, "")
+ availableLocales := *cfg.LocalizationSettings.AvailableLocales
+
+ if !isDefaultClientLocaleInAvailableLocales {
+ availableLocales += "," + *cfg.LocalizationSettings.DefaultClientLocale
+ err = model.NewLocAppError("ValidateLocales", "utils.config.add_client_locale.app_error", nil, "")
+ }
+
+ *cfg.LocalizationSettings.AvailableLocales = strings.Join(RemoveDuplicatesFromStringArray(strings.Split(availableLocales, ",")), ",")
}
- return nil
+ return err
}
func Desanitize(cfg *model.Config) {
diff --git a/utils/config_test.go b/utils/config_test.go
index 3032766ec..a6bfa4e82 100644
--- a/utils/config_test.go
+++ b/utils/config_test.go
@@ -5,6 +5,7 @@ package utils
import (
"os"
+ "strings"
"testing"
"time"
@@ -157,3 +158,122 @@ func TestConfigListener(t *testing.T) {
t.Fatal("listener 2 should've been called")
}
}
+
+func TestValidateLocales(t *testing.T) {
+ TranslationsPreInit()
+ LoadConfig("config.json")
+
+ defaultServerLocale := *Cfg.LocalizationSettings.DefaultServerLocale
+ defaultClientLocale := *Cfg.LocalizationSettings.DefaultClientLocale
+ availableLocales := *Cfg.LocalizationSettings.AvailableLocales
+
+ defer func() {
+ *Cfg.LocalizationSettings.DefaultClientLocale = defaultClientLocale
+ *Cfg.LocalizationSettings.DefaultServerLocale = defaultServerLocale
+ *Cfg.LocalizationSettings.AvailableLocales = availableLocales
+ }()
+
+ *Cfg.LocalizationSettings.DefaultServerLocale = "en"
+ *Cfg.LocalizationSettings.DefaultClientLocale = "en"
+ *Cfg.LocalizationSettings.AvailableLocales = ""
+
+ // t.Logf("*Cfg.LocalizationSettings.DefaultClientLocale: %+v", *Cfg.LocalizationSettings.DefaultClientLocale)
+ if err := ValidateLocales(Cfg); err != nil {
+ t.Fatal("Should have not returned an error")
+ }
+
+ // validate DefaultServerLocale
+ *Cfg.LocalizationSettings.DefaultServerLocale = "junk"
+ if err := ValidateLocales(Cfg); err != nil {
+ if *Cfg.LocalizationSettings.DefaultServerLocale != "en" {
+ t.Fatal("DefaultServerLocale should have assigned to en as a default value")
+ }
+ } else {
+
+ t.Fatal("Should have returned an error validating DefaultServerLocale")
+ }
+
+ *Cfg.LocalizationSettings.DefaultServerLocale = ""
+ if err := ValidateLocales(Cfg); err != nil {
+ if *Cfg.LocalizationSettings.DefaultServerLocale != "en" {
+ t.Fatal("DefaultServerLocale should have assigned to en as a default value")
+ }
+ } else {
+ t.Fatal("Should have returned an error validating DefaultServerLocale")
+ }
+
+ *Cfg.LocalizationSettings.AvailableLocales = "en"
+ *Cfg.LocalizationSettings.DefaultServerLocale = "de"
+ if err := ValidateLocales(Cfg); err != nil {
+ if strings.Contains(*Cfg.LocalizationSettings.AvailableLocales, *Cfg.LocalizationSettings.DefaultServerLocale) {
+ t.Fatal("DefaultServerLocale should not be added to AvailableLocales")
+ }
+ t.Fatal("Should have not returned an error validating DefaultServerLocale")
+ }
+
+ // validate DefaultClientLocale
+ *Cfg.LocalizationSettings.AvailableLocales = ""
+ *Cfg.LocalizationSettings.DefaultClientLocale = "junk"
+ if err := ValidateLocales(Cfg); err != nil {
+ if *Cfg.LocalizationSettings.DefaultClientLocale != "en" {
+ t.Fatal("DefaultClientLocale should have assigned to en as a default value")
+ }
+ } else {
+
+ t.Fatal("Should have returned an error validating DefaultClientLocale")
+ }
+
+ *Cfg.LocalizationSettings.DefaultClientLocale = ""
+ if err := ValidateLocales(Cfg); err != nil {
+ if *Cfg.LocalizationSettings.DefaultClientLocale != "en" {
+ t.Fatal("DefaultClientLocale should have assigned to en as a default value")
+ }
+ } else {
+ t.Fatal("Should have returned an error validating DefaultClientLocale")
+ }
+
+ *Cfg.LocalizationSettings.AvailableLocales = "en"
+ *Cfg.LocalizationSettings.DefaultClientLocale = "de"
+ if err := ValidateLocales(Cfg); err != nil {
+ if !strings.Contains(*Cfg.LocalizationSettings.AvailableLocales, *Cfg.LocalizationSettings.DefaultClientLocale) {
+ t.Fatal("DefaultClientLocale should have added to AvailableLocales")
+ }
+ } else {
+ t.Fatal("Should have returned an error validating DefaultClientLocale")
+ }
+
+ // validate AvailableLocales
+ *Cfg.LocalizationSettings.DefaultServerLocale = "en"
+ *Cfg.LocalizationSettings.DefaultClientLocale = "en"
+ *Cfg.LocalizationSettings.AvailableLocales = "junk"
+ if err := ValidateLocales(Cfg); err != nil {
+ if *Cfg.LocalizationSettings.AvailableLocales != "" {
+ t.Fatal("AvailableLocales should have assigned to empty string as a default value")
+ }
+ } else {
+ t.Fatal("Should have returned an error validating AvailableLocales")
+ }
+
+ *Cfg.LocalizationSettings.AvailableLocales = "en,de,junk"
+ if err := ValidateLocales(Cfg); err != nil {
+ if *Cfg.LocalizationSettings.AvailableLocales != "" {
+ t.Fatal("AvailableLocales should have assigned to empty string as a default value")
+ }
+ } else {
+ t.Fatal("Should have returned an error validating AvailableLocales")
+ }
+
+ *Cfg.LocalizationSettings.DefaultServerLocale = "fr"
+ *Cfg.LocalizationSettings.DefaultClientLocale = "de"
+ *Cfg.LocalizationSettings.AvailableLocales = "en"
+ if err := ValidateLocales(Cfg); err != nil {
+ if strings.Contains(*Cfg.LocalizationSettings.AvailableLocales, *Cfg.LocalizationSettings.DefaultServerLocale) {
+ t.Fatal("DefaultServerLocale should not be added to AvailableLocales")
+ }
+ if !strings.Contains(*Cfg.LocalizationSettings.AvailableLocales, *Cfg.LocalizationSettings.DefaultClientLocale) {
+ t.Fatal("DefaultClientLocale should have added to AvailableLocales")
+ }
+ } else {
+ t.Fatal("Should have returned an error validating AvailableLocales")
+ }
+}