1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- <?php
-
- declare(strict_types=1);
-
- /**
- * @copyright Copyright (c) 2020, Morris Jobke <hey@morrisjobke.de>
- *
- * @author Joas Schilling <coding@schilljs.com>
- * @author Morris Jobke <hey@morrisjobke.de>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- */
- namespace OCA\Files_External\Listener;
-
- use OCA\Files_External\Lib\Auth\Password\LoginCredentials;
- use OCP\EventDispatcher\Event;
- use OCP\EventDispatcher\IEventListener;
- use OCP\Security\ICredentialsManager;
- use OCP\User\Events\PasswordUpdatedEvent;
- use OCP\User\Events\UserLoggedInEvent;
-
- /** @template-implements IEventListener<PasswordUpdatedEvent|UserLoggedInEvent> */
- class StorePasswordListener implements IEventListener {
- /** @var ICredentialsManager */
- private $credentialsManager;
-
- public function __construct(ICredentialsManager $credentialsManager) {
- $this->credentialsManager = $credentialsManager;
- }
-
- public function handle(Event $event): void {
- if (!$event instanceof UserLoggedInEvent && !$event instanceof PasswordUpdatedEvent) {
- return;
- }
-
- if ($event instanceof UserLoggedInEvent && $event->isTokenLogin()) {
- return;
- }
-
- $storedCredentials = $this->credentialsManager->retrieve($event->getUser()->getUID(), LoginCredentials::CREDENTIALS_IDENTIFIER);
-
- if (!$storedCredentials) {
- return;
- }
-
- $newCredentials = $storedCredentials;
- $shouldUpdate = false;
-
- if (($storedCredentials['password'] ?? null) !== $event->getPassword() && $event->getPassword() !== null) {
- $shouldUpdate = true;
- $newCredentials['password'] = $event->getPassword();
- }
-
- if ($event instanceof UserLoggedInEvent && ($storedCredentials['user'] ?? null) !== $event->getLoginName()) {
- $shouldUpdate = true;
- $newCredentials['user'] = $event->getLoginName();
- }
-
- if ($shouldUpdate) {
- $this->credentialsManager->store($event->getUser()->getUID(), LoginCredentials::CREDENTIALS_IDENTIFIER, $newCredentials);
- }
- }
- }
|