From a624a2b34f87f7655b008f940ad5427739501fed Mon Sep 17 00:00:00 2001 From: Maxence Lange Date: Wed, 17 Apr 2024 16:27:21 -0100 Subject: [PATCH] fix(appconfig): returns correct value on details Signed-off-by: Maxence Lange --- core/Command/Config/App/SetConfig.php | 4 ++-- lib/private/AppConfig.php | 10 ++++++++-- tests/lib/AppConfigTest.php | 2 +- 3 files changed, 11 insertions(+), 5 deletions(-) diff --git a/core/Command/Config/App/SetConfig.php b/core/Command/Config/App/SetConfig.php index ae6f24e71d49e..3adba4af69704 100644 --- a/core/Command/Config/App/SetConfig.php +++ b/core/Command/Config/App/SetConfig.php @@ -173,8 +173,8 @@ protected function execute(InputInterface $input, OutputInterface $output): int */ $sensitive = $input->getOption('sensitive'); try { - $currSensitive = $this->appConfig->isLazy($appName, $configName); - if ($sensitive === null || $sensitive === $currSensitive || !$this->ask($input, $output, ($sensitive) ? 'LAZY' : 'NOT LAZY')) { + $currSensitive = $this->appConfig->isSensitive($appName, $configName, null); + if ($sensitive === null || $sensitive === $currSensitive || !$this->ask($input, $output, ($sensitive) ? 'SENSITIVE' : 'NOT SENSITIVE')) { $sensitive = $currSensitive; } } catch (AppConfigUnknownKeyException) { diff --git a/lib/private/AppConfig.php b/lib/private/AppConfig.php index c72a407383205..338792e23d179 100644 --- a/lib/private/AppConfig.php +++ b/lib/private/AppConfig.php @@ -1034,14 +1034,20 @@ public function getDetails(string $app, string $key): array { throw new AppConfigUnknownKeyException('unknown config key'); } + $value = $cache[$app][$key]; + $sensitive = $this->isSensitive($app, $key, null); + if ($sensitive && str_starts_with($value, self::ENCRYPTION_PREFIX)) { + $value = $this->crypto->decrypt(substr($value, self::ENCRYPTION_PREFIX_LENGTH)); + } + return [ 'app' => $app, 'key' => $key, - 'value' => $cache[$app][$key], + 'value' => $value, 'type' => $type, 'lazy' => $lazy, 'typeString' => $typeString, - 'sensitive' => $this->isSensitive($app, $key, null) + 'sensitive' => $sensitive ]; } diff --git a/tests/lib/AppConfigTest.php b/tests/lib/AppConfigTest.php index 5bbc3f56791ea..d25a25c8e6637 100644 --- a/tests/lib/AppConfigTest.php +++ b/tests/lib/AppConfigTest.php @@ -1253,7 +1253,7 @@ public function testGetDetailsSensitive(): void { [ 'app' => 'sensitive-app', 'key' => 'lazy-key', - 'value' => $this->baseStruct['sensitive-app']['lazy-key']['encrypted'], + 'value' => 'value', 'type' => 4, 'lazy' => true, 'typeString' => 'string',