Documentation ¶
Overview ¶
Package i18n wraps go-i18n lib for manipulating bundles
Index ¶
- Variables
- func GetDefaultLanguage(conf config.Config) string
- func UserLanguage(ctx context.Context, user *idm.User, conf config.Config) string
- func UserLanguageFromContext(ctx context.Context, conf config.Config, returnDefault bool) string
- func UserLanguagesFromRestRequest(req *restful.Request, conf config.Config) []string
- type I18nBundle
Constants ¶
This section is empty.
Variables ¶
var ( // AvailableLanguages stores a manually maintained maps with all languages // that are currently supported by Cells front-end and can be chosen via the interface. AvailableLanguages = map[string]string{ "en-us": "English", "fr": "Français", "de": "Deutsch", "es-es": "Español", "it": "Italiano", "pt-br": "Português", "lv": "Latv", } LanguagesLegacyNames = map[string]string{ "en": "en-us", "fr": "fr", "es": "es-es", "it": "it", "pt": "pt-pt", "pt-br": "pt-br", "de": "de", "ru": "ru", "ca": "ca", "cs": "cs", "da": "da", "et": "et", "fi": "fi", "he": "he", "hu": "hu", "ja": "ja", "ko": "ko", "nl": "nl", "nn": "nn-no", "pl": "pl", "si": "sl", "sv": "sv-se", "tr": "tr", "zh-cn": "zh-cn", "zh-tw": "zh-tw", } )
Functions ¶
func GetDefaultLanguage ¶
GetDefaultLanguage reads default language from config
func UserLanguage ¶
UserLanguage looks for the user roles and check if a language parameter is set (starting from the last). Otherwise returns the default language from config
func UserLanguageFromContext ¶
UserLanguageFromContext tries to find Claims in context and get the language for the corresponding user. If nothing is found, if returnDefault is true it returns the global default language, otherwise it returns an empty string.
func UserLanguagesFromRestRequest ¶
UserLanguagesFromRestRequest tries to find user language from various sources: X-Pydio-Language header, user language inside the system (set via roles), or Accept-Language standard header.
Types ¶
type I18nBundle ¶
func NewI18nBundle ¶
func NewI18nBundle(box packr.Box) *I18nBundle
func (*I18nBundle) GetTranslationFunc ¶
func (b *I18nBundle) GetTranslationFunc(languages ...string) i18n.TranslateFunc
GetTranslationFunc provides the correct translation func for language or the IdentityFunc if language is not supported. Languages can be a list of weighted languages as provided in the http header Accept-Language
func (*I18nBundle) LoadPackrTranslationFiles ¶
func (b *I18nBundle) LoadPackrTranslationFiles(box packr.Box)
LoadPackrTranslationFiles loads goi18n translation files from packr boxes