public function banUser($id) { if (!$this->isAdmin()) { $this->addPopup('danger', 'Pro zakázání přístupu nemáte dostatečná práva.'); redirectTo('/administrace/nahlaseni-uzivatele'); } $user = UserQuery::create()->findPk($id); if ($user == NULL) { $this->addPopup('danger', 'Uživatel se zadaným identifikačním číslem se v databázi nenachází.'); redirectTo('/administrace/nahlaseni-uzivatele'); } $ban = new Ban(); $ban->setReason($_POST["reason"]); $ban->setIdUser($id); $end_date = new DateTime(); $end_date->setTimestamp($end_date->format('U') + $_POST["length"]); $ban->setEndingDate($end_date->format('U')); $ban->setBannedBy($_SESSION["user"]->getId()); $ban->save(); $reports = UserReportQuery::create()->filterByIdUserReported($id)->find(); foreach ($reports as $r) { $r->delete(); } $this->addPopup('success', 'Uživateli ' . $user->getUsername() . ' byl úspěšně zakázán přístup.'); redirectTo('/administrace/nahlaseni-uzivatele'); }