Browse Source
Migrate app dir owner check to SetupCheck API
Migrate app dir owner check to SetupCheck API
Signed-off-by: Côme Chilliet <come.chilliet@nextcloud.com>pull/42176/head
No known key found for this signature in database
GPG Key ID: A3E2F658B28C760A
8 changed files with 108 additions and 128 deletions
-
1apps/settings/composer/composer/autoload_classmap.php
-
1apps/settings/composer/composer/autoload_static.php
-
2apps/settings/lib/AppInfo/Application.php
-
49apps/settings/lib/Controller/CheckSetupController.php
-
104apps/settings/lib/SetupChecks/AppDirsWithDifferentOwner.php
-
1apps/settings/tests/Controller/CheckSetupControllerTest.php
-
15core/js/setupchecks.js
-
63core/js/tests/specs/setupchecksSpec.js
@ -0,0 +1,104 @@ |
|||
<?php |
|||
|
|||
declare(strict_types=1); |
|||
|
|||
/** |
|||
* @copyright Copyright (c) 2023 Côme Chilliet <come.chilliet@nextcloud.com> |
|||
* |
|||
* @author Côme Chilliet <come.chilliet@nextcloud.com> |
|||
* |
|||
* @license GNU AGPL version 3 or any later version |
|||
* |
|||
* This program is free software: you can redistribute it and/or modify |
|||
* it under the terms of the GNU Affero General Public License as |
|||
* published by the Free Software Foundation, either version 3 of the |
|||
* License, or (at your option) any later version. |
|||
* |
|||
* This program is distributed in the hope that it will be useful, |
|||
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
* GNU Affero General Public License for more details. |
|||
* |
|||
* You should have received a copy of the GNU Affero General Public License |
|||
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
* |
|||
*/ |
|||
namespace OCA\Settings\SetupChecks; |
|||
|
|||
use OCP\IL10N; |
|||
use OCP\SetupCheck\ISetupCheck; |
|||
use OCP\SetupCheck\SetupResult; |
|||
|
|||
class AppDirsWithDifferentOwner implements ISetupCheck { |
|||
public function __construct( |
|||
private IL10N $l10n, |
|||
) { |
|||
} |
|||
|
|||
public function getName(): string { |
|||
return $this->l10n->t('App directories owner'); |
|||
} |
|||
|
|||
public function getCategory(): string { |
|||
return 'security'; |
|||
} |
|||
|
|||
/** |
|||
* Iterates through the configured app roots and |
|||
* tests if the subdirectories are owned by the same user than the current user. |
|||
* |
|||
* @return string[] |
|||
*/ |
|||
private function getAppDirsWithDifferentOwner(int $currentUser): array { |
|||
$appDirsWithDifferentOwner = [[]]; |
|||
|
|||
foreach (\OC::$APPSROOTS as $appRoot) { |
|||
if ($appRoot['writable'] === true) { |
|||
$appDirsWithDifferentOwner[] = $this->getAppDirsWithDifferentOwnerForAppRoot($currentUser, $appRoot); |
|||
} |
|||
} |
|||
|
|||
$appDirsWithDifferentOwner = array_merge(...$appDirsWithDifferentOwner); |
|||
sort($appDirsWithDifferentOwner); |
|||
|
|||
return $appDirsWithDifferentOwner; |
|||
} |
|||
|
|||
/** |
|||
* Tests if the directories for one apps directory are writable by the current user. |
|||
* |
|||
* @param int $currentUser The current user |
|||
* @param array $appRoot The app root config |
|||
* @return string[] The none writable directory paths inside the app root |
|||
*/ |
|||
private function getAppDirsWithDifferentOwnerForAppRoot(int $currentUser, array $appRoot): array { |
|||
$appDirsWithDifferentOwner = []; |
|||
$appsPath = $appRoot['path']; |
|||
$appsDir = new \DirectoryIterator($appRoot['path']); |
|||
|
|||
foreach ($appsDir as $fileInfo) { |
|||
if ($fileInfo->isDir() && !$fileInfo->isDot()) { |
|||
$absAppPath = $appsPath . DIRECTORY_SEPARATOR . $fileInfo->getFilename(); |
|||
$appDirUser = fileowner($absAppPath); |
|||
if ($appDirUser !== $currentUser) { |
|||
$appDirsWithDifferentOwner[] = $absAppPath; |
|||
} |
|||
} |
|||
} |
|||
|
|||
return $appDirsWithDifferentOwner; |
|||
} |
|||
|
|||
public function run(): SetupResult { |
|||
$currentUser = posix_getuid(); |
|||
$currentUserInfos = posix_getpwuid($currentUser) ?: []; |
|||
$appDirsWithDifferentOwner = $this->getAppDirsWithDifferentOwner($currentUser); |
|||
if (count($appDirsWithDifferentOwner) > 0) { |
|||
return SetupResult::warning( |
|||
$this->l10n->t("Some app directories are owned by a different user than the web server one. This may be the case if apps have been installed manually. Check the permissions of the following app directories:\n%s", implode("\n", $appDirsWithDifferentOwner)) |
|||
); |
|||
} else { |
|||
return SetupResult::success($this->l10n->t('App directories have the correct owner "%s"', [$currentUserInfos['name'] ?? ''])); |
|||
} |
|||
} |
|||
} |
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue