. * * 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\Tools\UserSecurity\Api; use Espo\Core\Api\Action; use Espo\Core\Api\Request; use Espo\Core\Api\Response; use Espo\Core\Api\ResponseComposer; use Espo\Core\Exceptions\BadRequest; use Espo\Entities\User; use Espo\Tools\UserSecurity\Password\Service; use SensitiveParameter; /** * Changes own user password. */ class PutPassword implements Action { public function __construct( private Service $service, private User $user ) {} public function process(#[SensitiveParameter] Request $request): Response { $data = $request->getParsedBody(); $password = $data->password ?? null; $currentPassword = $data->currentPassword ?? null; if ( !is_string($password) || !is_string($currentPassword) ) { throw new BadRequest("No `password` or `currentPassword`."); } $this->service->changePasswordWithCheck($this->user->getId(), $password, $currentPassword); return ResponseComposer::json(true); } }