mirror of
https://github.com/nextcloud/server.git
synced 2026-02-19 02:38:40 -05:00
fix(lostpassword): Delete lost password token on password change
Signed-off-by: Carl Schwan <carl.schwan@nextcloud.com>
This commit is contained in:
parent
e2ea6d4680
commit
1d3c3cfb80
4 changed files with 37 additions and 0 deletions
|
|
@ -20,6 +20,7 @@ use OC\Authentication\Notifications\Notifier as AuthenticationNotifier;
|
|||
use OC\Core\Listener\AddMissingIndicesListener;
|
||||
use OC\Core\Listener\AddMissingPrimaryKeyListener;
|
||||
use OC\Core\Listener\BeforeTemplateRenderedListener;
|
||||
use OC\Core\Listener\PasswordUpdatedListener;
|
||||
use OC\Core\Notification\CoreNotifier;
|
||||
use OC\TagManager;
|
||||
use OCP\AppFramework\App;
|
||||
|
|
@ -31,6 +32,7 @@ use OCP\AppFramework\Http\Events\BeforeTemplateRenderedEvent;
|
|||
use OCP\DB\Events\AddMissingIndicesEvent;
|
||||
use OCP\DB\Events\AddMissingPrimaryKeyEvent;
|
||||
use OCP\User\Events\BeforeUserDeletedEvent;
|
||||
use OCP\User\Events\PasswordUpdatedEvent;
|
||||
use OCP\User\Events\UserDeletedEvent;
|
||||
use OCP\Util;
|
||||
|
||||
|
|
@ -75,6 +77,7 @@ class Application extends App implements IBootstrap {
|
|||
$context->registerEventListener(BeforeUserDeletedEvent::class, UserDeletedFilesCleanupListener::class);
|
||||
$context->registerEventListener(UserDeletedEvent::class, UserDeletedFilesCleanupListener::class);
|
||||
$context->registerEventListener(UserDeletedEvent::class, UserDeletedWebAuthnCleanupListener::class);
|
||||
$context->registerEventListener(PasswordUpdatedEvent::class, PasswordUpdatedListener::class);
|
||||
|
||||
// Tags
|
||||
$context->registerEventListener(UserDeletedEvent::class, TagManager::class);
|
||||
|
|
|
|||
32
core/Listener/PasswordUpdatedListener.php
Normal file
32
core/Listener/PasswordUpdatedListener.php
Normal file
|
|
@ -0,0 +1,32 @@
|
|||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
/**
|
||||
* SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors
|
||||
* SPDX-License-Identifier: AGPL-3.0-or-later
|
||||
*/
|
||||
|
||||
namespace OC\Core\Listener;
|
||||
|
||||
use OCP\EventDispatcher\Event;
|
||||
use OCP\EventDispatcher\IEventListener;
|
||||
use OCP\Security\VerificationToken\IVerificationToken;
|
||||
use OCP\User\Events\PasswordUpdatedEvent;
|
||||
|
||||
/**
|
||||
* @template-implements IEventListener<PasswordUpdatedEvent>
|
||||
*/
|
||||
class PasswordUpdatedListener implements IEventListener {
|
||||
public function __construct(
|
||||
readonly private IVerificationToken $verificationToken,
|
||||
) {
|
||||
|
||||
}
|
||||
|
||||
public function handle(Event $event): void {
|
||||
if ($event instanceof PasswordUpdatedEvent) {
|
||||
$this->verificationToken->delete('', $event->getUser(), 'lostpassword');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -1440,6 +1440,7 @@ return array(
|
|||
'OC\\Core\\Listener\\BeforeMessageLoggedEventListener' => $baseDir . '/core/Listener/BeforeMessageLoggedEventListener.php',
|
||||
'OC\\Core\\Listener\\BeforeTemplateRenderedListener' => $baseDir . '/core/Listener/BeforeTemplateRenderedListener.php',
|
||||
'OC\\Core\\Listener\\FeedBackHandler' => $baseDir . '/core/Listener/FeedBackHandler.php',
|
||||
'OC\\Core\\Listener\\PasswordUpdatedListener' => $baseDir . '/core/Listener/PasswordUpdatedListener.php',
|
||||
'OC\\Core\\Middleware\\TwoFactorMiddleware' => $baseDir . '/core/Middleware/TwoFactorMiddleware.php',
|
||||
'OC\\Core\\Migrations\\Version13000Date20170705121758' => $baseDir . '/core/Migrations/Version13000Date20170705121758.php',
|
||||
'OC\\Core\\Migrations\\Version13000Date20170718121200' => $baseDir . '/core/Migrations/Version13000Date20170718121200.php',
|
||||
|
|
|
|||
|
|
@ -1481,6 +1481,7 @@ class ComposerStaticInit749170dad3f5e7f9ca158f5a9f04f6a2
|
|||
'OC\\Core\\Listener\\BeforeMessageLoggedEventListener' => __DIR__ . '/../../..' . '/core/Listener/BeforeMessageLoggedEventListener.php',
|
||||
'OC\\Core\\Listener\\BeforeTemplateRenderedListener' => __DIR__ . '/../../..' . '/core/Listener/BeforeTemplateRenderedListener.php',
|
||||
'OC\\Core\\Listener\\FeedBackHandler' => __DIR__ . '/../../..' . '/core/Listener/FeedBackHandler.php',
|
||||
'OC\\Core\\Listener\\PasswordUpdatedListener' => __DIR__ . '/../../..' . '/core/Listener/PasswordUpdatedListener.php',
|
||||
'OC\\Core\\Middleware\\TwoFactorMiddleware' => __DIR__ . '/../../..' . '/core/Middleware/TwoFactorMiddleware.php',
|
||||
'OC\\Core\\Migrations\\Version13000Date20170705121758' => __DIR__ . '/../../..' . '/core/Migrations/Version13000Date20170705121758.php',
|
||||
'OC\\Core\\Migrations\\Version13000Date20170718121200' => __DIR__ . '/../../..' . '/core/Migrations/Version13000Date20170718121200.php',
|
||||
|
|
|
|||
Loading…
Reference in a new issue