Skip to content

Commit

Permalink
Merge pull request #44876 from IONOS-Productivity/feat/reduce_availab…
Browse files Browse the repository at this point in the history
…le_languages_set

feat: reduce available languages per config value "reduce_to_languages"
  • Loading branch information
nickvergessen authored Jul 1, 2024
2 parents d5b7525 + aceb4d7 commit 7525edd
Show file tree
Hide file tree
Showing 3 changed files with 61 additions and 1 deletion.
11 changes: 10 additions & 1 deletion config/config.sample.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
* SPDX-License-Identifier: AGPL-3.0-only
*/

/**
* This configuration file is only provided to document the different
* configuration options and their usage.
Expand Down Expand Up @@ -228,6 +228,15 @@
*/
'default_locale' => 'en_US',

/**
* With this setting is possible to reduce the languages available in the
* language chooser. The languages have to be set as array values using ISO_639-1
* language codes such as ``en`` for English, ``de`` for German etc.
*
* For example: Set to ['de', 'fr'] to only allow German and French languages.
*/
'reduce_to_languages' => [],

/**
* This sets the default region for phone numbers on your Nextcloud server,
* using ISO 3166-1 country codes such as ``DE`` for Germany, ``FR`` for France, …
Expand Down
4 changes: 4 additions & 0 deletions lib/private/L10N/Factory.php
Original file line number Diff line number Diff line change
Expand Up @@ -576,6 +576,10 @@ public function getLanguages(): array {
}

$languageCodes = $this->findAvailableLanguages();
$reduceToLanguages = $this->config->getSystemValue('reduce_to_languages', []);
if (!empty($reduceToLanguages)) {
$languageCodes = array_intersect($languageCodes, $reduceToLanguages);
}

$commonLanguages = [];
$otherLanguages = [];
Expand Down
47 changes: 47 additions & 0 deletions tests/lib/L10N/FactoryTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -700,6 +700,53 @@ public function testRespectDefaultLanguage($lang, $defaultLanguage, $langExists,
self::assertSame($expected, $result);
}

public static function dataTestReduceToLanguages(): array {
return [
['en', ['en', 'de', 'fr', 'it', 'es'], ['en', 'fr', 'de'], ['en', 'fr', 'de']],
['en', ['en', 'de', 'fr', 'it', 'es'], ['en', 'de'], ['en', 'de']],
['en', ['en', 'de', 'fr', 'it', 'es'], [], ['de', 'en', 'es', 'fr', 'it']],
];
}

/**
* test
* - if available languages set can be reduced by configuration
* - if available languages set is not reduced to an empty set if
* the reduce config is an empty set
*
* @dataProvider dataTestReduceToLanguages
*
* @param string $lang
* @param array $availableLanguages
* @param array $reducedLanguageSet
* @param array $expected
*/
public function testReduceLanguagesByConfiguration(string $lang, array $availableLanguages, array $reducedLanguageSet, array $expected): void {
$factory = $this->getFactory(['findAvailableLanguages', 'languageExists']);
$factory->expects(self::any())
->method('languageExists')->willReturn(true);
$factory->expects(self::any())
->method('findAvailableLanguages')
->willReturnCallback(function ($app) use ($availableLanguages) {
return $availableLanguages;
});

$this->config
->method('getSystemValue')
->willReturnMap([
['force_language', false, false],
['default_language', false, $lang],
['reduce_to_languages', [], $reducedLanguageSet]
]);

$result = $this->invokePrivate($factory, 'getLanguages');
$commonLanguagesCodes = array_map(function ($lang) {
return $lang['code'];
}, $result['commonLanguages']);

self::assertEqualsCanonicalizing($expected, $commonLanguagesCodes);
}

public function languageIteratorRequestProvider():array {
return [
[ true, $this->createMock(IUser::class)],
Expand Down

0 comments on commit 7525edd

Please sign in to comment.