/** * @param string $veranstaltungsreihe_id * @param string $veranstaltung_id * @param int $antrag_id * @param int $aenderungsantrag_id * @param int $kommentar_id */ public function actionAnzeige($veranstaltungsreihe_id = "", $veranstaltung_id, $antrag_id, $aenderungsantrag_id, $kommentar_id = 0) { $aenderungsantrag = $this->getValidatedParamObjects($veranstaltungsreihe_id, $veranstaltung_id, $antrag_id, $aenderungsantrag_id); $this->layout = '//layouts/column2'; if (!$aenderungsantrag) { Yii::app()->user->setFlash("error", "Eine ungültige URL wurde aufgerufen"); $this->redirect($this->createUrl("veranstaltung/veranstaltung")); } $this->performAnzeigeActions($aenderungsantrag, $kommentar_id); $kommentare_offen = array(); if (AntiXSS::isTokenSet("kommentar_schreiben") && $aenderungsantrag->antrag->veranstaltung->darfEroeffnenKommentar()) { $zeile = IntVal($_REQUEST["absatz_nr"]); $person = $_REQUEST["Person"]; $person["typ"] = Person::$TYP_PERSON; if ($aenderungsantrag->antrag->veranstaltung->getEinstellungen()->kommentar_neu_braucht_email && trim($person["email"]) == "") { Yii::app()->user->setFlash("error", "Bitte gib deine E-Mail-Adresse an."); $this->redirect($this->createUrl("aenderungsantrag/anzeige", array("antrag_id" => $aenderungsantrag->antrag_id, "aenderungsantrag_id" => $aenderungsantrag->id))); } $model_person = static::getCurrenPersonOrCreateBySubmitData($person, Person::$STATUS_UNCONFIRMED, false); $kommentar = new AenderungsantragKommentar(); $kommentar->attributes = $_REQUEST["AenderungsantragKommentar"]; $kommentar->absatz = $zeile; $kommentar->datum = new CDbExpression('NOW()'); $kommentar->verfasserIn = $model_person; $kommentar->verfasserIn_id = $model_person->id; $kommentar->aenderungsantrag = $aenderungsantrag; $kommentar->aenderungsantrag_id = $aenderungsantrag_id; $kommentar->status = $this->veranstaltung->getEinstellungen()->freischaltung_kommentare ? IKommentar::$STATUS_NICHT_FREI : IKommentar::$STATUS_FREI; $kommentare_offen[] = $zeile; if ($kommentar->save()) { $add = $this->veranstaltung->getEinstellungen()->freischaltung_kommentare ? " Er wird nach einer kurzen Prüfung freigeschaltet und damit sichtbar." : ""; Yii::app()->user->setFlash("success", "Der Kommentar wurde gespeichert." . $add); if ($this->veranstaltung->admin_email != "" && $kommentar->status == IKommentar::$STATUS_NICHT_FREI) { $kommentar_link = $kommentar->getLink(true); $mails = explode(",", $this->veranstaltung->admin_email); $from_name = veranstaltungsspezifisch_email_from_name($this->veranstaltung); $mail_text = "Es wurde ein neuer Kommentar zum Änderungsantrag \"" . $aenderungsantrag->revision_name . " zu " . $aenderungsantrag->antrag->revision_name . " - " . $aenderungsantrag->antrag->name . "\" verfasst (nur eingeloggt sichtbar):\n" . "Link: " . $kommentar_link; foreach ($mails as $mail) { if (trim($mail) != "") { AntraegeUtils::send_mail_log(EmailLog::$EMAIL_TYP_ANTRAG_BENACHRICHTIGUNG_ADMIN, trim($mail), null, "Neuer Kommentar - bitte freischalten.", $mail_text, $from_name); } } } if ($kommentar->status == IKommentar::$STATUS_FREI) { $benachrichtigt = array(); foreach ($aenderungsantrag->antrag->veranstaltung->veranstaltungsreihe->veranstaltungsreihenAbos as $abo) { if ($abo->kommentare && !in_array($abo->person_id, $benachrichtigt)) { $abo->person->benachrichtigenKommentar($kommentar); $benachrichtigt[] = $abo->person_id; } } } $this->redirect($kommentar->getLink()); } else { foreach ($kommentar->getErrors() as $key => $val) { foreach ($val as $val2) { Yii::app()->user->setFlash("error", "Kommentar konnte nicht angelegt werden: {$key}: {$val2}"); } } foreach ($model_person->getErrors() as $key => $val) { foreach ($val as $val2) { Yii::app()->user->setFlash("error", "Kommentar konnte nicht angelegt werden: {$key}: {$val2}"); } } } } if ($kommentar_id > 0) { if ($aenderungsantrag->kommentar_legacy) { $abs = $aenderungsantrag->getAntragstextParagraphs_flat(); foreach ($abs as $ab) { /** @var AntragAbsatz $ab */ foreach ($ab->kommentare as $komm) { if ($komm->id == $kommentar_id) { $kommentare_offen[] = $ab->absatz_nr; } } } } else { $abs2 = $aenderungsantrag->getAntragstextParagraphs_diff(); foreach ($abs2 as $i => $ab2) { if ($ab2 === null) { continue; } /** @var AenderungsantragAbsatz $ab2 */ foreach ($ab2->kommentare as $komm) { if ($komm->id == $kommentar_id) { $kommentare_offen[] = $i; } } } } } $hiddens = array(); $js_protection = Yii::app()->user->isGuest; if ($js_protection) { $hiddens["form_token"] = AntiXSS::createToken("kommentar_schreiben"); } else { $hiddens[AntiXSS::createToken("kommentar_schreiben")] = "1"; } if (Yii::app()->user->isGuest) { $kommentar_person = new Person(); } else { $kommentar_person = Person::model()->findByAttributes(array("auth" => Yii::app()->user->id)); } $kommentar_person->setEmailRequired($aenderungsantrag->antrag->veranstaltung->getEinstellungen()->kommentar_neu_braucht_email); $support_status = ""; if (!Yii::app()->user->isGuest) { foreach ($aenderungsantrag->aenderungsantragUnterstuetzerInnen as $unt) { if ($unt->person->id == Yii::app()->user->getState("person_id")) { $support_status = $unt->rolle; } } } $anzeige_opts = array("aenderungsantrag" => $aenderungsantrag, "edit_link" => $aenderungsantrag->binInitiatorIn(), "admin_edit" => $this->veranstaltung->isAdminCurUser() ? $this->createUrl("/admin/aenderungsantraege/update", array("id" => $aenderungsantrag_id)) : null, "kommentare_offen" => $kommentare_offen, "kommentar_person" => $kommentar_person, "komm_del_link" => $this->createUrl("aenderungsantrag/anzeige", array("antrag_id" => $antrag_id, "aenderungsantrag_id" => $aenderungsantrag_id, AntiXSS::createToken("komm_del") => "#komm_id#")), "hiddens" => $hiddens, "js_protection" => $js_protection, "support_status" => $support_status, "sprache" => $aenderungsantrag->antrag->veranstaltung->getSprache()); if ($aenderungsantrag->kommentar_legacy) { $this->render("anzeige_legacy", $anzeige_opts); } else { $this->render("anzeige", $anzeige_opts); } }