2018-02-26 11:13:23 -05:00
|
|
|
<?php
|
2019-12-03 13:57:53 -05:00
|
|
|
|
2018-02-26 11:13:23 -05:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
|
|
/**
|
2024-05-27 04:08:53 -04:00
|
|
|
* SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
2018-02-26 11:13:23 -05:00
|
|
|
*/
|
|
|
|
|
namespace OC\Core\Controller;
|
|
|
|
|
|
|
|
|
|
use OC\Security\CSRF\CsrfTokenManager;
|
|
|
|
|
use OCP\AppFramework\Controller;
|
2020-01-03 07:08:37 -05:00
|
|
|
use OCP\AppFramework\Http;
|
2024-01-10 06:35:44 -05:00
|
|
|
use OCP\AppFramework\Http\Attribute\FrontpageRoute;
|
2024-07-25 07:24:59 -04:00
|
|
|
use OCP\AppFramework\Http\Attribute\NoCSRFRequired;
|
2024-12-17 07:17:22 -05:00
|
|
|
use OCP\AppFramework\Http\Attribute\OpenAPI;
|
2024-07-25 07:24:59 -04:00
|
|
|
use OCP\AppFramework\Http\Attribute\PublicPage;
|
2018-02-26 11:13:23 -05:00
|
|
|
use OCP\AppFramework\Http\JSONResponse;
|
|
|
|
|
use OCP\IRequest;
|
|
|
|
|
|
|
|
|
|
class CSRFTokenController extends Controller {
|
2023-06-05 11:05:32 -04:00
|
|
|
public function __construct(
|
|
|
|
|
string $appName,
|
|
|
|
|
IRequest $request,
|
|
|
|
|
private CsrfTokenManager $tokenManager,
|
|
|
|
|
) {
|
2018-02-26 11:13:23 -05:00
|
|
|
parent::__construct($appName, $request);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2024-07-25 11:52:47 -04:00
|
|
|
* Returns a new CSRF token.
|
|
|
|
|
*
|
2024-09-24 09:53:13 -04:00
|
|
|
* @return JSONResponse<Http::STATUS_OK, array{token: string}, array{}>|JSONResponse<Http::STATUS_FORBIDDEN, list<empty>, array{}>
|
2024-07-25 11:52:47 -04:00
|
|
|
*
|
|
|
|
|
* 200: CSRF token returned
|
|
|
|
|
* 403: Strict cookie check failed
|
2025-06-17 15:41:09 -04:00
|
|
|
*
|
|
|
|
|
* @NoTwoFactorRequired
|
2018-02-26 11:13:23 -05:00
|
|
|
*/
|
2024-07-25 07:24:59 -04:00
|
|
|
#[PublicPage]
|
|
|
|
|
#[NoCSRFRequired]
|
2024-01-10 06:35:44 -05:00
|
|
|
#[FrontpageRoute(verb: 'GET', url: '/csrftoken')]
|
2024-12-17 07:17:22 -05:00
|
|
|
#[OpenAPI(scope: OpenAPI::SCOPE_DEFAULT)]
|
2018-02-26 11:13:23 -05:00
|
|
|
public function index(): JSONResponse {
|
2020-01-03 07:08:37 -05:00
|
|
|
if (!$this->request->passesStrictCookieCheck()) {
|
|
|
|
|
return new JSONResponse([], Http::STATUS_FORBIDDEN);
|
|
|
|
|
}
|
|
|
|
|
|
2018-02-26 11:13:23 -05:00
|
|
|
$requestToken = $this->tokenManager->getToken();
|
|
|
|
|
|
|
|
|
|
return new JSONResponse([
|
|
|
|
|
'token' => $requestToken->getEncryptedValue(),
|
|
|
|
|
]);
|
|
|
|
|
}
|
|
|
|
|
}
|