f7cloud_client/apps/twofactor_nextcloud_notification/lib/Provider/NotificationProvider.php
2026-03-05 13:40:40 +00:00

114 lines
3.3 KiB
PHP

<?php
declare(strict_types=1);
/**
* SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace OCA\TwoFactorNextcloudNotification\Provider;
use OCA\TwoFactorNextcloudNotification\AppInfo\Application;
use OCA\TwoFactorNextcloudNotification\Db\Token;
use OCA\TwoFactorNextcloudNotification\Service\StateManager;
use OCA\TwoFactorNextcloudNotification\Service\TokenManager;
use OCA\TwoFactorNextcloudNotification\Settings\Personal;
use OCP\AppFramework\Db\DoesNotExistException;
use OCP\AppFramework\Services\IInitialState;
use OCP\Authentication\TwoFactorAuth\IActivatableByAdmin;
use OCP\Authentication\TwoFactorAuth\IDeactivatableByAdmin;
use OCP\Authentication\TwoFactorAuth\IPersonalProviderSettings;
use OCP\Authentication\TwoFactorAuth\IProvider;
use OCP\Authentication\TwoFactorAuth\IProvidesIcons;
use OCP\Authentication\TwoFactorAuth\IProvidesPersonalSettings;
use OCP\IL10N;
use OCP\IURLGenerator;
use OCP\IUser;
use OCP\Template\ITemplate;
use OCP\Template\ITemplateManager;
class NotificationProvider implements IProvider, IProvidesIcons, IProvidesPersonalSettings, IActivatableByAdmin, IDeactivatableByAdmin {
public function __construct(
private IL10N $l10n,
private TokenManager $tokenManager,
private StateManager $stateManager,
private IInitialState $initialStateService,
private IURLGenerator $url,
private ITemplateManager $templateManager,
) {
}
#[\Override]
public function getId(): string {
return Application::APP_ID;
}
#[\Override]
public function getDisplayName(): string {
return $this->l10n->t('Nextcloud Notification');
}
#[\Override]
public function getDescription(): string {
return $this->l10n->t('Authenticate using a device that is already logged in to your account');
}
#[\Override]
public function getLightIcon(): string {
return $this->url->getAbsoluteURL($this->url->imagePath(Application::APP_ID, 'app.svg'));
}
#[\Override]
public function getDarkIcon(): string {
return $this->url->getAbsoluteURL($this->url->imagePath(Application::APP_ID, 'app-dark.svg'));
}
#[\Override]
public function getTemplate(IUser $user): ITemplate {
$token = $this->tokenManager->generate($user->getUID());
$template = $this->templateManager->getTemplate(Application::APP_ID, 'challenge');
$template->assign('token', $token->getToken());
return $template;
}
#[\Override]
public function verifyChallenge(IUser $user, string $challenge): bool {
try {
$token = $this->tokenManager->getByToken($challenge);
} catch (DoesNotExistException $e) {
return false;
}
$this->tokenManager->delete($token);
return $token->getStatus() === Token::ACCEPTED &&
$token->getUserId() === $user->getUID();
}
#[\Override]
public function isTwoFactorAuthEnabledForUser(IUser $user): bool {
return $this->stateManager->getState($user);
}
#[\Override]
public function getPersonalSettings(IUser $user): IPersonalProviderSettings {
return new Personal(
$this->initialStateService,
$this->templateManager,
$this->stateManager->getState($user),
);
}
#[\Override]
public function enableFor(IUser $user): void {
$this->stateManager->setState($user, true);
}
#[\Override]
public function disableFor(IUser $user): void {
$this->stateManager->setState($user, false);
}
}