. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Services\UserService; use Fisharebest\Webtrees\Tree; use Fisharebest\Webtrees\User; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use function redirect; use function route; /** * Delete a user account. */ class AccountDelete implements RequestHandlerInterface { /** @var UserService */ private $user_service; /** * AccountController constructor. * * @param UserService $user_service */ public function __construct(UserService $user_service) { $this->user_service = $user_service; } /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function handle(ServerRequestInterface $request): ResponseInterface { $tree = $request->getAttribute('tree'); $user = $request->getAttribute('user'); // An administrator can only be deleted by another administrator if ($user instanceof User && !$user->getPreference('canadmin')) { $this->user_service->delete($user); Auth::logout(); } return redirect(route(AccountEdit::class, ['tree' => $tree instanceof Tree ? $tree->name() : null])); } }