123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- namespace OCA\User_LDAP\Controller;
- use OCP\AppFramework\Controller;
- use OCP\AppFramework\Http\Attribute\NoCSRFRequired;
- use OCP\AppFramework\Http\Attribute\OpenAPI;
- use OCP\AppFramework\Http\Attribute\PublicPage;
- use OCP\AppFramework\Http\Attribute\UseSession;
- use OCP\AppFramework\Http\RedirectResponse;
- use OCP\AppFramework\Http\TemplateResponse;
- use OCP\HintException;
- use OCP\IConfig;
- use OCP\IL10N;
- use OCP\IRequest;
- use OCP\ISession;
- use OCP\IURLGenerator;
- use OCP\IUser;
- use OCP\IUserManager;
- #[OpenAPI(scope: OpenAPI::SCOPE_IGNORE)]
- class RenewPasswordController extends Controller {
- /**
- * @param string $appName
- * @param IRequest $request
- * @param IUserManager $userManager
- * @param IConfig $config
- * @param IURLGenerator $urlGenerator
- */
- public function __construct(
- $appName,
- IRequest $request,
- private IUserManager $userManager,
- private IConfig $config,
- protected IL10N $l10n,
- private ISession $session,
- private IURLGenerator $urlGenerator,
- ) {
- parent::__construct($appName, $request);
- }
- /**
- * @return RedirectResponse
- */
- #[PublicPage]
- #[NoCSRFRequired]
- public function cancel() {
- return new RedirectResponse($this->urlGenerator->linkToRouteAbsolute('core.login.showLoginForm'));
- }
- /**
- * @param string $user
- *
- * @return TemplateResponse|RedirectResponse
- */
- #[PublicPage]
- #[NoCSRFRequired]
- #[UseSession]
- public function showRenewPasswordForm($user) {
- if ($this->config->getUserValue($user, 'user_ldap', 'needsPasswordReset') !== 'true') {
- return new RedirectResponse($this->urlGenerator->linkToRouteAbsolute('core.login.showLoginForm'));
- }
- $parameters = [];
- $renewPasswordMessages = $this->session->get('renewPasswordMessages');
- $errors = [];
- $messages = [];
- if (is_array($renewPasswordMessages)) {
- [$errors, $messages] = $renewPasswordMessages;
- }
- $this->session->remove('renewPasswordMessages');
- foreach ($errors as $value) {
- $parameters[$value] = true;
- }
- $parameters['messages'] = $messages;
- $parameters['user'] = $user;
- $parameters['canResetPassword'] = true;
- $parameters['resetPasswordLink'] = $this->config->getSystemValue('lost_password_link', '');
- if (!$parameters['resetPasswordLink']) {
- $userObj = $this->userManager->get($user);
- if ($userObj instanceof IUser) {
- $parameters['canResetPassword'] = $userObj->canChangePassword();
- }
- }
- $parameters['cancelLink'] = $this->urlGenerator->linkToRouteAbsolute('core.login.showLoginForm');
- return new TemplateResponse(
- $this->appName, 'renewpassword', $parameters, 'guest'
- );
- }
- /**
- * @param string $user
- * @param string $oldPassword
- * @param string $newPassword
- *
- * @return RedirectResponse
- */
- #[PublicPage]
- #[UseSession]
- public function tryRenewPassword($user, $oldPassword, $newPassword) {
- if ($this->config->getUserValue($user, 'user_ldap', 'needsPasswordReset') !== 'true') {
- return new RedirectResponse($this->urlGenerator->linkToRouteAbsolute('core.login.showLoginForm'));
- }
- $args = !is_null($user) ? ['user' => $user] : [];
- $loginResult = $this->userManager->checkPassword($user, $oldPassword);
- if ($loginResult === false) {
- $this->session->set('renewPasswordMessages', [
- ['invalidpassword'], []
- ]);
- return new RedirectResponse($this->urlGenerator->linkToRoute('user_ldap.renewPassword.showRenewPasswordForm', $args));
- }
- try {
- if (!is_null($newPassword) && \OC_User::setPassword($user, $newPassword)) {
- $this->session->set('loginMessages', [
- [], [$this->l10n->t('Please login with the new password')]
- ]);
- $this->config->setUserValue($user, 'user_ldap', 'needsPasswordReset', 'false');
- return new RedirectResponse($this->urlGenerator->linkToRoute('core.login.showLoginForm', $args));
- } else {
- $this->session->set('renewPasswordMessages', [
- ['internalexception'], []
- ]);
- }
- } catch (HintException $e) {
- $this->session->set('renewPasswordMessages', [
- [], [$e->getHint()]
- ]);
- }
- return new RedirectResponse($this->urlGenerator->linkToRoute('user_ldap.renewPassword.showRenewPasswordForm', $args));
- }
- /**
- * @return RedirectResponse
- */
- #[PublicPage]
- #[NoCSRFRequired]
- #[UseSession]
- public function showLoginFormInvalidPassword($user) {
- $args = !is_null($user) ? ['user' => $user] : [];
- $this->session->set('loginMessages', [
- ['invalidpassword'], []
- ]);
- return new RedirectResponse($this->urlGenerator->linkToRoute('core.login.showLoginForm', $args));
- }
- }
|