diff --git a/Web/Presenters/WallPresenter.php b/Web/Presenters/WallPresenter.php index ccb13886..60d083dd 100644 --- a/Web/Presenters/WallPresenter.php +++ b/Web/Presenters/WallPresenter.php @@ -5,6 +5,9 @@ use openvk\Web\Models\Entities\Notifications\{RepostNotification, WallPostNotifi use openvk\Web\Models\Repositories\{Posts, Users, Clubs, Albums}; use Chandler\Database\DatabaseConnection; use Nette\InvalidStateException as ISE; +use Bhaktaraz\RSSGenerator\Item; +use Bhaktaraz\RSSGenerator\Feed; +use Bhaktaraz\RSSGenerator\Channel; final class WallPresenter extends OpenVKPresenter { @@ -52,14 +55,14 @@ final class WallPresenter extends OpenVKPresenter $canPost = $owner->getPrivacyPermission("wall.write", $this->user->identity); else $this->flashFail("err", tr("error"), "Ошибка доступа"); - } else if($user < 0) { + } else if($user < 0) { if($owner->canBeModifiedBy($this->user->identity)) $canPost = true; else $canPost = $owner->canPost(); } else { $canPost = false; - } + } if ($embedded == true) $this->template->_template = "components/wall.xml"; $this->template->oObj = $owner; @@ -82,6 +85,49 @@ final class WallPresenter extends OpenVKPresenter { $this->renderWall($user, true); } + + function renderRSS(int $user): void + { + if(false) + exit("Ошибка доступа: " . (string) random_int(0, 255)); + + $owner = ($user < 0 ? (new Clubs) : (new Users))->get(abs($user)); + if(is_null($this->user)) { + $canPost = false; + } else if($user > 0) { + if(!$owner->isBanned()) + $canPost = $owner->getPrivacyPermission("wall.write", $this->user->identity); + else + $this->flashFail("err", tr("error"), "Ошибка доступа"); + } else if($user < 0) { + if($owner->canBeModifiedBy($this->user->identity)) + $canPost = true; + else + $canPost = $owner->canPost(); + } else { + $canPost = false; + } + + $posts = iterator_to_array($this->posts->getPostsFromUsersWall($user)); + + $feed = new Feed(); + + $channel = new Channel(); + $channel->title(OPENVK_ROOT_CONF['openvk']['appearance']['name'])->url(ovk_scheme(true))->appendTo($feed); + + foreach($posts as $post) { + $item = new Item(); + $item + ->title($post->getOwner()->getCanonicalName()) + ->description($post->getText()) + ->url(ovk_scheme(true)."/wall{$post->getPrettyId()}") + ->pubDate($post->getPublicationTime()->timestamp()) + ->appendTo($channel); + } + + header("Content-Type: application/rss+xml"); + exit($feed); + } function renderFeed(): void { diff --git a/Web/routes.yml b/Web/routes.yml index c8cc0439..65d1df1f 100644 --- a/Web/routes.yml +++ b/Web/routes.yml @@ -105,6 +105,8 @@ routes: hashTag: ".++" - url: "/wall{num}" handler: "Wall->wall" + - url: "/wall{num}/rss" + handler: "Wall->rss" - url: "/wall{num}/makePost" handler: "Wall->makePost" - url: "/wall{num}_{num}" diff --git a/composer.json b/composer.json index 396eea06..7cfa85e7 100644 --- a/composer.json +++ b/composer.json @@ -13,7 +13,8 @@ "lfkeitel/phptotp": "dev-master", "chillerlan/php-qrcode": "dev-main", "vearutop/php-obscene-censor-rus": "dev-master", - "erusev/parsedown": "dev-master" + "erusev/parsedown": "dev-master", + "bhaktaraz/php-rss-generator": "dev-master" }, "minimum-stability": "dev" } diff --git a/composer.lock b/composer.lock index 8ad0ecb4..99071bc9 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "3816f5fbf2c78a3e252637476cd2ae08", + "content-hash": "2c94032cae911ca438bbcfc46c346961", "packages": [ { "name": "al/emoji-detector", @@ -52,6 +52,55 @@ }, "time": "2020-06-26T09:10:17+00:00" }, + { + "name": "bhaktaraz/php-rss-generator", + "version": "dev-master", + "source": { + "type": "git", + "url": "https://github.com/bhaktaraz/php-rss-generator.git", + "reference": "53cf11db18d87e65973e6df453fb8c1382e5a3bd" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/bhaktaraz/php-rss-generator/zipball/53cf11db18d87e65973e6df453fb8c1382e5a3bd", + "reference": "53cf11db18d87e65973e6df453fb8c1382e5a3bd", + "shasum": "" + }, + "require": { + "php": ">=5.3.0" + }, + "default-branch": true, + "type": "library", + "autoload": { + "psr-4": { + "Bhaktaraz\\RSSGenerator\\": "Source/Bhaktaraz/RSSGenerator/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Bhaktaraz Bhatta", + "email": "bhattabhakta@gmail.com" + } + ], + "description": "Simple RSS generator library for PHP 5.5 or later.", + "homepage": "https://github.com/bhaktaraz/php-rss-generator", + "keywords": [ + "Facebook product feed generator", + "feed", + "generator", + "rss", + "writer" + ], + "support": { + "issues": "https://github.com/bhaktaraz/php-rss-generator/issues", + "source": "https://github.com/bhaktaraz/php-rss-generator/tree/master" + }, + "time": "2021-03-15T10:59:47+00:00" + }, { "name": "chillerlan/php-qrcode", "version": "dev-main", @@ -520,12 +569,12 @@ } }, "autoload": { - "psr-4": { - "GuzzleHttp\\Psr7\\": "src/" - }, "files": [ "src/functions_include.php" - ] + ], + "psr-4": { + "GuzzleHttp\\Psr7\\": "src/" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -600,12 +649,12 @@ "source": { "type": "git", "url": "https://github.com/JamesHeinrich/getID3.git", - "reference": "46346ff3bea96a63f1a1d58ee4eabc79471d0ec8" + "reference": "2279f7caca2d761dfc580dd02b401e7a1ff69dfe" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/JamesHeinrich/getID3/zipball/46346ff3bea96a63f1a1d58ee4eabc79471d0ec8", - "reference": "46346ff3bea96a63f1a1d58ee4eabc79471d0ec8", + "url": "https://api.github.com/repos/JamesHeinrich/getID3/zipball/2279f7caca2d761dfc580dd02b401e7a1ff69dfe", + "reference": "2279f7caca2d761dfc580dd02b401e7a1ff69dfe", "shasum": "" }, "require": { @@ -660,7 +709,7 @@ "issues": "https://github.com/JamesHeinrich/getID3/issues", "source": "https://github.com/JamesHeinrich/getID3/tree/master" }, - "time": "2022-01-03T16:59:52+00:00" + "time": "2022-02-03T17:07:51+00:00" }, { "name": "komeiji-satori/curl", @@ -1069,12 +1118,12 @@ } }, "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Intl\\Idn\\": "" - }, "files": [ "bootstrap.php" - ] + ], + "psr-4": { + "Symfony\\Polyfill\\Intl\\Idn\\": "" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -1154,12 +1203,12 @@ } }, "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Intl\\Normalizer\\": "" - }, "files": [ "bootstrap.php" ], + "psr-4": { + "Symfony\\Polyfill\\Intl\\Normalizer\\": "" + }, "classmap": [ "Resources/stubs" ] @@ -1235,12 +1284,12 @@ } }, "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Php72\\": "" - }, "files": [ "bootstrap.php" - ] + ], + "psr-4": { + "Symfony\\Polyfill\\Php72\\": "" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -1512,7 +1561,8 @@ "lfkeitel/phptotp": 20, "chillerlan/php-qrcode": 20, "vearutop/php-obscene-censor-rus": 20, - "erusev/parsedown": 20 + "erusev/parsedown": 20, + "bhaktaraz/php-rss-generator": 20 }, "prefer-stable": false, "prefer-lowest": false,