c6888326b0
Closes #2576. Updates #2275. Updates #2419. Updates #2443. Squashed commit of the following: commit b1a4809ada298d675de12740051ba26fb9945957 Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Fri May 21 14:01:40 2021 +0300 all: add --local-frontend, upd docker commit 619ee7c82f27e3405753003dbec556ffb056d025 Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Thu May 20 15:02:33 2021 +0300 bamboo-specs: bump docker version commit 5c2b2fbce80afdcc81fd0cb83674dc3d64facbf1 Merge: 6536b32d9c60aef6
Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Thu May 20 15:01:47 2021 +0300 Merge branch 'master' into 2275-upd-go commit 6536b32dd4580425f7dedde6765463a79b9bd699 Merge: 9bb32bc46f7fd33a
Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Wed May 19 20:38:48 2021 +0300 Merge branch 'master' into 2275-upd-go commit 9bb32bc4c0ac0f3a97195adc75359e48c9c58897 Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Wed May 19 18:48:50 2021 +0300 all: fix build, imp err handling commit 6868eac7f7d2980fb706881f53e72afe5f7c3447 Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Wed May 19 18:09:32 2021 +0300 all: fix github lint commit ebbb9c55f32fbd57e34e8b161016aa6b291c097c Author: Ainar Garipov <A.Garipov@AdGuard.COM> Date: Wed May 19 17:36:56 2021 +0300 all: update go and backend tools
99 lines
1.7 KiB
Go
99 lines
1.7 KiB
Go
package home
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"net/http"
|
|
"strings"
|
|
|
|
"github.com/AdguardTeam/AdGuardHome/internal/aghstrings"
|
|
"github.com/AdguardTeam/golibs/log"
|
|
)
|
|
|
|
// TODO(a.garipov): Get rid of a global variable?
|
|
var allowedLanguages = aghstrings.NewSet(
|
|
"be",
|
|
"bg",
|
|
"cs",
|
|
"da",
|
|
"de",
|
|
"en",
|
|
"es",
|
|
"fa",
|
|
"fr",
|
|
"hr",
|
|
"hu",
|
|
"id",
|
|
"it",
|
|
"ja",
|
|
"ko",
|
|
"nl",
|
|
"no",
|
|
"pl",
|
|
"pt-br",
|
|
"pt-pt",
|
|
"ro",
|
|
"ru",
|
|
"si-lk",
|
|
"sk",
|
|
"sl",
|
|
"sr-cs",
|
|
"sv",
|
|
"th",
|
|
"tr",
|
|
"vi",
|
|
"zh-cn",
|
|
"zh-hk",
|
|
"zh-tw",
|
|
)
|
|
|
|
func handleI18nCurrentLanguage(w http.ResponseWriter, r *http.Request) {
|
|
w.Header().Set("Content-Type", "text/plain")
|
|
log.Printf("config.Language is %s", config.Language)
|
|
_, err := fmt.Fprintf(w, "%s\n", config.Language)
|
|
if err != nil {
|
|
msg := fmt.Sprintf("Unable to write response json: %s", err)
|
|
log.Println(msg)
|
|
http.Error(w, msg, http.StatusInternalServerError)
|
|
return
|
|
}
|
|
}
|
|
|
|
func handleI18nChangeLanguage(w http.ResponseWriter, r *http.Request) {
|
|
// This use of ReadAll is safe, because request's body is now limited.
|
|
body, err := io.ReadAll(r.Body)
|
|
if err != nil {
|
|
msg := fmt.Sprintf("failed to read request body: %s", err)
|
|
log.Println(msg)
|
|
http.Error(w, msg, http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
language := strings.TrimSpace(string(body))
|
|
if language == "" {
|
|
msg := "empty language specified"
|
|
log.Println(msg)
|
|
http.Error(w, msg, http.StatusBadRequest)
|
|
|
|
return
|
|
}
|
|
|
|
if !allowedLanguages.Has(language) {
|
|
msg := fmt.Sprintf("unknown language specified: %s", language)
|
|
log.Println(msg)
|
|
http.Error(w, msg, http.StatusBadRequest)
|
|
|
|
return
|
|
}
|
|
|
|
func() {
|
|
config.Lock()
|
|
defer config.Unlock()
|
|
|
|
config.Language = language
|
|
}()
|
|
|
|
onConfigModified()
|
|
returnOK(w)
|
|
}
|