From 0cc7a7a07f18944e902e34d7a66ea37922df806d Mon Sep 17 00:00:00 2001 From: Marcel Klehr Date: Thu, 26 Mar 2026 10:34:07 +0100 Subject: [PATCH] feat(settings): Log AI config changes to audit log Signed-off-by: Marcel Klehr --- .../settings/lib/Controller/AISettingsController.php | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/apps/settings/lib/Controller/AISettingsController.php b/apps/settings/lib/Controller/AISettingsController.php index 114cbf61514..ba58e30607e 100644 --- a/apps/settings/lib/Controller/AISettingsController.php +++ b/apps/settings/lib/Controller/AISettingsController.php @@ -12,15 +12,19 @@ use OCA\Settings\Settings\Admin\ArtificialIntelligence; use OCP\AppFramework\Controller; use OCP\AppFramework\Http\Attribute\AuthorizedAdminSetting; use OCP\AppFramework\Http\DataResponse; +use OCP\EventDispatcher\IEventDispatcher; use OCP\IAppConfig; use OCP\IRequest; +use OCP\Log\Audit\CriticalActionPerformedEvent; class AISettingsController extends Controller { public function __construct( $appName, IRequest $request, + private string $userId, private IAppConfig $appConfig, + private IEventDispatcher $eventDispatcher, ) { parent::__construct($appName, $request); } @@ -38,7 +42,13 @@ class AISettingsController extends Controller { if (!isset($settings[$key])) { continue; } - $this->appConfig->setValueString('core', $key, json_encode($settings[$key]), lazy: in_array($key, \OC\TaskProcessing\Manager::LAZY_CONFIG_KEYS, true)); + $changed = $this->appConfig->setValueString('core', $key, json_encode($settings[$key]), lazy: in_array($key, \OC\TaskProcessing\Manager::LAZY_CONFIG_KEYS, true)); + if ($changed) { + $this->eventDispatcher->dispatchTyped(new CriticalActionPerformedEvent( + 'AI configuration was changed by user %s: %s was set to %s', + [$this->userId, $key, json_encode($settings[$key])] + )); + } } return new DataResponse();