From 2c5f43fc955cf025f70f5e73dc48f42729b32011 Mon Sep 17 00:00:00 2001 From: Pooya Parsa Date: Wed, 26 Dec 2018 23:24:28 +0330 Subject: [PATCH] Validate `AppleLocale` against supported locales (#33) Fixes #28 --- index.js | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/index.js b/index.js index 3cd60c9..8c73c99 100644 --- a/index.js +++ b/index.js @@ -24,12 +24,30 @@ function getLocale(string) { return (string && string.replace(/[.:].*/, '')); } +function getLocales() { + return execa.stdout('locale', ['-a']); +} + +function getLocalesSync() { + return execa.sync('locale', ['-a']).stdout; +} + +function getSupportedLocale(locale, locales = '') { + return locales.includes(locale) ? locale : defaultLocale; +} + function getAppleLocale() { - return execa.stdout('defaults', ['read', '-globalDomain', 'AppleLocale']); + return Promise.all([ + execa.stdout('defaults', ['read', '-globalDomain', 'AppleLocale']), + getLocales() + ]).then(results => getSupportedLocale(results[0], results[1])); } function getAppleLocaleSync() { - return execa.sync('defaults', ['read', '-globalDomain', 'AppleLocale']).stdout; + return getSupportedLocale( + execa.sync('defaults', ['read', '-globalDomain', 'AppleLocale']).stdout, + getLocalesSync() + ); } function getUnixLocale() {