. * * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU Affero General Public License version 3. * * In accordance with Section 7(b) of the GNU Affero General Public License version 3, * these Appropriate Legal Notices must retain the display of the "EspoCRM" word. ************************************************************************/ namespace Espo\EntryPoints; use Espo\Core\Exceptions\BadRequest; use Espo\Entities\PasswordChangeRequest; use Espo\Core\Utils\Client\ActionRenderer; use Espo\Core\EntryPoint\EntryPoint; use Espo\Core\EntryPoint\Traits\NoAuth; use Espo\Core\Api\Request; use Espo\Core\Api\Response; use Espo\ORM\EntityManager; use Espo\Tools\UserSecurity\Password\ConfigProvider; class ChangePassword implements EntryPoint { use NoAuth; public function __construct( private EntityManager $entityManager, private ActionRenderer $actionRenderer, private ConfigProvider $configProvider, ) {} public function run(Request $request, Response $response): void { $requestId = $request->getQueryParam('id'); if (!$requestId) { throw new BadRequest("No request ID."); } $passwordChangeRequest = $this->entityManager ->getRDBRepository(PasswordChangeRequest::ENTITY_TYPE) ->where([ 'requestId' => $requestId, ]) ->findOne(); $strengthParams = [ 'passwordGenerateLength' => $this->configProvider->getGenerateLength(), 'passwordGenerateLetterCount' => $this->configProvider->getGenerateLetterCount(), 'generateNumberCount' => $this->configProvider->getGenerateNumberCount(), 'passwordStrengthLength' => $this->configProvider->getStrengthLength(), 'passwordStrengthLetterCount' => $this->configProvider->getStrengthLetterCount(), 'passwordStrengthNumberCount' => $this->configProvider->getStrengthNumberCount(), 'passwordStrengthBothCases' => $this->configProvider->getStrengthBothCases(), 'passwordStrengthSpecialCharacterCount' => $this->configProvider->getStrengthSpecialCharacterCount(), ]; $options = [ 'id' => $requestId, 'strengthParams' => $strengthParams, 'notFound' => !$passwordChangeRequest, ]; $params = new ActionRenderer\Params('controllers/password-change-request', 'passwordChange', $options); $this->actionRenderer->write($response, $params); } }