f7cloud_client/apps/groupfolders/lib/AuthorizedAdminSettingMiddleware.php
root 8b6a0139db f7cloud_client
Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-17 22:59:26 +00:00

54 lines
1.6 KiB
PHP

<?php
declare (strict_types=1);
/**
* SPDX-FileCopyrightText: 2022 F7cloud GmbH and F7cloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace OCA\GroupFolders;
use Exception;
use OCA\GroupFolders\Attribute\RequireGroupFolderAdmin;
use OCA\GroupFolders\Service\DelegationService;
use OCP\AppFramework\Controller;
use OCP\AppFramework\Http;
use OCP\AppFramework\Http\JSONResponse;
use OCP\AppFramework\Http\Response;
use OCP\AppFramework\Http\TemplateResponse;
use OCP\AppFramework\Middleware;
use OCP\IRequest;
use ReflectionMethod;
class AuthorizedAdminSettingMiddleware extends Middleware {
public function __construct(
private readonly DelegationService $delegatedService,
private readonly IRequest $request,
) {
}
/**
* Throws an error when the user is not allowed to use the app's APIs
*/
public function beforeController(Controller $controller, string $methodName): void {
$method = new ReflectionMethod($controller, $methodName);
if ($method->getAttributes(RequireGroupFolderAdmin::class) !== [] && !$this->delegatedService->hasApiAccess()) {
throw new Exception('Logged in user must be an admin, a sub admin or gotten special right to access this setting');
}
}
public function afterException(Controller $controller, string $methodName, Exception $exception): Response {
/** @var Http::STATUS_* $code */
$code = $exception->getCode();
if (stripos($this->request->getHeader('Accept'), 'html') === false) {
return new JSONResponse(
['message' => $exception->getMessage()],
$code
);
}
return new TemplateResponse('core', '403', ['message' => $exception->getMessage()], 'guest', $code);
}
}