diff options
Diffstat (limited to 'core/Controller/WipeController.php')
-rw-r--r-- | core/Controller/WipeController.php | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/core/Controller/WipeController.php b/core/Controller/WipeController.php new file mode 100644 index 00000000000..1b57be71aa0 --- /dev/null +++ b/core/Controller/WipeController.php @@ -0,0 +1,87 @@ +<?php + +declare(strict_types=1); + +/** + * SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors + * SPDX-License-Identifier: AGPL-3.0-or-later + */ +namespace OC\Core\Controller; + +use OC\Authentication\Token\RemoteWipe; +use OCP\AppFramework\Controller; +use OCP\AppFramework\Http; +use OCP\AppFramework\Http\Attribute\AnonRateLimit; +use OCP\AppFramework\Http\Attribute\FrontpageRoute; +use OCP\AppFramework\Http\Attribute\NoCSRFRequired; +use OCP\AppFramework\Http\Attribute\OpenAPI; +use OCP\AppFramework\Http\Attribute\PublicPage; +use OCP\AppFramework\Http\JSONResponse; +use OCP\Authentication\Exceptions\InvalidTokenException; +use OCP\IRequest; + +#[OpenAPI(scope: OpenAPI::SCOPE_DEFAULT)] +class WipeController extends Controller { + public function __construct( + string $appName, + IRequest $request, + private RemoteWipe $remoteWipe, + ) { + parent::__construct($appName, $request); + } + + /** + * Check if the device should be wiped + * + * @param string $token App password + * + * @return JSONResponse<Http::STATUS_OK, array{wipe: bool}, array{}>|JSONResponse<Http::STATUS_NOT_FOUND, list<empty>, array{}> + * + * 200: Device should be wiped + * 404: Device should not be wiped + */ + #[PublicPage] + #[NoCSRFRequired] + #[AnonRateLimit(limit: 10, period: 300)] + #[FrontpageRoute(verb: 'POST', url: '/core/wipe/check')] + public function checkWipe(string $token): JSONResponse { + try { + if ($this->remoteWipe->start($token)) { + return new JSONResponse([ + 'wipe' => true + ]); + } + + return new JSONResponse([], Http::STATUS_NOT_FOUND); + } catch (InvalidTokenException $e) { + return new JSONResponse([], Http::STATUS_NOT_FOUND); + } + } + + + /** + * Finish the wipe + * + * @param string $token App password + * + * @return JSONResponse<Http::STATUS_OK|Http::STATUS_NOT_FOUND, list<empty>, array{}> + * + * 200: Wipe finished successfully + * 404: Device should not be wiped + */ + #[PublicPage] + #[NoCSRFRequired] + #[AnonRateLimit(limit: 10, period: 300)] + #[FrontpageRoute(verb: 'POST', url: '/core/wipe/success')] + public function wipeDone(string $token): JSONResponse { + try { + if ($this->remoteWipe->finish($token)) { + return new JSONResponse([]); + } + + return new JSONResponse([], Http::STATUS_NOT_FOUND); + } catch (InvalidTokenException $e) { + return new JSONResponse([], Http::STATUS_NOT_FOUND); + } + } +} |