videos = $videos; $this->users = $users; parent::__construct(); } function renderList(int $id): void { $user = $this->users->get($id); if(!$user) $this->notFound(); if(!$user->getPrivacyPermission('videos.read', $this->user->identity ?? NULL) || !$user->canBeViewedBy($this->user->identity)) $this->flashFail("err", tr("forbidden"), tr("forbidden_comment")); $this->template->user = $user; $this->template->videos = $this->videos->getByUser($user, (int) ($this->queryParam("p") ?? 1)); $this->template->count = $this->videos->getUserVideosCount($user); $this->template->paginatorConf = (object) [ "count" => $this->template->count, "page" => (int) ($this->queryParam("p") ?? 1), "amount" => NULL, "perPage" => 7, ]; } function renderView(int $owner, int $vId): void { $user = $this->users->get($owner); if(!$user || $user->isDeleted()) $this->notFound(); $video = $this->videos->getByOwnerAndVID($owner, $vId); if(!$video || $video->isDeleted()) $this->notFound(); if(!$video->canBeViewedBy($this->user->identity)) $this->flashFail("err", tr("forbidden"), tr("forbidden_comment")); $this->template->user = $user; $this->template->video = $video; $this->template->cCount = $this->template->video->getCommentsCount(); $this->template->cPage = (int) ($this->queryParam("p") ?? 1); $this->template->comments = iterator_to_array($this->template->video->getComments($this->template->cPage)); } function renderUpload(): void { $this->assertUserLoggedIn(); $this->willExecuteWriteAction(); if(OPENVK_ROOT_CONF['openvk']['preferences']['videos']['disableUploading']) $this->flashFail("err", tr("error"), "Video uploads are disabled by the system administrator."); if($_SERVER["REQUEST_METHOD"] === "POST") { if(!empty($this->postParam("name"))) { $video = new Video; $video->setOwner($this->user->id); $video->setName(ovk_proc_strtr($this->postParam("name"), 61)); $video->setDescription(ovk_proc_strtr($this->postParam("desc"), 300)); $video->setCreated(time()); try { if(isset($_FILES["blob"]) && file_exists($_FILES["blob"]["tmp_name"])) $video->setFile($_FILES["blob"]); else if(!empty($this->postParam("link"))) $video->setLink($this->postParam("link")); else $this->flashFail("err", "Нету видеозаписи", "Выберите файл или укажите ссылку."); } catch(\DomainException $ex) { $this->flashFail("err", "Произошла ошибка", "Файл повреждён или не содержит видео." ); } catch(ISE $ex) { $this->flashFail("err", "Произошла ошибка", "Возможно, ссылка некорректна."); } $video->save(); $this->redirect("/video" . $video->getPrettyId()); } else { $this->flashFail("err", "Произошла ошибка", "Видео не может быть опубликовано без названия."); } } } function renderEdit(int $owner, int $vId): void { $this->assertUserLoggedIn(); $this->willExecuteWriteAction(); $video = $this->videos->getByOwnerAndVID($owner, $vId); if(!$video) $this->notFound(); if(is_null($this->user) || $this->user->id !== $owner) $this->flashFail("err", "Ошибка доступа", "Вы не имеете права редактировать этот ресурс."); if($_SERVER["REQUEST_METHOD"] === "POST") { $video->setName(empty($this->postParam("name")) ? NULL : $this->postParam("name")); $video->setDescription(empty($this->postParam("desc")) ? NULL : $this->postParam("desc")); $video->save(); $this->flash("succ", "Изменения сохранены", "Обновлённое описание появится на странице с видосиком."); $this->redirect("/video" . $video->getPrettyId()); } $this->template->video = $video; } function renderRemove(int $owner, int $vid): void { $this->assertUserLoggedIn(); $this->willExecuteWriteAction(); $video = $this->videos->getByOwnerAndVID($owner, $vid); if(!$video) $this->notFound(); $user = $this->user->id; if(!is_null($user)) { if($video->getOwnerVideo() == $user) { $video->deleteVideo($owner, $vid); } } else { $this->flashFail("err", "Не удалось удалить пост", "Вы не вошли в аккаунт."); } $this->redirect("/videos" . $owner); } }