diff --git a/occ b/occ index b3fed16e82aae..e4dcc80c9da9f 100755 --- a/occ +++ b/occ @@ -1,11 +1,33 @@ #!/usr/bin/env php - * SPDX-License-Identifier: AGPL-3.0-only + * Drop privileges when run as root */ +function dropPrivileges(): void { + if (posix_getuid() !== 0) { + return; + } + + $configPath = __DIR__ . '/config/config.php'; + $uid = fileowner($configPath); + if ($uid === false) { + return; + } + $info = posix_getpwuid($uid); + if ($info === false) { + return; + } + posix_setuid($uid); + posix_setgid($info['gid']); +} -//$argv = $_SERVER['argv']; +dropPrivileges(); require_once __DIR__ . '/console.php';