summaryrefslogtreecommitdiff
path: root/i18n/i18n.go
diff options
context:
space:
mode:
authorJeroen Wijenbergh <jeroen.wijenbergh@geant.org>2025-08-25 10:59:37 +0200
committerJeroen Wijenbergh <jeroen.wijenbergh@geant.org>2025-08-25 13:06:41 +0200
commit27b95b4911da055fe9b5fb37b5fb4a33eda6b989 (patch)
treef6eb1143fa9bd2995d671b71d75c950e2c703660 /i18n/i18n.go
parentb4f4f5600298436c63b89f289c318d777300c499 (diff)
All: Remove util packages
Was giving linting errors and it's not a good idea anyways
Diffstat (limited to 'i18n/i18n.go')
-rw-r--r--i18n/i18n.go54
1 files changed, 54 insertions, 0 deletions
diff --git a/i18n/i18n.go b/i18n/i18n.go
new file mode 100644
index 0000000..02b9028
--- /dev/null
+++ b/i18n/i18n.go
@@ -0,0 +1,54 @@
+// Package i18n implements utility functions for internationalization
+package i18n
+
+import "strings"
+
+// GetLanguageMatched uses a map from language tags to strings to extract the right language given the tag
+// It implements it according to https://github.com/eduvpn/documentation/blob/dc4d53c47dd7a69e95d6650eec408e16eaa814a2/SERVER_DISCOVERY.md#language-matching
+func GetLanguageMatched(langMap map[string]string, langTag string) string {
+ // If no map is given, return the empty string
+ if len(langMap) == 0 {
+ return ""
+ }
+ // Try to find the exact match
+ if val, ok := langMap[langTag]; ok {
+ return val
+ }
+ // Try to find a key that starts with the OS language setting
+ for k := range langMap {
+ if strings.HasPrefix(k, langTag) {
+ return langMap[k]
+ }
+ }
+ // Try to find a key that starts with the first part of the OS language (e.g. de-)
+ pts := strings.Split(langTag, "-")
+ // We have a "-"
+ if len(pts) > 1 {
+ for k := range langMap {
+ if strings.HasPrefix(k, pts[0]+"-") {
+ return langMap[k]
+ }
+ }
+ }
+ // search for just the language (e.g. de)
+ for k := range langMap {
+ if k == pts[0] {
+ return langMap[k]
+ }
+ }
+
+ // Pick one that is deemed best, e.g. en-US or en, but note that not all languages are always available!
+ // We force an entry that is english exactly or with an english prefix
+ for k := range langMap {
+ if k == "en" || strings.HasPrefix(k, "en-") {
+ return langMap[k]
+ }
+ }
+
+ // Otherwise just return one
+ for k := range langMap {
+ return langMap[k]
+ }
+
+ return ""
+}