Generating RSS Feed for opened or closed wall of user or community (group, public page or event page) on vk.com
- Generating RSS feed of opened wall: data extraction from different post parts (attachments included) and automatic title generation of RSS items.
- Also generating RSS feed of closed wall if there's access token with offline permissions that's created by user who has access to the closed wall. See more here about user access token creating.
- Generating RSS feed for different opened walls based on global search results.
- Generating RSS news feed of access token's owner.
- Feeding arbitrary number of posts.
- Posts filtering by author: all posts, posts by community/profile owner only or all posts except posts by community/profile owner.
- Posts filtering by signature presence.
- Posts filtering by regular expression (PCRE notation) matching and/or mismatching.
- Optionally ad posts skipping [disabled by default].
- Extracting RSS categories from the post hash tags.
- Optionally HTML formatting of RSS item description: links, images, line breaks [enabled by default].
- HTTPS, SOCKS4, SOCKS4A or SOCKS5 proxy usage is available.
- Each feed item has author name (post signer/publisher or source post signer/publisher if wall post is the repost).
- Customizable repost delimiter with substitutions.
- Optionally video embedding as iframe [disabled by default] in the default HTML mode.
- Optionally VK Donut posts including [disabled by default].
- PHP>=5.3 (5.4.X, 5.5.X, 5.6.X, 7.X, 8.X are included)
with installed
mbstring
,json
,pcre
,openssl
bundled extensions. - Script prefers the built-in tools for the requests.
If
allow_url_fopen
parameter is disabled in the PHP configuration file or interpreter parameters andcURL
PHP extension is installed then script usescURL
for the requests. - If you want to use proxy server then
- for HTTPS proxy: either
cURL
>=7.10 extension must be installed orallow_url_fopen
parameter must be enabled in the PHP configuration file or interpreter parameters; - for SOCKS5 proxy:
cURL
>=7.10 extension must be installed; - for SOCKS4 proxy: PHP>=5.3 with
cURL
>=7.10 extension is required; - for SOCKS4A proxy: PHP>=5.5.23 or PHP>=5.6.7 (7.X included)
with
cURL
>=7.18 extension is required.
- for HTTPS proxy: either
- You should own a (sub)domain and point A record to IP-address of the server the repository should run on.
If script returns page with non-200 HTTP status then some problem was occurred:
detailed problem information is described in the HTTP status phrase,
in the script output and in the server/interpreter logfile.
To look at PHP server last 50 records in logs, you can try the command:
docker compose logs -t -n 50 php
- Clone the repo:
git clone [email protected]:Kenya-West/vkrss.git
; - Fill
.env
file with the content from.env.example
or paste the following:
DOMAIN= # Your domain
EMAIL= # E-mail that was set with your domain
FEED_PORT_HTTP=8081 # Port to access Feed server without SSL (CAUTION: this is not secure! Use only for testing purposes!)
FEED_PORT_HTTPS=443 # Port to access Feed server with SSL
FEED_PATH=api/vkrss # Subpath to access Feed server. Without leading "/" slash. Leave empty by default
VKRSS_PORT=9900 # Port to access VKRSS server through NGINX (it adds access token)
VKRSS_ACCESS_TOKEN=vkrssaccesstoken # Access token to access VKRSS server (NGINX). It's used to protect VKRSS server from unauthorized access
VK_ACCESS_TOKEN= # Access token to access VK API. You can get it from VK API settings
- Launch certbot to get SSL certificates:
docker compose up -d certbot
In logs available by docker compose logs certbot
command, you should see something like this:
- After successful certificates installation, un-comment those lines with
###
characters insidetemplates/default.conf.template
bynano
orvi
/vim
editors, or by executing command:
sed -i 's/### //' templates/default.conf.template
- Restart NGINX:
docker compose restart webserver
- Launch the rest:
docker compose up -d php webserver
- PHP server is available at
9900
port, NGINX is on8081
for HTTP and8082
for HTTPS respectively. These are default values, if otherwise not set in.env
.
Main index.php
script accepts the below GET-parameters.
id
and access_token
OR global_search
and access_token
OR news_feed
and access_token
parameters are required, another parameters are optional.
id
, global_search
and news_feed
parameters cannot be used together.
-
[conditionally required]
id
is short name, ID number (community ID is started with-
sign) or full identifier (like idXXXX, clubXXXX, publicXXXX, eventXXXX) of profile or community. Only its single wall is processed. Examples of a valid values:123456
,id123456
— both of these values identify the user profile with ID 123456,-123456
,club123456
— both of these values identify the group with ID 123456,-123456
,public123456
— both of these values identify the public page with ID 123456,-123456
,event123456
— both of these values identify the event with ID 123456,apiclub
— value identifies the user profile or community with this short name.
Deprecated
domain
andowner_id
parameters are allowed and they're identical toid
. -
[conditionally required]
global_search
is an arbitrary text search query to lookup on all opened walls. It uses internal VK algorithms to search posts that're published by wall's owner. Search results are the same as on this search page. -
[conditionally required]
news_type
takes one of the values eitherrecent
(recent news) orrecommended
(VK recommended news). It generates an RSS news feed of the access token's owner that's shown on this news page.News feed contains a walls posts only, the rest of news are ignored (such as new friends of friends, new photos in friends' profiles and so on).
This parameter requires a user' access token with
wall
andfriends
permissions. -
-
either service token that's specified in the app settings (you can create your own standalone application here, app can be off)
Service token allows to fetch only opened for everyone walls.
-
or user access token with
offline
and optionallyvideo
permissionsIf you uses
id
parameter then user access token allows to fetch both opened and closed walls that are opened for this user.Warning: If user terminates all sessions in the security settings of profile then him access token becomes invalid; in that case, user must create new access token.
If you uses
global_search
then service and user access tokens give equivalent results, i.e. only opened walls is processed. -
-
count
is a number of processing posts starting with the latest published post. It's arbitrary amount including more than 100.Default value: 20.
If
owner_only
,non_owner_only
,include
,exclude
orskip_ads
parameters are passed then amount of posts in the result RSS feed can be less thancount
because some post can be skipped by these parameters.If
donut
is passed then amount of posts in the result RSS feed can be at most2*count
(count
VK Donut posts +count
regular posts).If
id
is passed thencount
is unlimited, but API requests number can be no more than 5000 requests per day and each request can fetch no more than 100 posts.If
global_search
is passed then maximum value ofcount
is 1000, API requests number can be no more than 1000 requests per day, and each request can fetch no more than 200 posts.Delay between requests is equal to 1 sec in order to satisfy VK API limits (no more than 3 requests per second).
-
repost_delimiter
is a string that's placed between parent and child posts; in other words, it's a header of a child post in the repost.Default value is
<hr><hr>
if HTML formatting is enabled (default behaviour), otherwise______________________
(disable_html
parameter).This parameter can contain the next special strings that will be substituted in the RSS feed:
{author}
that's replaced with first and last names of child post' author in the nominative case if author is a user, otherwise it's replaced with community name in the nominative that's published child post.{author_ins}
that's replaced with first and last names of child post' author in the instrumental case if author is a user, otherwise it's replaced with community name in the nominative that's published child post{author_gen}
that's replaced with first and last names of child post' author in the genitive case if author is a user, otherwise it's replaced with community name in the nominative that's published child post
Author is child post' signer if it exists, otherwise it's child post' publisher.
E.g., parameter value
<hr>Written by {author}
is replaced with:<hr>Written by John Smith
if author is user and publisher of child post,<hr>Written by Fun Club
if author is community,<hr>Written by John Smith in Fun Club
if author is user and signer of child post.
Additionally substitutions adds links to user/community pages that're represented as either HTML hyperlinks on author name or plain text in the brackets (if
disable_html
is enabled). -
donut
passing (including absent value) indicates that RSS contains donut posts (VK Donut subscription) at the beginning, followed by regular posts. Total amount of posts in the RSS feed can be at most2*count
posts (count
donut posts +count
regular posts) if they exist.If an API Error 15 occurs by this parameter usage, it means that:
- either user (whose
access_token
is used) has not subscribed to VK Donut of community withid
, - or community has not enabled VK Donut feature,
- or
id
belongs to some user instead of community.
- either user (whose
-
include
is case-insensitive regular expression (PCRE notation) that must match the post text. Another posts will be skipped.Symbol
/
is not required at the start and at the end of regular expression. -
exclude
is case-insensitive regular expression (PCRE notation) that must not match the post text. Another posts will be skipped.Symbol
/
is not required at the start and at the end of regular expression. -
disable_html
passing (including absent value) indicates that RSS item descriptions must be without HTML formatting.By default HTML formatting is applied for links and images.
-
disable_comments_amount
passing (including absent value) indicates that RSS item must be without amount of comments (<slash:comments>
).By default feed item contains number of comments.
-
owner_only
passing (including absent value) indicates that RSS must contain only posts that's-
published by community in the case of community wall;
If
allow_signed
parameter withfalse
value is also passed then posts with signature (that's published by community) will be skipped. -
published by profile owner in the case of user wall.
By default [absent parameter] RSS feed contains all posts that passes another filters.
-
-
non_owner_only
ornot_owner_only
passing (including absent value) indicates that RSS must contain only posts that's-
not published by community in the case of community wall, i.e. published by users.
If
allow_signed
parameter withtrue
or absent value is also passed then posts with signature (that's published by community) will be included to the RSS feed. -
not published by profile owner in the case of user wall, i.e. published by another users.
By default [absent parameter] RSS feed contains all posts that passes another filters.
-
-
allow_signed
allows or disallows posts (that's published by community) with signature whenowner_only
ornon_owner_only
/not_owner_only
parameter is passed.By default [absent parameter] RSS feed contains all posts that passes another filters.
Allowed values: [absent value] (same as
true
),true
,false
,0
(same asfalse
),1
(same astrue
). Another values are interpreted astrue
.- If
owner_only
is passed thenallow_signed
withfalse
value doesn't include posts with signature to the RSS feed. - If
non_owner_only
ornot_owner_only
is passed thenallow_signed
withtrue
value includes posts with signature to the RSS feed.
- If
-
skip_ads
passing indicates that all marked as ad posts will be skipped.By default [absent parameter] RSS feed contains all posts that passes another filters.
Note: Some wall posts that're marked as ad on the website, VK API doesn't mark as ad, therefore some ad posts can be in the RSS feed.
-
allow_embedded_video
allows or disallows video player embedding (as iframe) into the posts' description.By default [absent parameter] it is disabled.
When it's enabled, script tries to get video player link but if the
access_token
does not have thevideo
permission then this parameter turn intofalse
forcibly.If script can get video player link then videos are playable in the HTML mode, otherwise videos are displayed as either clickable image preview (HTML is enabled) or text (HTML is disabled).
-
proxy
is proxy server address. Allowed value formats:address
,address:port
,type://address
,type://address:port
,login:password@address
,login:password@address:port
,type://login:password@address
,type://login:password@address:port
,
where
address
is proxy domain or IP-address,port
is proxy port,type
is proxy type (HTTPS, SOCKS4, SOCKS4A, SOCKS5),login
andpassword
are login and password for proxy access if it's necessary.Proxy type, login and password can be passed through another parameters:
proxy_type
,proxy_login
andproxy_password
respectively.
PHP is launched on its default port 9900
, the NGINX server is live on ports 8081
for HTTP and 8082
for HTTPS, respectively.
The NGINX server main purpose is to save the user from having to explicitly specify the access_token
(a VK standalone application's) for the case lost or changed. IF NGINX server is not used and something happens with access_token
, all links to subscriptions in the RSS service/RSS client will have to be changed. This is inconvenient, that is why NGINX server exists.
Instead of access_token
, this server accepts vkrss_access_token
, defined in the .env
file under the line VKRSS_ACCESS_TOKEN
. Default value: vkrssaccesstoken
.
After receiving the request, the NGINX server redirects it to the PHP server with the access_token
(defined in the .env
file under the line VK_ACCESS_TOKEN
) and receives the VK feed.
The NGINX server will also be accessible along the path defined in the .env
file under the FEED_PATH
line. Default value: api/vkrss
.
So, for example, these two queries are similar:
index.php?id=club1&access_token=XXXXXXXXX
And
api/vkrss/index.php?id=club1&vkrss_access_token=YYYYYYYYYY
This authorization flow is preferred getting user access token for the server side access to the walls.
-
Create your own standalone application here. Created app can be off after token generation because it does not matter for the API requests.
IMPORTANT NOTE: currently, newly created apps require passport' data or organisation' data in the developer' dashboard in order to generate access tokens with required permissions.
However, old apps still provide the ability to generate access tokens with required permissions.
-
Authorize necessary account on vk.com and go to the next URL
https://oauth.vk.com/authorize?client_id=APP_ID&scope=offline,video,wall,friends&redirect_uri=https%3A%2F%2Foauth.vk.com%2Fblank.html&display=page&response_type=token&revoke=1
where replace
APP_ID
with application ID that's specified in the app settings.The listed permissions in the
scope
parameter are as the follows:offline
is required to get endless access token;video
is only required for theallow_embedded_video
option;wall
andfriends
are only required for thenews_type
option.
Therefore, if you do not want to use some features then the relevant permissions can be omitted.
-
Confirm permissions. The result URL in the address bar contains sought-for access token after the
access_token=
string.
Bonus: created app keeps API calls statistics, so you can see it.
Warning: If user terminates all sessions in him security settings then all him access tokens becomes invalid; in that case, user must create new access token by repeating steps 2-4.
index.php?id=apiclub&access_token=XXXXXXXXX
index.php?id=-1&access_token=XXXXXXXXX
index.php?id=id1&access_token=XXXXXXXXX
index.php?id=club1&access_token=XXXXXXXXX
index.php?id=club1&disable_html&access_token=XXXXXXXXX # no HTML formatting in RSS item descriptions
index.php?id=apiclub&count=100&include=newsfeed&access_token=XXXXXXXXX # feed contains only posts with substring 'newsfeed'
index.php?id=apiclub&count=100&exclude=newsfeed&access_token=XXXXXXXXX # feed contains only posts without substring 'newsfeed'
index.php?id=apiclub&proxy=localhost:8080&access_token=XXXXXXXXX
index.php?id=apiclub&proxy=localhost:8080&proxy_type=https&access_token=XXXXXXXXX
index.php?id=apiclub&proxy=https%3A%2F%2Flocalhost:8080&access_token=XXXXXXXXX
index.php?id=club1&owner_only&access_token=XXXXXXXXX # feed contains only posts by community
index.php?id=club1&owner_only&allow_signed=false&access_token=XXXXXXXXX # feed contains only posts by community
# that's without signature
index.php?id=club1&non_owner_only&access_token=XXXXXXXXX # feed contains only posts by users
index.php?id=club1&non_owner_only&allow_signed&access_token=XXXXXXXXX # feed contains only posts by users
# and community posts with signature
index.php?id=club1&allow_embedded_video&access_token=XXXXXXXXX # embed playable videos into RSS items' description
index.php?id=-1&count=30&repost_delimiter=<hr><hr>Written by {author}:&access_token=XXXXXXXXX
index.php?id=pitertransport&donut&access_token=XXXXXXXXX # RSs feed contains VK Donut posts and regular posts
index.php?news_type=recent&count=25&access_token=XXXXXXXXX # 25 recent posts of the news feed
index.php?news_type=recommended&count=30&access_token=XXXXXXXXX # 30 VK recommended posts of the news feed
index.php?global_search=query&count=300&access_token=XXXXXXXXX # search posts that contains 'query'
index.php?id=-1&count=100&include=(new|wall|\d+)&access_token=XXXXXXXXX
or the same for Caddy server:
api/vkrss/index.php?id=apiclub&access_token=XXXXXXXXX
api/vkrss/index.php?id=-1&access_token=XXXXXXXXX
api/vkrss/index.php?id=id1&access_token=XXXXXXXXX
api/vkrss/index.php?id=club1&access_token=XXXXXXXXX
api/vkrss/index.php?id=club1&disable_html&access_token=XXXXXXXXX # no HTML formatting in RSS item descriptions
api/vkrss/index.php?id=apiclub&count=100&include=newsfeed&access_token=XXXXXXXXX # feed contains only posts with substring 'newsfeed'
api/vkrss/index.php?id=apiclub&count=100&exclude=newsfeed&access_token=XXXXXXXXX # feed contains only posts without substring 'newsfeed'
api/vkrss/index.php?id=apiclub&proxy=localhost:8080&access_token=XXXXXXXXX
api/vkrss/index.php?id=apiclub&proxy=localhost:8080&proxy_type=https&access_token=XXXXXXXXX
api/vkrss/index.php?id=apiclub&proxy=https%3A%2F%2Flocalhost:8080&access_token=XXXXXXXXX
api/vkrss/index.php?id=club1&owner_only&access_token=XXXXXXXXX # feed contains only posts by community
api/vkrss/index.php?id=club1&owner_only&allow_signed=false&access_token=XXXXXXXXX # feed contains only posts by community
# that's without signature
api/vkrss/index.php?id=club1&non_owner_only&access_token=XXXXXXXXX # feed contains only posts by users
api/vkrss/index.php?id=club1&non_owner_only&allow_signed&access_token=XXXXXXXXX # feed contains only posts by users
# and community posts with signature
api/vkrss/index.php?id=club1&allow_embedded_video&access_token=XXXXXXXXX # embed playable videos into RSS items' description
api/vkrss/index.php?id=-1&count=30&repost_delimiter=<hr><hr>Written by {author}:&access_token=XXXXXXXXX
api/vkrss/index.php?id=pitertransport&donut&access_token=XXXXXXXXX # RSs feed contains VK Donut posts and regular posts
api/vkrss/index.php?news_type=recent&count=25&access_token=XXXXXXXXX # 25 recent posts of the news feed
api/vkrss/index.php?news_type=recommended&count=30&access_token=XXXXXXXXX # 30 VK recommended posts of the news feed
api/vkrss/index.php?global_search=query&count=300&access_token=XXXXXXXXX # search posts that contains 'query'
api/vkrss/index.php?id=-1&count=100&include=(new|wall|\d+)&access_token=XXXXXXXXX
Note: one parameter contains special characters in the two last examples,
so URL-encoding can be required for the direct call, e.g.:
index.php?id=-1&count=100&include=(new%7Cwall%7C%5Cd%2B)&access_token=XXXXXXXXX
-
If you get error:
date(): It is not safe to rely on the system's timezone settings. You are required to use the date.timezone setting or the date_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected the timezone 'UTC' for now, but please set date.timezone to select your timezone.
then set timezone in php configuration (
date.timezone
parameter) or add line likedate_default_timezone_set('UTC');
to the start of theindex.php
script (beforerequire_once
statement). -
If your RSS aggregator marks post as new/updated when number of its comments is changed then you can disable comments counter for each RSS item using GET-parameter
disable_comments_amount
:index.php?id=-1&disable_comments_amount
orindex.php?id=-1&disable_comments_amount=1
-
If an API Error 15 occurs by
donut
parameter usage, it means that:- either user (whose
access_token
is used) has not subscribed to VK Donut of community withid
, - or community has not enabled VK Donut feature,
- or
id
belongs to some user instead of community.
- either user (whose
Генерация RSS-ленты открытой или закрытой стены пользователя или сообщества (группы, публичной страницы или мероприятия) во Вконтакте.
- Получение RSS-ленты открытой стены: извлечение описания из разных частей (включая вложения) и построение заголовков на основе описания.
- Также получение RSS-ленты закрытой стены при наличии токена с правами оффлайн-доступа, привязанного к профилю, которому открыт доступ к такой стене. Ниже описан один из способов получения токена.
- Получение RSS-ленты, содержащей записи с различных открытых стен, которые соответствуют глобальному поисковому запросу.
- Получение RSS-ленты новостей владельца токена.
- Получение произвольного количества записей со стены.
- Получение записей, опубликованных от кого угодно, от имени сообщества/владельца страницы или ото всех, кроме сообщества/владельца страницы.
- Фильтрация записей по наличию или отсутствию подписи.
- Фильтрация записей по соответствию и/или несоответствию регулярному выражению в стиле PCRE.
- При желании исключение записей в сообществе, помеченных как реклама [по умолчанию отключено].
- Извлечение хеш-тегов в качестве RSS-категорий.
- При желании HTML-форматирование всех видов ссылок, изображений, переносов строк [по умолчанию включено].
- Допустимо использование HTTPS, SOCKS4, SOCKS4A или SOCKS5 прокси-сервера для запросов.
- У каждой записи в ленте указан автор (либо тот, кто подписан или опубликовал запись, либо тот, кто подписан или опубликовал исходную запись, если конечная запись является репостом исходной).
- Возможность задать свой собственный разделитель с подстановками между родительским и дочерним записями (репосты).
- При желании встраивание видеозаписей в описание RSS записей с помощью iframe (по умолчанию отключено) при по умолчанию включенном HTML режиме.
- При желании можно включить записи для донов в RSS-ленту (по умолчанию отключено).
- PHP>=5.3 (в т.ч. 5.4.X, 5.5.X, 5.6.X, 7.X, 8.X) с установленными
по умолчанию поставляемыми расширениями
mbstring
,json
,pcre
,openssl
. - Скрипт предпочитает использовать встроенные в PHP возможности по отправке запросов.
Если у PHP отключена встроенная возможность загрузки файлов по URL
(отключен параметр
allow_url_fopen
в конфигурации или параметрах интерпретатора), но при этом у PHP установлено расширениеcURL
, то именно оно будет использоваться для загрузки данных. - Если необходимо использовать прокси-сервер, то в случае
- HTTPS-прокси — либо необходимо расширение
cURL
>=7.10, либо в конфигурационном файле или параметрах интерпретатора PHP должен быть включён параметрallow_url_fopen
, - SOCKS5-прокси — необходимо расширение
cURL
>=7.10, - SOCKS4-прокси — необходим PHP>=5.3 с расширением
cURL
>=7.10, - SOCKS4A-прокси — необходим PHP>=5.5.23 или PHP>=5.6.7 (включая 7.X) с расширением
cURL
>=7.18.
- HTTPS-прокси — либо необходимо расширение
- Свой (под)домен и A-запись на IP-адрес сервера, в котором будет запущен данный репозиторий.
В случае каких-либо проблем вместо RSS-ленты выдается страница с HTTP-статусом,
отличным от 200, и с описанием проблемы в HTTP-заголовке и теле страницы,
а также создаётся запись в журнале ошибок сервера или интерпретатора.
Посмотреть логи PHP-сервера можно будет командой (последние 50 записей):
docker compose logs -t -n 50 php
- Клонируйте репозиторий:
git clone [email protected]:Kenya-West/vkrss.git
; - Заполните файл
.env
контентом из.env.example
или вставьте из этого блока кода:
DOMAIN= # Your domain
EMAIL= # E-mail that was set with your domain
FEED_PORT_HTTP=8081 # Port to access Feed server without SSL (CAUTION: this is not secure! Use only for testing purposes!)
FEED_PORT_HTTPS=443 # Port to access Feed server with SSL
FEED_PATH=api/vkrss # Subpath to access Feed server. Without leading "/" slash. Leave empty by default
VKRSS_PORT=9900 # Port to access VKRSS server through NGINX (it adds access token)
VKRSS_ACCESS_TOKEN=vkrssaccesstoken # Access token to access VKRSS server (NGINX). It's used to protect VKRSS server from unauthorized access
VK_ACCESS_TOKEN= # Access token to access VK API. You can get it from VK API settings
- Запустите certbot для получения SSL-сертификатов:
docker compose up -d certbot webserver
В логах по команде docker compose logs certbot
должно быть сообщение об успешном получении сертификатов:
- После успешной установки сертификатов раскомментируйте строки, начинающиеся с тройных
###
в файлеtemplates/default.conf.template
редакторомnano
илиvi
/vim
, либо командой:
sed -i 's/### //' templates/default.conf.template
- Перезапустите NGINX:
docker compose restart webserver
- Запустите остальное:
docker compose up -d php
- По умолчанию сервер PHP доступен на порте
9900
, сервер NGINX на8081
для HTTP и8082
для HTTPS, если вы не указали иное в файле.env
.
Основной скрипт index.php
принимает следующие GET-параметры.
Пара параметров id
и access_token
ИЛИ global_search
и access_token
ИЛИ news_type
и access_token
обязательна, остальные параметры необязательны.
Одновременно можно использовать только один из параметров
id
, global_search
или news_type
.
-
[условно обязательный]
id
— короткое название, ID-номер (в случае сообщества ID начинается со знака-
) или полный идентификатор человека/сообщества (в виде idXXXX, clubXXXX, publicXXXX, eventXXXX), для стены которого будет строиться RSS-лента. Примеры допустимых значений параметраid
:123456
,id123456
— оба значения указывают на одну и ту же страницу пользователя с ID 123456,-123456
,club123456
— оба значения указывают на одну и ту же группу с ID 123456,-123456
,public123456
— оба значения указывают на одну и ту же публичную страницу с ID 123456,-123456
,event123456
— оба значения указывают на одну и ту же страницу мероприятия с ID 123456,apiclub
— значение указывает на пользователя или сообщество с данным коротким названием.
Ради обратной совместимости допускается вместо
id
использоватьdomain
илиowner_id
. -
[условно обязательный]
global_search
— произвольный текстовый глобальный поисковый запрос, по которому с помощью внутренних алгоритмов ВКонтакте ищутся записи со всех открытых стен, опубликованные владельцем профиля пользователя или от имени сообщества. Результаты поиска аналогичны результатам на этой поисковой странице. -
[условно обязательный]
news_type
— тип новостной ленты владельца ключа доступа: значение либоrecent
(последние новости), либоrecommended
(рекомендуемые новости) — новости, которые отображаются на странице новостей и только те, что являются записями на чьей-либо стене (все прочие новости, такие как новые друзья друзей, новые фотографии в профилях друзей и т.п., будут проигнорированы).Для использования этого параметра у ключа доступа пользователя обязательно наличие прав
wall
иfriends
. -
-
Либо сервисный ключ доступа, который указан в настройках приложения (создать собственное standalone-приложение можно по этой ссылке, само приложение может быть выключено).
Сервисный ключ доступа дает возможность получать записи только с открытых для всех стен.
-
Либо ключ доступа пользователя с правами оффлайн-доступа и опционально видео-доступа.
При использовании параметра
id
ключ доступа пользователя позволяет получать записи как с открытых, так и закрытых стен (но открытых для пользователя, который создал токен).Предупреждение: если в настройках безопасности пользователя будут завершены все сессии, то ключ доступа пользователя станет невалидным — нужно сформировать ключ заново.
Если используется параметр
global_search
, тогда генерируемые RSS-ленты при использовании сервисного ключа доступа и при использовании ключа доступа пользователя одинаковы, т.е. в любом случае все записи будут лишь с открытых стен. -
-
count
— количество обрабатываемых записей, начиная с последней опубликованной (произвольное количество, включая более 100, по умолчанию 20).Если дополнительно установлены параметры
owner_only
,non_owner_only
,include
,exclude
илиskip_ads
, то количество выводимых в RSS-ленте записей может быть меньше значенияcount
за счет исключения записей, которые отсеиваются этими параметрами.Если передан параметр
donut
, то RSS-лента может содержать до2*count
записей (максимумcount
записей для донов плюс максимумcount
обычных записей).Если передан параметр
id
, то значениеcount
неограниченно, но VK API позволяет делать не более 5000 запросов в сутки, а каждый запрос может получить не более 100 записей.Если передан параметр
global_search
, то значениеcount
не может быть больше 1000, при этом VK API позволяет делать не более 1000 запросов в сутки, каждый из которых может извлечь не более 200 записей.Между запросами задержка минимум в 1 секунду, чтобы не превышать ограничения VK API (не более 3 запросов в секунду).
-
repost_delimiter
— разделитель между родительской и дочерней записью (когда профиль/сообщество [«родитель»] поделилось записью от другого профиля/сообщества [«ребенок»]), иными словами, заголовок дочерней записи.По умолчанию разделителем служит
<hr><hr>
в случае по умолчанию включенного HTML-форматирования и______________________
в случае отключенного HTML-форматирования (параметрdisable_html
):В качестве значения параметра может быть передана любая строка. Допустимо использование специальных подстановок:
{author}
— в RSS ленте заменяется на автора дочерней записи в именительном падеже.{author_gen}
— заменяется на автора дочерней записи в родительном падеже в случае, если этот автор является пользователем, а если автор — сообщество, то заменяется на название сообщества без морфологических изменений.{author_ins}
— заменяется на автора дочерней записи в творительном падеже в случае, если этот автор является пользователем, а если автор — сообщество, то заменяется на название сообщества без морфологических изменений.
Под автором записи понимается в первую очередь подписанный автор, а если такового нет, то публикатор записи.
Примеры значений параметра:
{author} пишет:
— в случае автора-пользователя подставится, например,Иван Иванов пишет:
, а в случае автора-сообщества, например,ВКонтакте API пишет:
<hr>Опубликовано {author_ins}:
— в случае автора-пользователя подставится, например,Опубликовано Иваном Ивановым:
, а в случае автора-сообщества, например,Опубликовано ВКонтакте API:
Запись {author_gen}:
— в случае автора-пользователя подставится, например,Запись Ивана Иванова:
, а в случае автора-сообщества, например,Запись ВКонтакте API:
<hr>Написано {author_ins}:
— в случае автора-пользователя подставится, например,<hr>Написано Иваном Ивановым:
, а в случае автора-сообщества, например,<hr>Написано ВКонтакте API:
. Если же запись опубликована в сообществе, но при этом подписана автором, то подстановка станет наподобие такой:<hr>Написано Иваном Ивановым в сообществе ВКонтакте API:
(аналогично будет в предыдущих примерах)
В указанных примерах в результатах подстановки еще подставляются либо HTML-форматированные ссылки на пользователя/сообщество, либо эти же же ссылки в виде простого текста в случае отключенного HTML-форматирования (параметр
disable_html
). -
donut
— если передан (можно без значения), то в RSS-ленту будут добавлены записи для донов (по подключенной подписке VK Donut). При включении в RSS-ленте в первую очередь выводятся записи для донов, а после них обычные записи. Суммарное количество записей в RSS-ленте может достигать2*count
(count
записей для донов +count
обычных записей), если столько записей существует и они не фильтруются другими параметрами скрипта.Если при использовании этого параметра в результате появляется ошибка API Error 15, то это значит, что:
- либо у пользователя, чей ключ доступа использован, не оформлена подписка на VK Donut сообщества
(стоит удостовериться, что в качестве
access_token
используется именно ключ доступа пользователя, у которого есть подписка VK Donut на сообщество с вернымid
); - либо у сообщества отключен VK Donut;
- либо RSS-лента генерируется для стены пользователя, а не сообщества.
- либо у пользователя, чей ключ доступа использован, не оформлена подписка на VK Donut сообщества
(стоит удостовериться, что в качестве
-
include
— регистронезависимое регулярное выражение в стиле PCRE, которое должно соответствовать тексту записи. Остальные записи будут пропущены.В начале и в конце выражения символ
/
не нужен. -
exclude
— регистронезависимое регулярное выражение в стиле PCRE, которое не должно соответствовать тексту записи. Остальные записи будут пропущены.В начале и в конце выражения символ
/
не нужен. -
disable_html
— если передан (можно без значения), то описание каждой записи не будет содержать никаких HTML тегов.По умолчанию (отсутствие
disable_html
) описание может включать HTML-теги для создания гиперссылок и вставки изображений. -
disable_comments_amount
— если передан (можно без значения), то в RSS-ленте не будет счетчика комментариев у каждой записи (<slash:comments>
).По умолчанию у каждой записи указано текущее количество комментариев.
-
owner_only
— если передан (можно без значения), то в RSS-ленту выводятся лишь те записи, которые-
в случае стены сообщества опубликованы от имени сообщества;
если в этом случае дополнительно передан параметр
allow_signed=false
, то не будут выводиться подписанные записи, опубликованные от имени сообщества. -
в случае стены пользователя опубликованы самим этим пользователем.
По умолчанию (отсутствие параметра) выводятся записи ото всех, если они не фильтруются другими параметрами.
-
-
non_owner_only
илиnot_owner_only
— если передан любой из них (можно без значения), то в RSS-ленту выводятся лишь те записи, которые-
в случае стены сообщества опубликованы не от имени сообщества, а пользователями;
если в этом случае дополнительно передан параметр
allow_signed
с отсутствующим значением или со значениеtrue
, то еще будут выводиться подписанные записи, опубликованные от имени сообщества; -
в случае стены пользователя опубликованы не самим этим пользователем, а другими.
По умолчанию (отсутствие параметра) выводятся записи ото всех, если они не фильтруются другими параметрами.
-
-
allow_signed
— допускать или нет подписанные записи, опубликованные от имени сообщества, если передан параметрowner_only
илиnon_owner_only
/not_owner_only
.По умолчанию (отсутствие параметра) допустимы все записи, которые проходят фильтрацию другими параметрами.
Допустимые значения (регистр не учитывается): [отсутствие значения] (аналог
true
),true
,false
,0
(аналогfalse
),1
(аналогtrue
), все остальные значения воспринимаются какtrue
.- В случае переданного параметра
owner_only
позволяет исключать подписанные записи путем передачи параметраallow_signed
со значениемfalse
. - В случае переданного параметра
non_owner_only
илиnot_owner_only
позволяет дополнительно включать в RSS-ленту подписанные записи путем передачи параметраallow_signed
со значениемtrue
,
- В случае переданного параметра
-
skip_ads
— если передан (можно без значения), то не выводить в RSS-ленту записи, помеченные как реклама.По умолчанию (отсутствие параметра) выводятся все записи, если они не фильтруются другими параметрами.
Примечание: API Вконтакте помечает как рекламу не все записи, которые помечены на стене на сайте, поэтому некоторые рекламные посты параметр не убирает.
-
allow_embedded_video
допускает или нет встраивание видеозаписей в описание RSS записей.По умолчанию [отсутствующий параметр] отключено.
Когда включено, скрипт пытается получить ссылку на видеоплеер, но если
access_token
не имеет разрешенияvideo
, то этот параметр принудительно принимает значениеfalse
.Если скрипту удается получить ссылку на видеоплеер, тогда при включенном HTML форматировании видеозаписи можно проигрывать в читателе RSS, в противном случае видеозаписи отображаются либо в виде кликабельных изображений-превью при включенном HTML форматировании, либо в виде текста при отключенном HTML форматировании.
-
proxy
— адрес прокси-сервера. Допустимые форматы значения этого параметра:address
,address:port
,type://address
,type://address:port
,login:password@address
,login:password@address:port
,type://login:password@address
,type://login:password@address:port
,
где
address
— домен или IP-адрес прокси,port
— порт,type
— тип прокси (HTTPS, SOCKS4, SOCKS4A, SOCKS5),login
иpassword
— логин и пароль для доступа к прокси, если необходимы.Тип прокси и параметры авторизации можно передавать в виде отдельных параметров:
proxy_type
— тип прокси (по умолчанию считается HTTP, если не указано вproxy
иproxy_type
),proxy_login
— логин для доступа к прокси-серверу,proxy_password
— пароль для доступа к прокси-серверу.
Параллельно с сервером PHP (по умолчанию его порт: 9900
) запускается также и сервер на NGINX (порты 8081
для HTTP и 8082
для HTTPS).
Его задача: избавить пользователя от необходимости явно указывать access_token
от standalone-приложения VK, потому что, если его потерять или поменять, то придётся менять все ссылки на подписки в RSS-сервисе/RSS-клиенте, а это неудобно.
Вместо access_token
данный сервер принимает vkrss_access_token
, определенный в файле .env
под строчкой VKRSS_ACCESS_TOKEN
. Значение по умолчанию: vkrssaccesstoken
.
После получения запроса сервер перенаправляет его на PHP-сервер с access_token
, определенным в файле .env
под строчкой VK_ACCESS_TOKEN
и получает ленту ВК.
Также сервер будет доступен по пути, определенному в файле .env
под строчкой FEED_PATH
. Значение по умолчанию: api/vkrss
.
Таким образом, к примеру, эти два запроса аналогичны:
index.php?id=club1&access_token=XXXXXXXXX
и
api/vkrss/index.php?id=club1&vkrss_access_token=YYYYYYYYYY
Для серверного доступа предпочтительна такая схема:
-
Создать собственное standalone-приложение по этой ссылке. По желанию после генерации ключей в настройках приложения можно изменить состояние на «Приложение отключено» — это никак не помешает генерации RSS-ленты.
ВАЖНОЕ: в настоящее время у новосозданных приложений требуется ввод паспортных данных или данных об организации в личном кабинете разработчика, чтобы приложение могло получать доступ к нужным правам.
При этом старые standalone-приложения по-прежнему работают и дают возможность генерировать ключ доступа со всеми нужными правами.
-
После авторизации под нужным профилем пройти по ссылке:
https://oauth.vk.com/authorize?client_id=APP_ID&scope=offline,video,wall,friends&redirect_uri=https%3A%2F%2Foauth.vk.com%2Fblank.html&display=page&response_type=token&revoke=1
где вместо
APP_ID
подставить ID созданного приложения — его можно увидеть, например, в настройках приложения.Указанные в
scope
права доступа включают в себя следующие:offline
— обязательно для формирования бессрочного ключа доступа,video
— для работы параметраallow_embedded_video
,wall
иfriends
— для работы параметраnews_type
.
Если указанные параметры скрипта не будут использоваться, то соответствующие права можно убрать из ссылки.
-
Подтвердить права. В результате в адресной строке будет указан ключ доступа
access_token
— именно это значение и следует использовать в качестве GET-параметра скрипта, генерирующего RSS-ленту. -
При первом использовании токена с IP адреса, отличного от того, с которого получался токен, может выскочить ошибка "API Error 17: Validation required", требующая валидации: для этого необходимо пройти по первой ссылке из описания ошибки и ввести недостающие цифры номера телефона профиля.
В качестве бонуса в статистике созданного приложения можно смотреть частоту запросов к API.
Внимание! Если в настройках безопасности профиля будут завершены сессии приложения, то все сгенерированные через это приложение токены станут невалидными — нужно сформировать новый токен, повторив пункты 2-4.
index.php?id=apiclub&access_token=XXXXXXXXX
index.php?id=-1&access_token=XXXXXXXXX
index.php?id=id1&access_token=XXXXXXXXX
index.php?id=club1&access_token=XXXXXXXXX
index.php?id=club1&disable_html&access_token=XXXXXXXXX # в данных RSS-ленты отсутстуют HTML-сущности
index.php?id=apiclub&count=100&include=рекомендуем&access_token=XXXXXXXXX # выводятся только записи со словом 'рекомендуем'
index.php?id=apiclub&count=100&exclude=рекомендуем&access_token=XXXXXXXXX # выводятся только записи без слова 'рекомендуем'
index.php?id=apiclub&proxy=localhost:8080&access_token=XXXXXXXXX
index.php?id=apiclub&proxy=localhost:8080&proxy_type=https&access_token=XXXXXXXXX
index.php?id=apiclub&proxy=https%3A%2F%2Flocalhost:8080&access_token=XXXXXXXXX
index.php?id=club1&owner_only&access_token=XXXXXXXXX # выводятся только записи от имени сообщества
index.php?id=club1&owner_only&allow_signed=false&access_token=XXXXXXXXX # выводятся только записи от имени сообщества,
# у которых нет подписи
index.php?id=club1&non_owner_only&access_token=XXXXXXXXX # выводятся только записи от пользователей (не от имени сообщества)
index.php?id=club1&non_owner_only&allow_signed&access_token=XXXXXXXXX # выводятся только записи от имени сообщества,
# у которых есть подпись, и записи от пользователей
index.php?id=club1&allow_embedded_video&access_token=XXXXXXXXX # встраивает проигрываемые видеозаписи в описание записи
index.php?id=-1&count=30&repost_delimiter=<hr><hr>{author} пишет:&access_token=XXXXXXXXX
index.php?id=pitertransport&donut&access_token=XXXXXXXXX # Помимо обычных записей, в RSS ленту добавляются записи для донов
index.php?news_type=recent&count=25&access_token=XXXXXXXXX # 25 самых свежих записей из новостной ленты
index.php?news_type=recommended&count=30&access_token=XXXXXXXXX # 30 рекомендуемых записей из новостной ленты
index.php?global_search=запрос&count=300&access_token=XXXXXXXXX # поиск записей, содержащих слово "запрос"
index.php?id=-1&count=100&include=(рекомендуем|приглашаем|\d+)&access_token=XXXXXXXXX
либо аналогичные для сервера с Caddy:
api/vkrss/index.php?id=apiclub&access_token=XXXXXXXXX
api/vkrss/index.php?id=-1&access_token=XXXXXXXXX
api/vkrss/index.php?id=id1&access_token=XXXXXXXXX
api/vkrss/index.php?id=club1&access_token=XXXXXXXXX
api/vkrss/index.php?id=club1&disable_html&access_token=XXXXXXXXX # в данных RSS-ленты отсутстуют HTML-сущности
api/vkrss/index.php?id=apiclub&count=100&include=рекомендуем&access_token=XXXXXXXXX # выводятся только записи со словом 'рекомендуем'
api/vkrss/index.php?id=apiclub&count=100&exclude=рекомендуем&access_token=XXXXXXXXX # выводятся только записи без слова 'рекомендуем'
api/vkrss/index.php?id=apiclub&proxy=localhost:8080&access_token=XXXXXXXXX
api/vkrss/index.php?id=apiclub&proxy=localhost:8080&proxy_type=https&access_token=XXXXXXXXX
api/vkrss/index.php?id=apiclub&proxy=https%3A%2F%2Flocalhost:8080&access_token=XXXXXXXXX
api/vkrss/index.php?id=club1&owner_only&access_token=XXXXXXXXX # выводятся только записи от имени сообщества
api/vkrss/index.php?id=club1&owner_only&allow_signed=false&access_token=XXXXXXXXX # выводятся только записи от имени сообщества,
# у которых нет подписи
api/vkrss/index.php?id=club1&non_owner_only&access_token=XXXXXXXXX # выводятся только записи от пользователей (не от имени сообщества)
api/vkrss/index.php?id=club1&non_owner_only&allow_signed&access_token=XXXXXXXXX # выводятся только записи от имени сообщества,
# у которых есть подпись, и записи от пользователей
api/vkrss/index.php?id=club1&allow_embedded_video&access_token=XXXXXXXXX # встраивает проигрываемые видеозаписи в описание записи
api/vkrss/index.php?id=-1&count=30&repost_delimiter=<hr><hr>{author} пишет:&access_token=XXXXXXXXX
api/vkrss/index.php?id=pitertransport&donut&access_token=XXXXXXXXX # Помимо обычных записей, в RSS ленту добавляются записи для донов
api/vkrss/index.php?news_type=recent&count=25&access_token=XXXXXXXXX # 25 самых свежих записей из новостной ленты
api/vkrss/index.php?news_type=recommended&count=30&access_token=XXXXXXXXX # 30 рекомендуемых записей из новостной ленты
api/vkrss/index.php?global_search=запрос&count=300&access_token=XXXXXXXXX # поиск записей, содержащих слово "запрос"
api/vkrss/index.php?id=-1&count=100&include=(рекомендуем|приглашаем|\d+)&access_token=XXXXXXXXX
Примечание: в последних двух примерах при таком вызове напрямую через
GET-параметры может потребоваться URL-кодирование символов у параметров global_search
, include
и им подобным:
index.php?id=-1&count=100&include=(%D1%80%D0%B5%D0%BA%D0%BE%D0%BC%D0%B5%D0%BD%D0%B4%D1%83%D0%B5%D0%BC%7C%D0%BF%D1%80%D0%B8%D0%B3%D0%BB%D0%B0%D1%88%D0%B0%D0%B5%D0%BC%7C%5Cd%2B)&access_token=XXXXXXXXX
-
Если при запуске скрипта интерпретатор выдает ошибку:
date(): It is not safe to rely on the system's timezone settings. You are required to use the date.timezone setting or the date_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected the timezone 'UTC' for now, but please set date.timezone to select your timezone.
тогда необходимо либо добавить информацию о часовом поясе в конфигурационный файл PHP (параметр
date.timezone
), либо добавить в начале скриптаindex.php
(передrequire_once
) строку, подобнуюdate_default_timezone_set('UTC');
, устанавливающую часовую зонуUTC
для скрипта. -
Если при изменении количества комментариев к записи в вашем агрегаторе RSS-лент запись помечается/ранжируется как новая/обновленная, то для такого случая есть возможность отключить счетчик комментариев, добавив GET-параметр
disable_comments_amount
:index.php?id=-1&disable_comments_amount
илиindex.php?id=-1&disable_comments_amount=1
-
Если при использовании параметра
donut
в результате появляется ошибка API Error 15, то это значит, что:- либо у пользователя, чей ключ доступа использован, не оформлена подписка на VK Donut сообщества
(стоит удостовериться, что в качестве
access_token
используется именно ключ доступа пользователя, у которого есть подписка VK Donut на сообщество с вернымid
); - либо у сообщества отключен VK Donut;
- либо RSS-лента генерируется для стены пользователя, а не сообщества.
- либо у пользователя, чей ключ доступа использован, не оформлена подписка на VK Donut сообщества
(стоит удостовериться, что в качестве